From 49a36bb4929f0bc2f0b9d87ff8331ee41d2cfdfd Mon Sep 17 00:00:00 2001 From: agra Date: Thu, 11 Jun 2026 19:25:49 +0300 Subject: [PATCH] =?UTF-8?q?std:=20the=20prelude=20becomes=20a=20pure=20re-?= =?UTF-8?q?export=20facade=20=E2=80=94=20implementations=20move=20to=20std?= =?UTF-8?q?/core.sx,=20std/fmt.sx,=20std/list.sx?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit std.sx now contains only alias declarations (the re-export mechanism: own decls carry one flat-import level) over three part-files: core.sx (builtins, libc escape hatch, Source_Location/Allocator/Context/Into, the reserved `string` decl — which needs and permits no alias), fmt.sx (print/format/any_to_string/string ops/cstring/alloc_slice), list.sx (List). The namespace tail is unchanged; the part-file namespaces (core/fmt/list) carry alongside it. Consumer surface is byte-identical — every bare prelude name resolves through the aliases (0120/0121 machinery). 37 .ir snapshots re-pinned: pure string-constant renumbering from the changed import graph (digit-normalized diff is empty). Gates: zig build test 426/426, suite 588/588, m3te 23/23, game SxChess builds + bundles. --- CLAUDE.md | 4 +- .../expected/0031-basic-local-fn-return.ir | 3634 ++++++++-------- .../expected/0032-basic-ufcs-return-type.ir | 3534 +++++++-------- .../0044-basic-default-arg-expansion.ir | 2618 +++++------ .../0107-types-int-cmp-in-float-ternary.ir | 2572 +++++------ examples/expected/0200-generics-generic.ir | 2576 +++++------ .../expected/0201-generics-generic-struct.ir | 3010 ++++++------- .../expected/0301-closures-fn-pointers.ir | 2590 +++++------ .../0400-protocols-impl-for-builtin.ir | 2636 +++++------ ...-protocols-parameterized-protocol-value.ir | 2850 ++++++------ ...protocols-generic-struct-protocol-erase.ir | 2864 ++++++------ .../0416-protocols-auto-type-erasure.ir | 3876 +++++++++-------- .../expected/0507-packs-pack-mono-dedup.ir | 2646 +++++------ .../0513-packs-pack-mixed-comptime.ir | 2582 +++++------ .../0518-packs-pack-value-dispatch.ir | 2602 +++++------ .../0528-packs-protocol-pack-methods.ir | 2788 ++++++------ .../0903-optionals-optional-roundtrip.ir | 2862 ++++++------ .../0904-optionals-any-to-string-optional.ir | 2614 +++++------ examples/expected/1004-errors-try.ir | 2586 +++++------ .../1006-errors-inferred-error-sets.ir | 2602 +++++------ examples/expected/1009-errors-catch.ir | 2590 +++++------ .../expected/1202-ffi-cc-c-large-aggregate.ir | 336 +- .../1309-ffi-objc-class-method-lowering.ir | 580 +-- .../1314-ffi-objc-class-dealloc-roundtrip.ir | 636 +-- .../1319-ffi-objc-property-sx-defined.ir | 2906 ++++++------ .../1329-ffi-objc-call-03-selector-sharing.ir | 564 +-- .../1332-ffi-objc-call-06-sret-return.ir | 2770 ++++++------ .../1347-ffi-objc-dsl-07-mangling-table.ir | 628 +-- .../1402-ffi-jni-call-03-methodid-sharing.ir | 498 +-- .../1403-ffi-jni-call-04-jint-return.ir | 492 +-- .../1404-ffi-jni-call-05-jlong-return.ir | 492 +-- .../1405-ffi-jni-call-06-jdouble-return.ir | 492 +-- .../1406-ffi-jni-call-07-jboolean-return.ir | 492 +-- .../1407-ffi-jni-call-08-jobject-return.ir | 492 +-- .../expected/1408-ffi-jni-call-09-static.ir | 492 +-- .../expected/1418-ffi-jni-class-08-call.ir | 492 +-- .../1421-ffi-jni-env-02-lexical-direct.ir | 492 +-- .../expected/1425-ffi-jni-main-03-ctor.ir | 420 +- library/modules/std.sx | 548 +-- library/modules/std/core.sx | 68 + library/modules/std/fmt.sx | 392 ++ library/modules/std/list.sx | 46 + readme.md | 7 +- 43 files changed, 35649 insertions(+), 35322 deletions(-) create mode 100644 library/modules/std/core.sx create mode 100644 library/modules/std/fmt.sx create mode 100644 library/modules/std/list.sx diff --git a/CLAUDE.md b/CLAUDE.md index dcb048f..ba26dbb 100644 --- a/CLAUDE.md +++ b/CLAUDE.md @@ -577,8 +577,8 @@ Wiring a new bundling step: | `implementation_plan.md` | Archive of completed work (closures, protocols, etc.). Do not pick up tasks from here. | | `readme.md` | User-facing language overview — **maintained**. Update it whenever a user-facing sx change lands (new/changed syntax, semantics, gating diagnostics, language behavior), per the docs-track-changes rule. | | `CLAUDE.md` | This file. Session instructions. | -| `library/modules/std.sx` | The prelude (print/format/List/string ops/Context/Allocator) + the namespace tail (`mem`/`xml`/`log`/`fs`/`process`/`socket`/`json`/`cli`/`hash`/`test` carried to flat importers). | -| `library/modules/std/` | Stdlib modules: mem (allocators), fs, process, socket, json, cli, hash, xml, log, trace, test — all but trace carried by the std.sx tail; direct file imports give bare access. | +| `library/modules/std.sx` | The prelude FACADE — pure re-exports (alias decls) over the part-files `std/core.sx` (builtins, libc escape hatch, Context/Allocator/Into/Source_Location/string), `std/fmt.sx` (print/format/*_to_string/string ops), `std/list.sx` (List) + the namespace tail (`mem`/`xml`/`log`/`fs`/`process`/`socket`/`json`/`cli`/`hash`/`test` carried to flat importers). No implementations live here. | +| `library/modules/std/` | Stdlib modules: core, fmt, list (the prelude part-files — consumers reach them through std.sx, not directly), mem (allocators), fs, process, socket, json, cli, hash, xml, log, trace, test — all but trace and the part-files carried by the std.sx tail; direct file imports give bare access. | | `library/modules/ffi/` | FFI bindings: objc, objc_block, sdl3, opengl, raylib, stb, stb_truetype, wasm. | | `library/modules/math/` | scalar / vector2 / matrix44 — one spelling: `#import "modules/math"` (directory import). | | `library/modules/build.sx` | `BuildOptions` compile-time build DSL. See "Bundling lives in sx" above. | diff --git a/examples/expected/0031-basic-local-fn-return.ir b/examples/expected/0031-basic-local-fn-return.ir index a95b529..ef8a92b 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.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 +@str.474 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.475 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.476 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.477 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.478 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.479 = 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.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 }] +@tag.str.480 = private constant [9 x i8] c"Overflow\00" +@tag.str.481 = private constant [3 x i8] c"Io\00" +@tag.str.482 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.483 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.484 = private constant [10 x i8] c"BadEscape\00" +@tag.str.485 = private constant [10 x i8] c"BadNumber\00" +@tag.str.486 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.487 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.488 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.489 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.490 = private constant [13 x i8] c"MissingValue\00" +@tag.str.491 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.492 = 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.480, i64 8 }, { ptr, i64 } { ptr @tag.str.481, i64 2 }, { ptr, i64 } { ptr @tag.str.482, i64 15 }, { ptr, i64 } { ptr @tag.str.483, i64 13 }, { ptr, i64 } { ptr @tag.str.484, i64 9 }, { ptr, i64 } { ptr @tag.str.485, i64 9 }, { ptr, i64 } { ptr @tag.str.486, i64 15 }, { ptr, i64 } { ptr @tag.str.487, i64 14 }, { ptr, i64 } { ptr @tag.str.488, i64 14 }, { ptr, i64 } { ptr @tag.str.489, i64 11 }, { ptr, i64 } { ptr @tag.str.490, i64 12 }, { ptr, i64 } { ptr @tag.str.491, i64 15 }, { ptr, i64 } { ptr @tag.str.492, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@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 [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 +@tn.str.493 = private constant [5 x i8] c"bool\00" +@tn.str.494 = private constant [3 x i8] c"s8\00" +@tn.str.495 = private constant [4 x i8] c"s16\00" +@tn.str.496 = private constant [4 x i8] c"s32\00" +@tn.str.497 = private constant [4 x i8] c"s64\00" +@tn.str.498 = private constant [3 x i8] c"u8\00" +@tn.str.499 = private constant [4 x i8] c"u16\00" +@tn.str.500 = private constant [4 x i8] c"u32\00" +@tn.str.501 = private constant [4 x i8] c"u64\00" +@tn.str.502 = private constant [4 x i8] c"f32\00" +@tn.str.503 = private constant [4 x i8] c"f64\00" +@tn.str.504 = private constant [7 x i8] c"string\00" +@tn.str.505 = private constant [4 x i8] c"Any\00" +@tn.str.506 = private constant [9 x i8] c"noreturn\00" +@tn.str.507 = private constant [6 x i8] c"isize\00" +@tn.str.508 = private constant [6 x i8] c"usize\00" +@tn.str.509 = private constant [5 x i8] c"void\00" +@tn.str.510 = private constant [6 x i8] c"*void\00" +@tn.str.511 = private constant [16 x i8] c"Source_Location\00" +@tn.str.512 = private constant [10 x i8] c"Allocator\00" +@tn.str.513 = private constant [8 x i8] c"Context\00" +@tn.str.514 = private constant [7 x i8] c"[4]s64\00" +@tn.str.515 = private constant [9 x i8] c"[]string\00" +@tn.str.516 = private constant [11 x i8] c"CAllocator\00" +@tn.str.517 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.518 = private constant [4 x i8] c"GPA\00" +@tn.str.519 = private constant [5 x i8] c"*GPA\00" +@tn.str.520 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.521 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.522 = private constant [6 x i8] c"Arena\00" +@tn.str.523 = private constant [7 x i8] c"*Arena\00" +@tn.str.524 = private constant [6 x i8] c"[*]u8\00" +@tn.str.525 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.526 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.527 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.528 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.529 = private constant [9 x i8] c"OpenMode\00" +@tn.str.530 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.531 = private constant [5 x i8] c"File\00" +@tn.str.532 = private constant [6 x i8] c"*File\00" +@tn.str.533 = private constant [6 x i8] c"?File\00" +@tn.str.534 = private constant [8 x i8] c"?string\00" +@tn.str.535 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.536 = private constant [4 x i8] c"*u8\00" +@tn.str.537 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.538 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.539 = private constant [5 x i8] c"*s32\00" +@tn.str.540 = private constant [9 x i8] c"SockAddr\00" +@tn.str.541 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.542 = private constant [5 x i8] c"*u32\00" +@tn.str.543 = private constant [10 x i8] c"JsonError\00" +@tn.str.544 = private constant [6 x i8] c"Array\00" +@tn.str.545 = private constant [7 x i8] c"Object\00" +@tn.str.546 = private constant [6 x i8] c"Value\00" +@tn.str.547 = private constant [7 x i8] c"Member\00" +@tn.str.548 = private constant [9 x i8] c"[*]Value\00" +@tn.str.549 = private constant [7 x i8] c"*Array\00" +@tn.str.550 = private constant [10 x i8] c"[*]Member\00" +@tn.str.551 = private constant [8 x i8] c"*Object\00" +@tn.str.552 = private constant [5 x i8] c"[]u8\00" +@tn.str.553 = private constant [5 x i8] c"Sink\00" +@tn.str.554 = private constant [6 x i8] c"*Sink\00" +@tn.str.555 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.556 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.557 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.558 = private constant [7 x i8] c"Parser\00" +@tn.str.559 = private constant [8 x i8] c"*Parser\00" +@tn.str.560 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.561 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.562 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.563 = private constant [13 x i8] c"Architecture\00" +@tn.str.564 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.565 = private constant [11 x i8] c"() -> bool\00" +@tn.str.566 = private constant [5 x i8] c"*s64\00" +@tn.str.567 = private constant [9 x i8] c"CliError\00" +@tn.str.568 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.569 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.570 = private constant [8 x i8] c"Command\00" +@tn.str.571 = private constant [10 x i8] c"FlagValue\00" +@tn.str.572 = private constant [5 x i8] c"Diag\00" +@tn.str.573 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.574 = private constant [7 x i8] c"Parsed\00" +@tn.str.575 = private constant [8 x i8] c"*Parsed\00" +@tn.str.576 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.577 = private constant [10 x i8] c"[]Command\00" +@tn.str.578 = private constant [6 x i8] c"*Diag\00" +@tn.str.579 = private constant [7 x i8] c"[8]s64\00" +@tn.str.580 = private constant [7 x i8] c"[64]u8\00" +@tn.str.581 = private constant [7 x i8] c"Sha256\00" +@tn.str.582 = private constant [8 x i8] c"*Sha256\00" +@tn.str.583 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.584 = private constant [8 x i8] c"[64]s64\00" +@tn.str.585 = private constant [8 x i8] c"[16]f32\00" +@tn.str.586 = private constant [5 x i8] c"Mat4\00" +@tn.str.587 = private constant [5 x i8] c"Vec2\00" +@tn.str.588 = private constant [6 x i8] c"Point\00" +@tn.str.589 = private constant [11 x i8] c"Shape.rect\00" +@tn.str.590 = private constant [6 x i8] c"Shape\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 [7 x i8] c"*Point\00" +@tn.str.599 = private constant [7 x i8] c"[2]Any\00" +@tn.str.600 = private constant [8 x i8] c"*[2]Any\00" +@tn.str.601 = private constant [7 x i8] c"*Shape\00" +@tn.str.602 = private constant [7 x i8] c"[1]Any\00" +@tn.str.603 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.604 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.605 = private constant [5 x i8] c"*f64\00" +@tn.str.606 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.607 = private constant [11 x i8] c"*Allocator\00" +@tn.str.608 = private constant [9 x i8] c"*Context\00" +@tn.str.609 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.610 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.611 = private constant [8 x i8] c"*Member\00" +@tn.str.612 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.613 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.614 = private constant [9 x i8] c"*Command\00" +@tn.str.615 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.616 = private constant [6 x i8] c"*Mat4\00" +@tn.str.617 = private constant [6 x i8] c"*Vec2\00" +@tn.str.618 = private constant [12 x i8] c"*Shape.rect\00" +@tn.str.619 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.620 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.621 = private constant [7 x i8] c"*Value\00" +@tn.str.622 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.623 = private constant [14 x i8] c"*Architecture\00" +@tn.str.624 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.625 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.626 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.627 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.628 = private constant [9 x i8] c"*[16]f32\00" +@tn.str.629 = private constant [10 x i8] c"*[]string\00" +@tn.str.630 = private constant [6 x i8] c"*[]u8\00" +@tn.str.631 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.632 = private constant [11 x i8] c"*[]Command\00" +@tn.str.633 = private constant [6 x i8] c"**GPA\00" +@tn.str.634 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.635 = private constant [8 x i8] c"**Arena\00" +@tn.str.636 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.637 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.638 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.639 = private constant [7 x i8] c"**File\00" +@tn.str.640 = private constant [5 x i8] c"**u8\00" +@tn.str.641 = private constant [6 x i8] c"**s32\00" +@tn.str.642 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.643 = private constant [6 x i8] c"**u32\00" +@tn.str.644 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.645 = private constant [8 x i8] c"**Array\00" +@tn.str.646 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.647 = private constant [9 x i8] c"**Object\00" +@tn.str.648 = private constant [7 x i8] c"**Sink\00" +@tn.str.649 = private constant [9 x i8] c"**Parser\00" +@tn.str.650 = private constant [6 x i8] c"**s64\00" +@tn.str.651 = private constant [9 x i8] c"**Parsed\00" +@tn.str.652 = private constant [7 x i8] c"**Diag\00" +@tn.str.653 = private constant [9 x i8] c"**Sha256\00" +@tn.str.654 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.655 = private constant [8 x i8] c"***void\00" +@tn.str.656 = private constant [9 x i8] c"**string\00" +@tn.str.657 = private constant [6 x i8] c"**Any\00" +@tn.str.658 = private constant [8 x i8] c"**[]Any\00" +@tn.str.659 = private constant [7 x i8] c"**bool\00" +@tn.str.660 = private constant [8 x i8] c"**Point\00" +@tn.str.661 = private constant [9 x i8] c"**[2]Any\00" +@tn.str.662 = private constant [8 x i8] c"**Shape\00" +@tn.str.663 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.664 = private constant [7 x i8] c"*?File\00" +@tn.str.665 = private constant [9 x i8] c"*?string\00" +@tn.str.666 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.667 = 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.493, i64 4 }, { 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 2 }, { ptr, i64 } { ptr @tn.str.499, i64 3 }, { ptr, i64 } { ptr @tn.str.500, i64 3 }, { ptr, i64 } { ptr @tn.str.501, i64 3 }, { ptr, i64 } { ptr @tn.str.502, i64 3 }, { ptr, i64 } { ptr @tn.str.503, i64 3 }, { ptr, i64 } { ptr @tn.str.504, i64 6 }, { ptr, i64 } { ptr @tn.str.505, i64 3 }, { ptr, i64 } { ptr @tn.str.506, i64 8 }, { ptr, i64 } { ptr @tn.str.507, i64 5 }, { ptr, i64 } { ptr @tn.str.508, i64 5 }, { ptr, i64 } { ptr @tn.str.509, i64 4 }, { ptr, i64 } { ptr @tn.str.510, i64 5 }, { ptr, i64 } { ptr @tn.str.511, i64 15 }, { ptr, i64 } { ptr @tn.str.512, i64 9 }, { ptr, i64 } { ptr @tn.str.513, i64 7 }, { ptr, i64 } { ptr @tn.str.514, i64 6 }, { ptr, i64 } { ptr @tn.str.515, i64 8 }, { ptr, i64 } { ptr @tn.str.516, i64 10 }, { ptr, i64 } { ptr @tn.str.517, i64 11 }, { ptr, i64 } { ptr @tn.str.518, i64 3 }, { ptr, i64 } { ptr @tn.str.519, i64 4 }, { ptr, i64 } { ptr @tn.str.520, i64 10 }, { ptr, i64 } { ptr @tn.str.521, i64 11 }, { ptr, i64 } { ptr @tn.str.522, i64 5 }, { ptr, i64 } { ptr @tn.str.523, i64 6 }, { ptr, i64 } { ptr @tn.str.524, i64 5 }, { ptr, i64 } { ptr @tn.str.525, i64 8 }, { ptr, i64 } { ptr @tn.str.526, i64 9 }, { ptr, i64 } { ptr @tn.str.527, i64 17 }, { ptr, i64 } { ptr @tn.str.528, i64 18 }, { ptr, i64 } { ptr @tn.str.529, i64 8 }, { ptr, i64 } { ptr @tn.str.530, i64 8 }, { ptr, i64 } { ptr @tn.str.531, i64 4 }, { ptr, i64 } { ptr @tn.str.532, i64 5 }, { ptr, i64 } { ptr @tn.str.533, i64 5 }, { ptr, i64 } { ptr @tn.str.534, i64 7 }, { ptr, i64 } { ptr @tn.str.535, i64 10 }, { ptr, i64 } { ptr @tn.str.536, i64 3 }, { ptr, i64 } { ptr @tn.str.537, i64 13 }, { ptr, i64 } { ptr @tn.str.538, i64 14 }, { ptr, i64 } { ptr @tn.str.539, i64 4 }, { ptr, i64 } { ptr @tn.str.540, i64 8 }, { ptr, i64 } { ptr @tn.str.541, i64 9 }, { ptr, i64 } { ptr @tn.str.542, i64 4 }, { ptr, i64 } { ptr @tn.str.543, i64 9 }, { ptr, i64 } { ptr @tn.str.544, i64 5 }, { ptr, i64 } { ptr @tn.str.545, i64 6 }, { ptr, i64 } { ptr @tn.str.546, i64 5 }, { ptr, i64 } { ptr @tn.str.547, i64 6 }, { ptr, i64 } { ptr @tn.str.548, i64 8 }, { ptr, i64 } { ptr @tn.str.549, i64 6 }, { ptr, i64 } { ptr @tn.str.550, i64 9 }, { ptr, i64 } { ptr @tn.str.551, i64 7 }, { ptr, i64 } { ptr @tn.str.552, i64 4 }, { ptr, i64 } { ptr @tn.str.553, i64 4 }, { ptr, i64 } { ptr @tn.str.554, i64 5 }, { ptr, i64 } { ptr @tn.str.555, i64 16 }, { ptr, i64 } { ptr @tn.str.556, i64 14 }, { ptr, i64 } { ptr @tn.str.557, i64 21 }, { ptr, i64 } { ptr @tn.str.558, i64 6 }, { ptr, i64 } { ptr @tn.str.559, i64 7 }, { ptr, i64 } { ptr @tn.str.560, i64 24 }, { ptr, i64 } { ptr @tn.str.561, i64 23 }, { ptr, i64 } { ptr @tn.str.562, i64 15 }, { ptr, i64 } { ptr @tn.str.563, i64 12 }, { ptr, i64 } { ptr @tn.str.564, i64 12 }, { ptr, i64 } { ptr @tn.str.565, i64 10 }, { ptr, i64 } { ptr @tn.str.566, i64 4 }, { ptr, i64 } { ptr @tn.str.567, i64 8 }, { ptr, i64 } { ptr @tn.str.568, i64 8 }, { ptr, i64 } { ptr @tn.str.569, i64 10 }, { ptr, i64 } { ptr @tn.str.570, i64 7 }, { ptr, i64 } { ptr @tn.str.571, i64 9 }, { ptr, i64 } { ptr @tn.str.572, i64 4 }, { ptr, i64 } { ptr @tn.str.573, i64 13 }, { ptr, i64 } { ptr @tn.str.574, i64 6 }, { ptr, i64 } { ptr @tn.str.575, i64 7 }, { ptr, i64 } { ptr @tn.str.576, i64 18 }, { ptr, i64 } { ptr @tn.str.577, i64 9 }, { ptr, i64 } { ptr @tn.str.578, i64 5 }, { ptr, i64 } { ptr @tn.str.579, i64 6 }, { ptr, i64 } { ptr @tn.str.580, i64 6 }, { ptr, i64 } { ptr @tn.str.581, i64 6 }, { ptr, i64 } { ptr @tn.str.582, i64 7 }, { ptr, i64 } { ptr @tn.str.583, i64 7 }, { ptr, i64 } { ptr @tn.str.584, i64 7 }, { ptr, i64 } { ptr @tn.str.585, i64 7 }, { ptr, i64 } { ptr @tn.str.586, i64 4 }, { ptr, i64 } { ptr @tn.str.587, i64 4 }, { ptr, i64 } { ptr @tn.str.588, i64 5 }, { ptr, i64 } { ptr @tn.str.589, i64 10 }, { ptr, i64 } { ptr @tn.str.590, i64 5 }, { 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 6 }, { ptr, i64 } { ptr @tn.str.599, i64 6 }, { ptr, i64 } { ptr @tn.str.600, i64 7 }, { ptr, i64 } { ptr @tn.str.601, i64 6 }, { ptr, i64 } { ptr @tn.str.602, i64 6 }, { ptr, i64 } { ptr @tn.str.603, i64 7 }, { ptr, i64 } { ptr @tn.str.604, i64 7 }, { ptr, i64 } { ptr @tn.str.605, i64 4 }, { ptr, i64 } { ptr @tn.str.606, i64 16 }, { ptr, i64 } { ptr @tn.str.607, i64 10 }, { ptr, i64 } { ptr @tn.str.608, i64 8 }, { ptr, i64 } { ptr @tn.str.609, i64 11 }, { ptr, i64 } { ptr @tn.str.610, i64 14 }, { ptr, i64 } { ptr @tn.str.611, i64 7 }, { ptr, i64 } { ptr @tn.str.612, i64 13 }, { ptr, i64 } { ptr @tn.str.613, i64 9 }, { ptr, i64 } { ptr @tn.str.614, i64 8 }, { ptr, i64 } { ptr @tn.str.615, i64 10 }, { ptr, i64 } { ptr @tn.str.616, i64 5 }, { ptr, i64 } { ptr @tn.str.617, i64 5 }, { ptr, i64 } { ptr @tn.str.618, i64 11 }, { ptr, i64 } { ptr @tn.str.619, i64 9 }, { ptr, i64 } { ptr @tn.str.620, i64 9 }, { ptr, i64 } { ptr @tn.str.621, i64 6 }, { ptr, i64 } { ptr @tn.str.622, i64 16 }, { ptr, i64 } { ptr @tn.str.623, i64 13 }, { ptr, i64 } { ptr @tn.str.624, i64 14 }, { ptr, i64 } { ptr @tn.str.625, i64 7 }, { ptr, i64 } { ptr @tn.str.626, i64 7 }, { ptr, i64 } { ptr @tn.str.627, i64 8 }, { ptr, i64 } { ptr @tn.str.628, i64 8 }, { ptr, i64 } { ptr @tn.str.629, i64 9 }, { ptr, i64 } { ptr @tn.str.630, i64 5 }, { ptr, i64 } { ptr @tn.str.631, i64 11 }, { ptr, i64 } { ptr @tn.str.632, i64 10 }, { ptr, i64 } { ptr @tn.str.633, i64 5 }, { ptr, i64 } { ptr @tn.str.634, i64 12 }, { ptr, i64 } { ptr @tn.str.635, i64 7 }, { ptr, i64 } { ptr @tn.str.636, i64 6 }, { ptr, i64 } { ptr @tn.str.637, i64 10 }, { ptr, i64 } { ptr @tn.str.638, i64 19 }, { ptr, i64 } { ptr @tn.str.639, i64 6 }, { ptr, i64 } { ptr @tn.str.640, i64 4 }, { ptr, i64 } { ptr @tn.str.641, i64 5 }, { ptr, i64 } { ptr @tn.str.642, i64 10 }, { ptr, i64 } { ptr @tn.str.643, i64 5 }, { ptr, i64 } { ptr @tn.str.644, i64 9 }, { ptr, i64 } { ptr @tn.str.645, i64 7 }, { ptr, i64 } { ptr @tn.str.646, i64 10 }, { 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 5 }, { 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 13 }, { ptr, i64 } { ptr @tn.str.655, i64 7 }, { ptr, i64 } { ptr @tn.str.656, i64 8 }, { ptr, i64 } { ptr @tn.str.657, i64 5 }, { ptr, i64 } { ptr @tn.str.658, i64 7 }, { ptr, i64 } { ptr @tn.str.659, i64 6 }, { ptr, i64 } { ptr @tn.str.660, i64 7 }, { ptr, i64 } { ptr @tn.str.661, i64 8 }, { ptr, i64 } { ptr @tn.str.662, i64 7 }, { ptr, i64 } { ptr @tn.str.663, i64 8 }, { ptr, i64 } { ptr @tn.str.664, i64 6 }, { ptr, i64 } { ptr @tn.str.665, i64 8 }, { ptr, i64 } { ptr @tn.str.666, i64 15 }, { ptr, i64 } { ptr @tn.str.667, i64 8 }] @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 [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 +@str.670 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.671 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.672 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.673 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.674 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.675 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.676 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.677 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.678 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.679 = private unnamed_addr constant [6 x i8] c"])); \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 [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.684 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.685 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.686 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.687 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.688 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.689 = private unnamed_addr constant [29 x i8] c"=== 19. Local Fn Return ===\0A\00", align 1 +@str.690 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.691 = private unnamed_addr constant [29 x i8] c"=== 19. Local Fn Return ===\0A\00", align 1 +@str.692 = private unnamed_addr constant [21 x i8] c"local-struct: {} {}\0A\00", align 1 +@str.693 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.694 = private unnamed_addr constant [21 x i8] c"local-struct: {} {}\0A\00", align 1 +@str.695 = private unnamed_addr constant [16 x i8] c"local-enum: {}\0A\00", align 1 +@str.696 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.697 = private unnamed_addr constant [16 x i8] c"local-enum: {}\0A\00", align 1 +@str.698 = private unnamed_addr constant [16 x i8] c"Source_Location\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 @fld.str = private constant [5 x i8] c"file\00" -@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 [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 +@fld.str.702 = private constant [5 x i8] c"line\00" +@fld.str.703 = private constant [4 x i8] c"col\00" +@fld.str.704 = 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.702, i64 4 }, { ptr, i64 } { ptr @fld.str.703, i64 3 }, { ptr, i64 } { ptr @fld.str.704, i64 4 }] +@str.705 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.706 = private unnamed_addr constant [10 x i8] c"Allocator\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 +@fld.str.710 = private constant [4 x i8] c"ctx\00" +@fld.str.711 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.712 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.713 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.710, i64 3 }, { ptr, i64 } { ptr @fld.str.711, i64 11 }, { ptr, i64 } { ptr @fld.str.712, i64 13 }] +@str.714 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.715 = private unnamed_addr constant [8 x i8] c"Context\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 +@fld.str.719 = private constant [10 x i8] c"allocator\00" +@fld.str.720 = private constant [5 x i8] c"data\00" +@field_names.721 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.719, i64 9 }, { ptr, i64 } { ptr @fld.str.720, i64 4 }] +@str.722 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.723 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.724 = private unnamed_addr constant [2 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 [3 x i8] c", \00", align 1 +@field_names.727 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.728 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.729 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.730 = private unnamed_addr constant [2 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 [3 x i8] c", \00", align 1 +@fld.str.733 = private constant [12 x i8] c"alloc_count\00" +@field_names.734 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.733, i64 11 }] +@str.735 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.736 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.741 = private constant [4 x i8] c"cap\00" +@field_names.742 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.740, i64 4 }, { ptr, i64 } { ptr @fld.str.741, i64 3 }] +@str.743 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.744 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.745 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.746 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.747 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.748 = private constant [6 x i8] c"first\00" +@fld.str.749 = private constant [10 x i8] c"end_index\00" +@fld.str.750 = private constant [7 x i8] c"parent\00" +@field_names.751 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.748, i64 5 }, { ptr, i64 } { ptr @fld.str.749, i64 9 }, { ptr, i64 } { ptr @fld.str.750, i64 6 }] +@str.752 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.753 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.754 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.755 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.756 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.757 = private constant [4 x i8] c"buf\00" +@fld.str.758 = private constant [4 x i8] c"len\00" +@fld.str.759 = private constant [4 x i8] c"pos\00" +@field_names.760 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.757, i64 3 }, { ptr, i64 } { ptr @fld.str.758, i64 3 }, { ptr, i64 } { ptr @fld.str.759, i64 3 }] +@str.761 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.762 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 [7 x i8] c"parent\00" +@fld.str.767 = private constant [12 x i8] c"alloc_count\00" +@fld.str.768 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.769 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.770 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.766, i64 6 }, { ptr, i64 } { ptr @fld.str.767, i64 11 }, { ptr, i64 } { ptr @fld.str.768, i64 13 }, { ptr, i64 } { ptr @fld.str.769, i64 17 }] +@str.771 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.772 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.773 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.774 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.775 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.776 = private constant [3 x i8] c"fd\00" +@field_names.777 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.776, i64 2 }] +@str.778 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.779 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.780 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.781 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.782 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.783 = private constant [5 x i8] c"file\00" +@fld.str.784 = private constant [5 x i8] c"line\00" +@fld.str.785 = private constant [4 x i8] c"col\00" +@fld.str.786 = private constant [5 x i8] c"func\00" +@fld.str.787 = private constant [10 x i8] c"line_text\00" +@field_names.788 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.783, i64 4 }, { ptr, i64 } { ptr @fld.str.784, i64 4 }, { ptr, i64 } { ptr @fld.str.785, i64 3 }, { ptr, i64 } { ptr @fld.str.786, i64 4 }, { ptr, i64 } { ptr @fld.str.787, i64 9 }] +@str.789 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.790 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.791 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.792 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.793 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.794 = private constant [10 x i8] c"exit_code\00" +@fld.str.795 = private constant [7 x i8] c"stdout\00" +@field_names.796 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.794, i64 9 }, { ptr, i64 } { ptr @fld.str.795, i64 6 }] +@str.797 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.798 = private unnamed_addr constant [9 x i8] c"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.803 = private constant [11 x i8] c"sin_family\00" +@fld.str.804 = private constant [9 x i8] c"sin_port\00" +@fld.str.805 = private constant [9 x i8] c"sin_addr\00" +@fld.str.806 = private constant [9 x i8] c"sin_zero\00" +@field_names.807 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.802, i64 7 }, { ptr, i64 } { ptr @fld.str.803, i64 10 }, { ptr, i64 } { ptr @fld.str.804, i64 8 }, { ptr, i64 } { ptr @fld.str.805, i64 8 }, { ptr, i64 } { ptr @fld.str.806, i64 8 }] +@str.808 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.809 = private unnamed_addr constant [6 x i8] c"Array\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"Object\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 [6 x i8] c"items\00" +@fld.str.823 = private constant [4 x i8] c"len\00" +@fld.str.824 = private constant [4 x i8] c"cap\00" +@field_names.825 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.822, i64 5 }, { ptr, i64 } { ptr @fld.str.823, i64 3 }, { ptr, i64 } { ptr @fld.str.824, i64 3 }] +@str.826 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.827 = private unnamed_addr constant [7 x i8] c"Member\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"key\00" +@fld.str.832 = private constant [4 x i8] c"val\00" +@field_names.833 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.831, i64 3 }, { ptr, i64 } { ptr @fld.str.832, i64 3 }] +@str.834 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.835 = private unnamed_addr constant [5 x i8] c"Sink\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"dst\00" +@fld.str.840 = private constant [4 x i8] c"pos\00" +@fld.str.841 = private constant [5 x i8] c"file\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 4 }] +@str.843 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.844 = private unnamed_addr constant [7 x i8] c"Parser\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 +@fld.str.848 = private constant [4 x i8] c"src\00" +@fld.str.849 = private constant [4 x i8] c"pos\00" +@fld.str.850 = private constant [6 x i8] c"alloc\00" +@field_names.851 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.848, i64 3 }, { ptr, i64 } { ptr @fld.str.849, i64 3 }, { ptr, i64 } { ptr @fld.str.850, i64 5 }] +@str.852 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.853 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.854 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.855 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.856 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.857 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.858 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.859 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.864 = private constant [12 x i8] c"takes_value\00" +@fld.str.865 = private constant [9 x i8] c"required\00" +@field_names.866 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.863, i64 4 }, { ptr, i64 } { ptr @fld.str.864, i64 11 }, { ptr, i64 } { ptr @fld.str.865, i64 8 }] +@str.867 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.868 = private unnamed_addr constant [8 x i8] c"Command\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"group\00" +@fld.str.873 = private constant [8 x i8] c"command\00" +@fld.str.874 = private constant [6 x i8] c"flags\00" +@field_names.875 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.872, i64 5 }, { ptr, i64 } { ptr @fld.str.873, i64 7 }, { ptr, i64 } { ptr @fld.str.874, i64 5 }] +@str.876 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.877 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.878 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.879 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.880 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.881 = private constant [4 x i8] c"set\00" +@fld.str.882 = private constant [6 x i8] c"value\00" +@field_names.883 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.881, i64 3 }, { ptr, i64 } { ptr @fld.str.882, i64 5 }] +@str.884 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.885 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.886 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.887 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.888 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.889 = private constant [6 x i8] c"index\00" +@fld.str.890 = private constant [6 x i8] c"token\00" +@field_names.891 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.889, i64 5 }, { ptr, i64 } { ptr @fld.str.890, i64 5 }] +@str.892 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.893 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.894 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.895 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.896 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.897 = private constant [6 x i8] c"group\00" +@fld.str.898 = private constant [8 x i8] c"command\00" +@fld.str.899 = private constant [10 x i8] c"cmd_index\00" +@fld.str.900 = private constant [5 x i8] c"json\00" +@fld.str.901 = private constant [5 x i8] c"rest\00" +@fld.str.902 = private constant [5 x i8] c"spec\00" +@fld.str.903 = private constant [7 x i8] c"values\00" +@field_names.904 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.897, i64 5 }, { ptr, i64 } { ptr @fld.str.898, i64 7 }, { ptr, i64 } { ptr @fld.str.899, i64 9 }, { ptr, i64 } { ptr @fld.str.900, i64 4 }, { ptr, i64 } { ptr @fld.str.901, i64 4 }, { ptr, i64 } { ptr @fld.str.902, i64 4 }, { ptr, i64 } { ptr @fld.str.903, i64 6 }] +@str.905 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.906 = private unnamed_addr constant [7 x i8] c"Sha256\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"h\00" +@fld.str.911 = private constant [4 x i8] c"buf\00" +@fld.str.912 = private constant [8 x i8] c"buf_len\00" +@fld.str.913 = private constant [10 x i8] c"total_len\00" +@field_names.914 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.910, i64 1 }, { ptr, i64 } { ptr @fld.str.911, i64 3 }, { ptr, i64 } { ptr @fld.str.912, i64 7 }, { ptr, i64 } { ptr @fld.str.913, i64 9 }] +@str.915 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.916 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 +@str.917 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.918 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.919 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.920 = private constant [5 x i8] c"data\00" +@field_names.921 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.920, i64 4 }] +@str.922 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.923 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 +@str.924 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.925 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.926 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.927 = private constant [2 x i8] c"x\00" +@fld.str.928 = private constant [2 x i8] c"y\00" +@field_names.929 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.927, i64 1 }, { ptr, i64 } { ptr @fld.str.928, i64 1 }] +@str.930 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.931 = private unnamed_addr constant [6 x i8] c"Point\00", align 1 +@str.932 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.933 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.934 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.935 = private constant [2 x i8] c"x\00" +@fld.str.936 = private constant [2 x i8] c"y\00" +@field_names.937 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.935, i64 1 }, { ptr, i64 } { ptr @fld.str.936, i64 1 }] +@str.938 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.939 = private unnamed_addr constant [11 x i8] c"Shape.rect\00", align 1 +@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 [3 x i8] c", \00", align 1 +@fld.str.943 = private constant [2 x i8] c"w\00" +@fld.str.944 = private constant [2 x i8] c"h\00" +@field_names.945 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.943, i64 1 }, { ptr, i64 } { ptr @fld.str.944, i64 1 }] +@str.946 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.947 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.948 = private constant [5 x i8] c"read\00" +@fld.str.949 = private constant [6 x i8] c"write\00" +@fld.str.950 = private constant [7 x i8] c"append\00" +@fld.str.951 = private constant [11 x i8] c"read_write\00" +@field_names.952 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.948, i64 4 }, { ptr, i64 } { ptr @fld.str.949, i64 5 }, { ptr, i64 } { ptr @fld.str.950, i64 6 }, { ptr, i64 } { ptr @fld.str.951, i64 10 }] +@str.953 = private unnamed_addr constant [2 x i8] c"(\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 +@fld.str.956 = private constant [4 x i8] c"set\00" +@fld.str.957 = private constant [8 x i8] c"current\00" +@fld.str.958 = private constant [4 x i8] c"end\00" +@field_names.959 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.956, i64 3 }, { ptr, i64 } { ptr @fld.str.957, i64 7 }, { ptr, i64 } { ptr @fld.str.958, i64 3 }] +@str.960 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@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 +@fld.str.963 = private constant [6 x i8] c"null_\00" +@fld.str.964 = private constant [6 x i8] c"bool_\00" +@fld.str.965 = private constant [5 x i8] c"int_\00" +@fld.str.966 = private constant [4 x i8] c"str\00" +@fld.str.967 = private constant [6 x i8] c"array\00" +@fld.str.968 = private constant [7 x i8] c"object\00" +@field_names.969 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.963, i64 5 }, { ptr, i64 } { ptr @fld.str.964, i64 5 }, { ptr, i64 } { ptr @fld.str.965, i64 4 }, { ptr, i64 } { ptr @fld.str.966, i64 3 }, { ptr, i64 } { ptr @fld.str.967, i64 5 }, { ptr, i64 } { ptr @fld.str.968, i64 6 }] +@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 +@fld.str.973 = private constant [6 x i8] c"macos\00" +@fld.str.974 = private constant [6 x i8] c"linux\00" +@fld.str.975 = private constant [8 x i8] c"windows\00" +@fld.str.976 = private constant [5 x i8] c"wasm\00" +@fld.str.977 = private constant [4 x i8] c"ios\00" +@fld.str.978 = private constant [8 x i8] c"android\00" +@fld.str.979 = private constant [8 x i8] c"unknown\00" +@field_names.980 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.973, i64 5 }, { ptr, i64 } { ptr @fld.str.974, i64 5 }, { ptr, i64 } { ptr @fld.str.975, i64 7 }, { ptr, i64 } { ptr @fld.str.976, i64 4 }, { ptr, i64 } { ptr @fld.str.977, i64 3 }, { ptr, i64 } { ptr @fld.str.978, i64 7 }, { 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 [8 x i8] c"aarch64\00" +@fld.str.985 = private constant [7 x i8] c"x86_64\00" +@fld.str.986 = private constant [7 x i8] c"wasm32\00" +@fld.str.987 = private constant [7 x i8] c"wasm64\00" +@fld.str.988 = private constant [8 x i8] c"unknown\00" +@field_names.989 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.984, i64 7 }, { ptr, i64 } { ptr @fld.str.985, i64 6 }, { ptr, i64 } { ptr @fld.str.986, i64 6 }, { ptr, i64 } { ptr @fld.str.987, i64 6 }, { ptr, i64 } { ptr @fld.str.988, i64 7 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.993 = private constant [7 x i8] c"circle\00" +@fld.str.994 = private constant [5 x i8] c"rect\00" +@fld.str.995 = private constant [5 x i8] c"none\00" +@field_names.996 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.993, i64 6 }, { ptr, i64 } { ptr @fld.str.994, i64 4 }, { ptr, i64 } { ptr @fld.str.995, i64 4 }] +@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 [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 [2 x i8] c"[\00", align 1 +@str.1030 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1031 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.1034 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@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 [3 x i8] c", \00", align 1 +@str.1038 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1039 = private unnamed_addr constant [6 x i8] c"*void\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 [12 x i8] c"*CAllocator\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"*GPA\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 [12 x i8] c"*ArenaChunk\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"*Arena\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"[*]u8\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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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 [6 x i8] c"*File\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 [4 x i8] c"*u8\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 [5 x i8] c"*s32\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 [10 x i8] c"*SockAddr\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 [5 x i8] c"*u32\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 [9 x i8] c"[*]Value\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"*Array\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 [10 x i8] c"[*]Member\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 [8 x i8] c"*Object\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 [6 x i8] c"*Sink\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 [8 x i8] c"*Parser\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 [5 x i8] c"*s64\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 [8 x i8] c"*Parsed\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 [6 x i8] c"*Diag\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"*Sha256\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 [13 x i8] c"**CAllocator\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"**void\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 [8 x i8] c"*string\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 [5 x i8] c"*Any\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 [7 x i8] c"*[]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 [6 x i8] c"*bool\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 [7 x i8] c"*Point\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 [8 x i8] c"*[2]Any\00", align 1 +@str.1130 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1131 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1132 = private unnamed_addr constant [7 x i8] c"*Shape\00", align 1 +@str.1133 = private unnamed_addr constant [4 x i8] c"@0x\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 +@str.1135 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.1136 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1137 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1138 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1139 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1140 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -688,85 +688,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -909,7 +831,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.470, i64 1 } + ret { ptr, i64 } { ptr @str.474, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1036,7 +958,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.471, i64 4 }, %if.then.78 ], [ { ptr @str.472, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.475, i64 4 }, %if.then.78 ], [ { ptr @str.476, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1370,7 +1292,7 @@ entry: br i1 %icmp, label %if.then.410, label %if.merge.411 if.then.410: ; preds = %entry - ret { ptr, i64 } { ptr @str.473, i64 1 } + ret { ptr, i64 } { ptr @str.477, i64 1 } if.merge.411: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1520,7 +1442,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.474, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.478, 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 @@ -1547,12 +1469,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1582,7 +1504,7 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 @@ -1590,19 +1512,19 @@ entry: i64 93, label %match.arm.47 i64 107, label %match.arm.47 i64 110, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 102, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1640,7 +1562,7 @@ match.merge.37: ; preds = %dispatch.merge.519, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.475, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.479, 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 @@ -1685,12 +1607,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1746,7 +1668,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.291 [ - i64 35, label %dispatch.case.292 + i64 22, label %dispatch.case.292 i64 81, label %dispatch.case.293 i64 87, label %dispatch.case.294 i64 88, label %dispatch.case.295 @@ -1761,7 +1683,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.341 [ - i64 36, label %dispatch.case.342 + i64 23, label %dispatch.case.342 i64 60, label %dispatch.case.343 i64 77, label %dispatch.case.344 i64 85, label %dispatch.case.345 @@ -1774,13 +1696,13 @@ 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 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 - i64 33, label %dispatch.case.381 + i64 25, label %dispatch.case.375 + i64 27, label %dispatch.case.376 + i64 29, label %dispatch.case.377 + i64 31, label %dispatch.case.378 + i64 32, label %dispatch.case.379 + i64 34, label %dispatch.case.380 + i64 36, label %dispatch.case.381 i64 40, label %dispatch.case.382 i64 44, label %dispatch.case.383 i64 47, label %dispatch.case.384 @@ -1876,7 +1798,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.664, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.668, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1898,56 +1820,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2117,7 +2039,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.665, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.669, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.270 dispatch.case.272: ; preds = %match.arm.44 @@ -2166,7 +2088,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.666, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.670, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.290 dispatch.case.292: ; preds = %match.arm.47 @@ -2239,7 +2161,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.667, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.671, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.340 dispatch.case.342: ; preds = %match.arm.48 @@ -2288,7 +2210,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.668, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.672, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.372 dispatch.case.374: ; preds = %match.arm.49 @@ -2528,7 +2450,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.669, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.673, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.519 dispatch.case.521: ; preds = %match.arm.50 @@ -2570,7 +2492,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.670, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.674, 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 +2588,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.671, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, 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 +2596,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.672, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2684,13 +2606,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.673, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, 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.674, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, 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 +2620,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.675, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.679, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2712,7 +2634,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.676, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, 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 +2642,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.677, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2731,7 +2653,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.678, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.682, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2788,7 +2710,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.679, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.683, 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 +2718,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.680, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2807,7 +2729,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.681, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.685, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2827,7 +2749,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.682, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.686, 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 +2757,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.683, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -2846,7 +2768,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.684, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.688, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2856,67 +2778,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3092,166 +3098,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3449,64 +3455,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3536,97 +3542,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3665,7 +3671,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind declare void @Mat4.identity(ptr sret({ [16 x float] }), ptr) #0 @@ -3734,1033 +3740,1039 @@ 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.127(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.128(i64, ptr) #0 +declare void @BuildOptions.add_framework.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.129(i64, ptr) #0 +declare void @BuildOptions.set_output_path.131(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.132(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.133(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.132(i64) #0 +declare i64 @BuildOptions.asset_dir_count.134(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.135(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.136(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.137(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.138(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.137(i64) #0 +declare ptr @BuildOptions.binary_path.139(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.141(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.142(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.143(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.142(i64) #0 +declare ptr @BuildOptions.bundle_path.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.143(i64) #0 +declare ptr @BuildOptions.bundle_id.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.144(i64) #0 +declare ptr @BuildOptions.codesign_identity.146(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.145(i64) #0 +declare ptr @BuildOptions.provisioning_profile.147(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.146(i64) #0 +declare ptr @BuildOptions.target_triple.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.147(i64) #0 +declare i1 @BuildOptions.is_macos.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.148(i64) #0 +declare i1 @BuildOptions.is_ios.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.149(i64) #0 +declare i1 @BuildOptions.is_ios_device.151(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.152(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.151(i64) #0 +declare i1 @BuildOptions.is_android.153(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.152(i64) #0 +declare i64 @BuildOptions.framework_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.154(i64) #0 +declare i64 @BuildOptions.framework_path_count.156(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.157(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.158(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.159(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.158(i64) #0 +declare ptr @BuildOptions.manifest_path.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.159(i64) #0 +declare ptr @BuildOptions.keystore_path.161(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.160(i64) #0 +declare i64 @BuildOptions.jni_main_count.162(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.163(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.164(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.163() #0 +declare i64 @build_options.165() #0 ; Function Attrs: nounwind -declare void @assert.164(ptr, i1) #0 +declare void @assert.166(ptr, i1) #0 ; Function Attrs: nounwind -declare void @out.165(ptr) #0 +declare void @out.167(ptr) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.166(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.168(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.167(ptr, ptr, i64) #0 +declare ptr @cstring.169(ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.168(ptr, ptr, ptr) #0 +declare ptr @int_to_string.170(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.169(ptr) #0 +declare ptr @uint_to_string.171(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.170(ptr, ptr, i64) #0 +declare ptr @bool_to_string.172(ptr, i1) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.171(ptr, ptr, ptr) #0 +declare ptr @float_to_string.173(ptr, double) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.172(ptr, ptr, i64) #0 +declare void @hex_group.174(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.173(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare [4 x i64] @decompose_u16x4.175(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.174(ptr, ptr) #0 +declare ptr @int_to_hex_string.176(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.175(ptr, ptr) #0 +declare ptr @concat.177(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.176(ptr, ptr, i64) #0 +declare ptr @substr.178(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.177(ptr, ptr, ptr) #0 +declare ptr @path_join.179(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.178(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare ptr @any_to_string.180(ptr, [2 x i64]) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.179(ptr, ptr) #0 +declare ptr @build_format.181(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.180(ptr, ptr, i64) #0 +declare void @out.182(ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.181(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.183(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.182(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.184(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.183(ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.185(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.184(ptr, ptr) #0 +declare i64 @GPA.init.186(ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.185(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.187(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.186(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.188(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @cstring.187(ptr, i64) #0 +declare void @Arena.add_chunk.189(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_string.188(ptr, i64) #0 +declare void @Arena.init.190(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @uint_to_string.189(ptr, i64) #0 +declare void @Arena.reset.191(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @bool_to_string.190(ptr, i1) #0 +declare void @Arena.deinit.192(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @float_to_string.191(ptr, double) #0 +declare ptr @Arena.alloc_bytes.193(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @hex_group.192(ptr, ptr, i64, i64) #0 +declare void @Arena.dealloc_bytes.194(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [4 x i64] @decompose_u16x4.193(ptr, i64) #0 +declare void @BufAlloc.init.195(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_hex_string.194(ptr, i64) #0 +declare void @BufAlloc.reset.196(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @concat.195(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.197(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @substr.196(ptr, ptr, i64, i64) #0 +declare void @BufAlloc.dealloc_bytes.198(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @path_join.197(ptr, ptr) #0 +declare void @TrackingAllocator.init.199(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @any_to_string.198(ptr, [2 x i64]) #0 +declare i64 @TrackingAllocator.leak_count.200(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @build_format.199(ptr, ptr) #0 +declare void @TrackingAllocator.report.201(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.200(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.202(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.201(ptr, ptr, i64) #0 +declare void @TrackingAllocator.dealloc_bytes.203(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.202(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.204(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.203(ptr) #0 +declare ptr @CAllocator.alloc_bytes.205(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.204(ptr, ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.206(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.205(ptr, ptr, ptr) #0 +declare i64 @GPA.init.207(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.206(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.208(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.207(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.209(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.reset.208(ptr, ptr) #0 +declare void @Arena.add_chunk.210(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.209(ptr, ptr) #0 +declare void @Arena.init.211(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.210(ptr, ptr, i64) #0 +declare void @Arena.reset.212(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.211(ptr, ptr, ptr) #0 +declare void @Arena.deinit.213(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.212(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.214(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.213(ptr, ptr) #0 +declare void @Arena.dealloc_bytes.215(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.214(ptr, ptr, i64) #0 +declare void @BufAlloc.init.216(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.215(ptr, ptr, ptr) #0 +declare void @BufAlloc.reset.217(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.216(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.218(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.217(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.219(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.218(ptr, ptr) #0 +declare void @TrackingAllocator.init.220(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.219(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.221(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.220(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.222(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @escape.221(ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.223(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @log_emit.222(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.224(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.223(ptr, i32, ...) #0 +declare ptr @escape.225(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.224(i32) #0 +declare void @log_emit.226(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.225(i32, ptr, i64) #0 +declare i32 @open.227(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.226(i32, i64, i32) #0 +declare i32 @close.228(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.227(ptr) #0 +declare i64 @read.229(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.228(ptr) #0 +declare i64 @lseek.230(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.229(ptr, i32) #0 +declare i32 @unlink.231(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.230(ptr, i32) #0 +declare i32 @rmdir.232(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.231(ptr, i32) #0 +declare i32 @mkdir.233(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.232(ptr, ptr) #0 +declare i32 @access.234(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.233(ptr, ptr) #0 +declare i32 @chmod.235(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.234(ptr, ptr) #0 +declare i32 @rename.236(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.235(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.237(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.236(ptr, ptr, ptr) #0 +declare i1 @File.close.238(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.237(ptr, ptr, i64, i64) #0 +declare i64 @File.read.239(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.238(ptr, i64) #0 +declare i64 @File.write.240(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.239(ptr, ptr, i64) #0 +declare i64 @File.seek.241(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.240(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.242(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.241(ptr, ptr, ptr) #0 +declare i64 @open_file.243(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.242(ptr, ptr, ptr) #0 +declare void @read_file.244(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.243(ptr, ptr) #0 +declare i1 @write_file.245(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.244(ptr, ptr) #0 +declare i1 @append_file.246(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.245(ptr, ptr) #0 +declare i1 @exists.247(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.246(ptr, ptr) #0 +declare i1 @delete_file.248(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.247(ptr, ptr, i32) #0 +declare i1 @delete_dir.249(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.248(ptr, ptr, ptr) #0 +declare i1 @create_dir.250(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.249(ptr, ptr) #0 +declare i1 @set_mode.251(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.250(ptr, ptr, ptr) #0 +declare i1 @move.252(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.251(ptr, ptr) #0 +declare i1 @create_dir_all.253(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.252(ptr, ptr) #0 +declare i1 @copy_file.254(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @spaces.253(ptr, i32) #0 +declare ptr @basename.255(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.254() #0 +declare ptr @dirname.256(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.255() #0 +declare ptr @spaces.257(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.256(i32) #0 +declare i32 @sx_trace_len.258() #0 ; Function Attrs: nounwind -declare ptr @to_string.257(ptr) #0 +declare i32 @sx_trace_truncated.259() #0 ; Function Attrs: nounwind -declare void @print_current.258(ptr) #0 +declare i64 @sx_trace_frame_at.260(i32) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.259(ptr) #0 +declare ptr @to_string.261(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.260(ptr, ptr) #0 +declare void @print_current.262(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.261(ptr) #0 +declare void @print_interpreter_frames.263(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.262(ptr, i64, i64, ptr) #0 +declare ptr @popen.264(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.263(ptr) #0 +declare i32 @pclose.265(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.264(ptr) #0 +declare i64 @fread.266(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.265(ptr) #0 +declare i32 @feof.267(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.266(ptr) #0 +declare ptr @getenv.268(ptr) #0 ; Function Attrs: nounwind -declare void @run.267(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare i64 @strlen.269(ptr) #0 ; Function Attrs: nounwind -declare void @env.268(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.270(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.269(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @run.271(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.270(i32) #0 +declare void @env.272(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.271(ptr, i8, ptr) #0 +declare void @find_executable.273(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.272(ptr, i1, ptr, ptr) #0 +declare void @_exit.274(i32) #0 ; Function Attrs: nounwind -declare i32 @socket.273(i32, i32, i32) #0 +declare void @exit.275(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @setsockopt.274(i32, i32, i32, ptr, i32) #0 +declare void @assert.276(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @bind.275(i32, ptr, i32) #0 +declare i32 @socket.277(i32, i32, i32) #0 ; Function Attrs: nounwind -declare i32 @listen.276(i32, i32) #0 +declare i32 @setsockopt.278(i32, i32, i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @accept.277(i32, ptr, ptr) #0 +declare i32 @bind.279(i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @read.278(i32, ptr, i64) #0 +declare i32 @listen.280(i32, i32) #0 ; Function Attrs: nounwind -declare i32 @close.279(i32) #0 +declare i32 @accept.281(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i16 @htons.280(ptr, i64) #0 +declare i64 @read.282(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.281(ptr, ptr, ptr, i64, i64, i64) #0 +declare i32 @close.283(i32) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.282(ptr, ptr, i64) #0 +declare i16 @htons.284(ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.283(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.285(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.284(ptr) #0 +declare ptr @CAllocator.alloc_bytes.286(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.285(ptr, ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.287(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.286(ptr, ptr, ptr) #0 +declare i64 @GPA.init.288(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.287(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.289(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.288(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.290(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.reset.289(ptr, ptr) #0 +declare void @Arena.add_chunk.291(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.290(ptr, ptr) #0 +declare void @Arena.init.292(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.291(ptr, ptr, i64) #0 +declare void @Arena.reset.293(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.292(ptr, ptr, ptr) #0 +declare void @Arena.deinit.294(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.293(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.295(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.294(ptr, ptr) #0 +declare void @Arena.dealloc_bytes.296(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.295(ptr, ptr, i64) #0 +declare void @BufAlloc.init.297(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.296(ptr, ptr, ptr) #0 +declare void @BufAlloc.reset.298(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.297(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.299(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.298(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.300(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.299(ptr, ptr) #0 +declare void @TrackingAllocator.init.301(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.300(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.302(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.301(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.303(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.302(ptr, i32, ...) #0 +declare ptr @TrackingAllocator.alloc_bytes.304(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.303(i32) #0 +declare void @TrackingAllocator.dealloc_bytes.305(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.304(i32, ptr, i64) #0 +declare i32 @open.306(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.305(i32, i64, i32) #0 +declare i32 @close.307(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.306(ptr) #0 +declare i64 @read.308(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.307(ptr) #0 +declare i64 @lseek.309(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.308(ptr, i32) #0 +declare i32 @unlink.310(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.309(ptr, i32) #0 +declare i32 @rmdir.311(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.310(ptr, i32) #0 +declare i32 @mkdir.312(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.311(ptr, ptr) #0 +declare i32 @access.313(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.312(ptr, ptr) #0 +declare i32 @chmod.314(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.313(ptr, ptr) #0 +declare i32 @rename.315(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.314(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.316(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.315(ptr, ptr, ptr) #0 +declare i1 @File.close.317(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.316(ptr, ptr, i64, i64) #0 +declare i64 @File.read.318(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.317(ptr, i64) #0 +declare i64 @File.write.319(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.318(ptr, ptr, i64) #0 +declare i64 @File.seek.320(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.319(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.321(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.320(ptr, ptr, ptr) #0 +declare i64 @open_file.322(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.321(ptr, ptr, ptr) #0 +declare void @read_file.323(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.322(ptr, ptr) #0 +declare i1 @write_file.324(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.323(ptr, ptr) #0 +declare i1 @append_file.325(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.324(ptr, ptr) #0 +declare i1 @exists.326(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.325(ptr, ptr) #0 +declare i1 @delete_file.327(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.326(ptr, ptr, i32) #0 +declare i1 @delete_dir.328(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.327(ptr, ptr, ptr) #0 +declare i1 @create_dir.329(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.328(ptr, ptr) #0 +declare i1 @set_mode.330(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.329(ptr, ptr, ptr) #0 +declare i1 @move.331(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.330(ptr, ptr) #0 +declare i1 @create_dir_all.332(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.331(ptr, ptr) #0 +declare i1 @copy_file.333(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.add.332(ptr, ptr, ptr, ptr) #0 +declare ptr @basename.334(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.deinit.333(ptr, ptr, ptr) #0 +declare ptr @dirname.335(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.put.334(ptr, ptr, ptr, ptr, ptr) #0 +declare void @Array.add.336(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.deinit.335(ptr, ptr, ptr) #0 +declare void @Array.deinit.337(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put_byte.336(ptr, ptr, i8) #0 +declare void @Object.put.338(ptr, ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put.337(ptr, ptr, ptr) #0 +declare void @Object.deinit.339(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.flush.338(ptr, ptr) #0 +declare i32 @Sink.put_byte.340(ptr, ptr, i8) #0 ; Function Attrs: nounwind -declare i8 @hex_digit.339(ptr, i64) #0 +declare i32 @Sink.put.341(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_u_escape.340(ptr, i8, ptr) #0 +declare i32 @Sink.flush.342(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_string.341(ptr, ptr, ptr) #0 +declare i8 @hex_digit.343(ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @write_int.342(ptr, i64, ptr) #0 +declare i32 @write_u_escape.344(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_value.343(ptr, ptr, ptr) #0 +declare i32 @write_string.345(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_array.344(ptr, ptr, ptr) #0 +declare i32 @write_int.346(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_object.345(ptr, ptr, ptr) #0 +declare i32 @write_value.347(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @write_to_buffer.346(ptr, ptr, ptr) #0 +declare i32 @write_array.348(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_to_file.347(ptr, ptr, ptr, ptr) #0 +declare i32 @write_object.349(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @hex_value.348(ptr, i8) #0 +declare [2 x i64] @write_to_buffer.350(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @encode_utf8.349(ptr, i64, ptr) #0 +declare i32 @write_to_file.351(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.skip_ws.350(ptr, ptr) #0 +declare [2 x i64] @hex_value.352(ptr, i8) #0 ; Function Attrs: nounwind -declare i32 @Parser.expect_lit.351(ptr, ptr, ptr) #0 +declare i64 @encode_utf8.353(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.read_hex4.352(ptr, ptr, i64, i64) #0 +declare void @Parser.skip_ws.354(ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.decode_into.353(ptr, ptr, i64, i64, ptr) #0 +declare i32 @Parser.expect_lit.355(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_string.354(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.read_hex4.356(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.parse_number.355(ptr, ptr) #0 +declare [2 x i64] @Parser.decode_into.357(ptr, ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_array.356(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare void @Parser.parse_string.358(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_object.357(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.parse_number.359(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_value.358(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare void @Parser.parse_array.360(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.359(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 +declare void @Parser.parse_object.361(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.360(i64, ptr) #0 +declare void @Parser.parse_value.362(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.361(i64, ptr) #0 +declare void @parse.363(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.362(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.364(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.363(i64, ptr) #0 +declare void @BuildOptions.add_framework.365(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.364(i64, ptr, ptr) #0 +declare void @BuildOptions.set_output_path.366(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.365(i64) #0 +declare void @BuildOptions.set_wasm_shell.367(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.366(i64, i64) #0 +declare void @BuildOptions.add_asset_dir.368(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.367(i64, i64) #0 +declare i64 @BuildOptions.asset_dir_count.369(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.368(i64, ptr) #0 +declare ptr @BuildOptions.asset_dir_src_at.370(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.369(i64, ptr) #0 +declare ptr @BuildOptions.asset_dir_dest_at.371(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.370(i64) #0 +declare void @BuildOptions.set_post_link_callback.372(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.371(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.373(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.372(i64, ptr) #0 +declare ptr @BuildOptions.binary_path.374(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.373(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.375(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.374(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.376(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.375(i64) #0 +declare void @BuildOptions.set_codesign_identity.377(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.376(i64) #0 +declare void @BuildOptions.set_provisioning_profile.378(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.377(i64) #0 +declare ptr @BuildOptions.bundle_path.379(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.378(i64) #0 +declare ptr @BuildOptions.bundle_id.380(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.379(i64) #0 +declare ptr @BuildOptions.codesign_identity.381(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.380(i64) #0 +declare ptr @BuildOptions.provisioning_profile.382(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.381(i64) #0 +declare ptr @BuildOptions.target_triple.383(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.382(i64) #0 +declare i1 @BuildOptions.is_macos.384(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.383(i64) #0 +declare i1 @BuildOptions.is_ios.385(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.384(i64) #0 +declare i1 @BuildOptions.is_ios_device.386(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.385(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.387(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.386(i64, i64) #0 +declare i1 @BuildOptions.is_android.388(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.387(i64) #0 +declare i64 @BuildOptions.framework_count.389(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.388(i64, i64) #0 +declare ptr @BuildOptions.framework_at.390(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.389(i64, ptr) #0 +declare i64 @BuildOptions.framework_path_count.391(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.390(i64, ptr) #0 +declare ptr @BuildOptions.framework_path_at.392(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.391(i64) #0 +declare void @BuildOptions.set_manifest_path.393(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.392(i64) #0 +declare void @BuildOptions.set_keystore_path.394(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.393(i64) #0 +declare ptr @BuildOptions.manifest_path.395(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.394(i64, i64) #0 +declare ptr @BuildOptions.keystore_path.396(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.395(i64, i64) #0 +declare i64 @BuildOptions.jni_main_count.397(i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.396() #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.398(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @spaces.397(ptr, i32) #0 +declare ptr @BuildOptions.jni_main_java_source_at.399(i64, i64) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.398() #0 +declare i64 @build_options.400() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.399() #0 +declare ptr @spaces.401(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.400(i32) #0 +declare i32 @sx_trace_len.402() #0 ; Function Attrs: nounwind -declare ptr @to_string.401(ptr) #0 +declare i32 @sx_trace_truncated.403() #0 ; Function Attrs: nounwind -declare void @print_current.402(ptr) #0 +declare i64 @sx_trace_frame_at.404(i32) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.403(ptr) #0 +declare ptr @to_string.405(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.404(ptr, ptr) #0 +declare void @print_current.406(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.405(ptr) #0 +declare void @print_interpreter_frames.407(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.406(ptr, i64, i64, ptr) #0 +declare ptr @popen.408(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.407(ptr) #0 +declare i32 @pclose.409(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.408(ptr) #0 +declare i64 @fread.410(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.409(ptr) #0 +declare i32 @feof.411(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.410(ptr) #0 +declare ptr @getenv.412(ptr) #0 ; Function Attrs: nounwind -declare void @run.411(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare i64 @strlen.413(ptr) #0 ; Function Attrs: nounwind -declare void @env.412(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.414(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.413(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @run.415(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.414(i32) #0 +declare void @env.416(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.415(ptr, i8, ptr) #0 +declare void @find_executable.417(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.416(ptr, i1, ptr, ptr) #0 +declare void @_exit.418(i32) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgv.417() #0 +declare void @exit.419(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgc.418() #0 +declare void @assert.420(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit_ok.419(ptr) #0 +declare ptr @_NSGetArgv.421() #0 ; Function Attrs: nounwind -declare void @exit_usage.420(ptr) #0 +declare ptr @_NSGetArgc.422() #0 ; Function Attrs: nounwind -declare i64 @os_argc.421(ptr) #0 +declare void @exit_ok.423(ptr) #0 ; Function Attrs: nounwind -declare ptr @os_args.422(ptr, ptr) #0 +declare void @exit_usage.424(ptr) #0 ; Function Attrs: nounwind -declare i1 @Parsed.is_set.423(ptr, ptr, ptr) #0 +declare i64 @os_argc.425(ptr) #0 ; Function Attrs: nounwind -declare ptr @Parsed.value_of.424(ptr, ptr, ptr) #0 +declare ptr @os_args.426(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @is_long_flag.425(ptr, ptr) #0 +declare i1 @Parsed.is_set.427(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare ptr @Parsed.value_of.428(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.427(ptr, i32, ...) #0 +declare i1 @is_long_flag.429(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.428(i32) #0 +declare void @parse.430(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 @read.429(i32, ptr, i64) #0 +declare i32 @open.431(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.430(i32, i64, i32) #0 +declare i32 @close.432(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.431(ptr) #0 +declare i64 @read.433(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.432(ptr) #0 +declare i64 @lseek.434(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.433(ptr, i32) #0 +declare i32 @unlink.435(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.434(ptr, i32) #0 +declare i32 @rmdir.436(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.435(ptr, i32) #0 +declare i32 @mkdir.437(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.436(ptr, ptr) #0 +declare i32 @access.438(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.437(ptr, ptr) #0 +declare i32 @chmod.439(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.438(ptr, ptr) #0 +declare i32 @rename.440(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.439(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.441(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.440(ptr, ptr, ptr) #0 +declare i1 @File.close.442(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.441(ptr, ptr, i64, i64) #0 +declare i64 @File.read.443(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.442(ptr, i64) #0 +declare i64 @File.write.444(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.443(ptr, ptr, i64) #0 +declare i64 @File.seek.445(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.444(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.446(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.445(ptr, ptr, ptr) #0 +declare i64 @open_file.447(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.446(ptr, ptr, ptr) #0 +declare void @read_file.448(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.447(ptr, ptr) #0 +declare i1 @write_file.449(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.448(ptr, ptr) #0 +declare i1 @append_file.450(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.449(ptr, ptr) #0 +declare i1 @exists.451(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.450(ptr, ptr) #0 +declare i1 @delete_file.452(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.451(ptr, ptr, i32) #0 +declare i1 @delete_dir.453(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.452(ptr, ptr, ptr) #0 +declare i1 @create_dir.454(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.453(ptr, ptr) #0 +declare i1 @set_mode.455(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.454(ptr, ptr, ptr) #0 +declare i1 @move.456(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.455(ptr, ptr) #0 +declare i1 @create_dir_all.457(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.456(ptr, ptr) #0 +declare i1 @copy_file.458(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @rotr.457(ptr, i64, i64) #0 +declare ptr @basename.459(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma0.458(ptr, i64) #0 +declare ptr @dirname.460(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma1.459(ptr, i64) #0 +declare i64 @rotr.461(ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @small_sigma0.460(ptr, i64) #0 +declare i64 @big_sigma0.462(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @small_sigma1.461(ptr, i64) #0 +declare i64 @big_sigma1.463(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.process_block.462(ptr, ptr) #0 +declare i64 @small_sigma0.464(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.update.463(ptr, ptr, ptr) #0 +declare i64 @small_sigma1.465(ptr, i64) #0 ; Function Attrs: nounwind -declare [64 x i8] @Sha256.final.464(ptr, ptr) #0 +declare void @Sha256.process_block.466(ptr, ptr) #0 ; Function Attrs: nounwind -declare i8 @nibble_hex.465(ptr, i64) #0 +declare void @Sha256.update.467(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @init.466(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 +declare [64 x i8] @Sha256.final.468(ptr, ptr) #0 ; Function Attrs: nounwind -declare [64 x i8] @sha256_hex.467(ptr, ptr) #0 +declare i8 @nibble_hex.469(ptr, i64) #0 ; Function Attrs: nounwind -declare void @sha256_file.468(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 +declare void @init.470(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 ; Function Attrs: nounwind -declare void @assert.469(ptr, i1) #0 +declare [64 x i8] @sha256_hex.471(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @sha256_file.472(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @assert.473(ptr, i1) #0 ; Function Attrs: nounwind declare ptr @cwd_greet(ptr) #0 @@ -4812,14 +4824,14 @@ entry: define internal void @print__ct_s4f0c3447f66dcf6d__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.685, i64 28 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.689, 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.686, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.690, 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) @@ -4835,7 +4847,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.687, i64 28 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.691, i64 28 }) ret { ptr, i64 } %call } @@ -4849,7 +4861,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.688, i64 20 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.692, i64 20 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca i32, align 4 @@ -4872,7 +4884,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.689, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.693, 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) @@ -4912,7 +4924,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.690, i64 20 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.694, i64 20 }) ret { ptr, i64 } %call } @@ -4932,7 +4944,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.691, i64 15 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.695, 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 @@ -4950,7 +4962,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.692, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.696, 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) @@ -4980,7 +4992,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.693, i64 15 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.697, i64 15 }) ret { ptr, i64 } %call } @@ -4991,7 +5003,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.694, i64 15 }, { ptr, i64 } { ptr @str.695, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 15 }, { ptr, i64 } { ptr @str.699, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5010,12 +5022,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.696, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.700, 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.697, 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 br label %if.merge.129 @@ -5027,7 +5039,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.701, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5084,7 +5096,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.702, i64 9 }, { ptr, i64 } { ptr @str.703, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 9 }, { ptr, i64 } { ptr @str.707, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5103,24 +5115,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.704, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.708, 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.705, 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.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 [3 x { ptr, i64 }], ptr @field_names.709, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.713, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.714, 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 @@ -5164,20 +5176,21 @@ fv.case21: ; preds = %if.merge.134 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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.711, i64 10 }, { ptr, i64 } { ptr @str.712, i64 1 }) + %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.715, i64 7 }, { ptr, i64 } { ptr @str.716, 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 +while.hdr.135: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 2 br i1 %icmp, label %while.body.136, label %while.exit.137 while.body.136: ; preds = %while.hdr.135 @@ -5187,24 +5200,102 @@ while.body.136: ; preds = %while.hdr.135 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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.717, 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 }) + %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.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.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.721, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.722, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.135 + +fv.default: ; preds = %if.merge.139 + br label %fv.merge + +fv.case: ; preds = %if.merge.139 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.139 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.723, i64 10 }, { ptr, i64 } { ptr @str.724, 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 = %if.merge.144, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + 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.725, 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.726, 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 [0 x { ptr, i64 }], ptr @field_names.727, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %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 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5215,7 +5306,7 @@ if.merge.139: ; preds = %if.then.138, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.135 + br label %while.hdr.140 } ; Function Attrs: nounwind @@ -5223,43 +5314,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 3 }, { ptr, i64 } { ptr @str.730, 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 + br label %while.hdr.145 -while.hdr.140: ; preds = %fv.merge, %entry +while.hdr.145: ; 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 + br i1 %icmp, label %while.body.146, label %while.exit.147 -while.body.141: ; preds = %while.hdr.140 +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.143, label %if.merge.144 + br i1 %icmpN, label %if.then.148, label %if.merge.149 -while.exit.142: ; preds = %while.hdr.140 +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.719, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.731, i64 1 }) ret { ptr, i64 } %callN -if.then.143: ; preds = %while.body.141 +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.720, 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 - br label %if.merge.144 + br label %if.merge.149 -if.merge.144: ; preds = %if.then.143, %while.body.141 +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 [1 x { ptr, i64 }], ptr @field_names.722, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.734, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 }) + %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64 }, ptr %alloca, align 8 @@ -5276,12 +5367,12 @@ 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.140 + br label %while.hdr.145 -fv.default: ; preds = %if.merge.144 +fv.default: ; preds = %if.merge.149 br label %fv.merge -fv.case: ; preds = %if.merge.144 +fv.case: ; preds = %if.merge.149 %fv.field = extractvalue { i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge @@ -5292,43 +5383,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 10 }, { ptr, i64 } { ptr @str.737, 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 + br label %while.hdr.150 -while.hdr.145: ; preds = %fv.merge, %entry +while.hdr.150: ; 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 + br i1 %icmp, label %while.body.151, label %while.exit.152 -while.body.146: ; preds = %while.hdr.145 +while.body.151: ; preds = %while.hdr.150 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.148, label %if.merge.149 + br i1 %icmpN, label %if.then.153, label %if.merge.154 -while.exit.147: ; preds = %while.hdr.145 +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.726, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.738, i64 1 }) ret { ptr, i64 } %callN -if.then.148: ; preds = %while.body.146 +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.727, 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.149 + br label %if.merge.154 -if.merge.149: ; preds = %if.then.148, %while.body.146 +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 [2 x { ptr, i64 }], ptr @field_names.730, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.742, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 }) + %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -5346,18 +5437,18 @@ 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.145 + br label %while.hdr.150 -fv.default: ; preds = %if.merge.149 +fv.default: ; preds = %if.merge.154 br label %fv.merge -fv.case: ; preds = %if.merge.149 +fv.case: ; preds = %if.merge.154 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.149 +fv.case17: ; preds = %if.merge.154 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -5369,91 +5460,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.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 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.150 - -while.hdr.150: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.151, label %while.exit.152 - -while.body.151: ; preds = %while.hdr.150 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.153, label %if.merge.154 - -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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.150 - -fv.default: ; preds = %if.merge.154 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.154 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 8 }, { ptr, i64 } { ptr @str.742, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.744, i64 5 }, { ptr, i64 } { ptr @str.745, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5472,27 +5479,27 @@ 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.743, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.746, 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.744, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.747, 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.748, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.751, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.752, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -5514,17 +5521,101 @@ fv.default: ; preds = %if.merge.159 br label %fv.merge fv.case: ; preds = %if.merge.159 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.159 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.159 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64, i64 }, align 8 + store { ptr, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 8 }, { ptr, i64 } { ptr @str.754, 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.160 + +while.hdr.160: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 3 + br i1 %icmp, label %while.body.161, label %while.exit.162 + +while.body.161: ; preds = %while.hdr.160 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.163, label %if.merge.164 + +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.755, 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.756, 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 [3 x { ptr, i64 }], ptr @field_names.760, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, 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 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + i64 2, label %fv.case20 + ] + +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.160 + +fv.default: ; preds = %if.merge.164 + br label %fv.merge + +fv.case: ; preds = %if.merge.164 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.164 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.164 %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge @@ -5536,43 +5627,43 @@ 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.750, i64 17 }, { ptr, i64 } { ptr @str.751, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 17 }, { ptr, i64 } { ptr @str.763, 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.160 + br label %while.hdr.165 -while.hdr.160: ; preds = %fv.merge, %entry +while.hdr.165: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 4 - br i1 %icmp, label %while.body.161, label %while.exit.162 + br i1 %icmp, label %while.body.166, label %while.exit.167 -while.body.161: ; preds = %while.hdr.160 +while.body.166: ; preds = %while.hdr.165 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.163, label %if.merge.164 + br i1 %icmpN, label %if.then.168, label %if.merge.169 -while.exit.162: ; preds = %while.hdr.160 +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.752, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.764, i64 1 }) ret { ptr, i64 } %callN -if.then.163: ; preds = %while.body.161 +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.753, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.765, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.164 + br label %if.merge.169 -if.merge.164: ; preds = %if.then.163, %while.body.161 +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 [4 x { ptr, i64 }], ptr @field_names.758, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.770, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.759, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -5592,110 +5683,31 @@ 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.160 - -fv.default: ; preds = %if.merge.164 - br label %fv.merge - -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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.164 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.164 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 - br label %fv.merge - -fv.case23: ; preds = %if.merge.164 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { -entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 - %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.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 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.165 - -while.hdr.165: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.166, label %while.exit.167 - -while.body.166: ; preds = %while.hdr.165 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.168, label %if.merge.169 - -while.exit.167: ; preds = %while.hdr.165 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %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.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.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.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 - %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.165 fv.default: ; preds = %if.merge.169 br label %fv.merge fv.case: ; preds = %if.merge.169 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.169 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.169 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.169 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -5704,7 +5716,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.768, i64 4 }, { ptr, i64 } { ptr @str.769, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.772, i64 4 }, { ptr, i64 } { ptr @str.773, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5723,24 +5735,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.770, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.774, 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.771, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.775, 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.773, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.777, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.774, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -5777,7 +5789,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.775, i64 10 }, { ptr, i64 } { ptr @str.776, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.779, i64 10 }, { ptr, i64 } { ptr @str.780, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5796,24 +5808,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.777, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.781, 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.778, 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 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.784, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.788, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.789, 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 @@ -5879,7 +5891,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.786, i64 13 }, { ptr, i64 } { ptr @str.787, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 13 }, { ptr, i64 } { ptr @str.791, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5898,24 +5910,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.788, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.792, 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.789, 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 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.792, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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.793, 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, i64 } }, ptr %alloca, align 8 @@ -5957,7 +5969,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.794, i64 8 }, { ptr, i64 } { ptr @str.795, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 8 }, { 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 @@ -5976,24 +5988,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.796, 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.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.797, 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.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.803, 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.804, 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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -6054,7 +6066,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.805, i64 5 }, { ptr, i64 } { ptr @str.806, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.809, i64 5 }, { 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 @@ -6073,24 +6085,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.807, 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.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.808, 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.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.812, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.816, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.817, 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 @@ -6136,7 +6148,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.814, i64 6 }, { ptr, i64 } { ptr @str.815, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.818, i64 6 }, { ptr, i64 } { ptr @str.819, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6155,24 +6167,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.816, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.820, 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.817, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.821, 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.821, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.825, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.826, 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 @@ -6220,7 +6232,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.823, i64 6 }, { ptr, i64 } { ptr @str.824, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.827, i64 6 }, { ptr, i64 } { ptr @str.828, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6239,24 +6251,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.825, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.829, 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.826, 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 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.829, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.833, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.834, 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 @@ -6300,7 +6312,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.831, i64 4 }, { ptr, i64 } { ptr @str.832, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.835, i64 4 }, { ptr, i64 } { ptr @str.836, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6319,24 +6331,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.833, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.837, 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.834, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.838, 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.838, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.842, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.843, 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 @@ -6386,7 +6398,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.840, i64 6 }, { ptr, i64 } { ptr @str.841, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.844, i64 6 }, { ptr, i64 } { ptr @str.845, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6405,24 +6417,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.842, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.846, 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.843, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.847, 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.847, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.851, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.852, 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 @@ -6471,7 +6483,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.849, i64 12 }, { ptr, i64 } { ptr @str.850, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.853, i64 12 }, { ptr, i64 } { ptr @str.854, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6490,24 +6502,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.851, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.855, 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.852, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.856, 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.853, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.857, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.858, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6527,7 +6539,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.855, i64 8 }, { ptr, i64 } { ptr @str.856, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.859, i64 8 }, { ptr, i64 } { ptr @str.860, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6546,24 +6558,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.857, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.861, 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.858, 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 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.862, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.866, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.867, 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 @@ -6615,7 +6627,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.864, i64 7 }, { ptr, i64 } { ptr @str.865, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.868, i64 7 }, { ptr, i64 } { ptr @str.869, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6634,24 +6646,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.866, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.870, 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.867, 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 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.871, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.875, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.876, 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 @@ -6703,7 +6715,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.873, i64 9 }, { ptr, i64 } { ptr @str.874, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.877, i64 9 }, { ptr, i64 } { ptr @str.878, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6722,24 +6734,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.875, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.879, 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.876, 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 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.879, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.883, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.880, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -6782,7 +6794,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.881, i64 4 }, { ptr, i64 } { ptr @str.882, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.885, i64 4 }, { ptr, i64 } { ptr @str.886, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6801,24 +6813,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.883, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.887, 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.884, 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 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.887, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.891, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.892, 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 @@ -6864,7 +6876,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.889, i64 6 }, { ptr, i64 } { ptr @str.890, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.893, i64 6 }, { ptr, i64 } { ptr @str.894, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6883,24 +6895,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.891, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.895, 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.892, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.896, 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.900, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.904, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.901, 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 %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 @@ -6957,7 +6969,7 @@ fv.case28: ; preds = %if.merge.244 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.244 @@ -6982,7 +6994,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.902, i64 6 }, { ptr, i64 } { ptr @str.903, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.906, i64 6 }, { ptr, i64 } { ptr @str.907, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7001,24 +7013,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.904, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.908, 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.905, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.909, 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.910, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.914, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.911, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -7074,7 +7086,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.912, i64 4 }, { ptr, i64 } { ptr @str.913, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.916, i64 4 }, { ptr, i64 } { ptr @str.917, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7093,24 +7105,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.914, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.918, 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.915, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.919, 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.917, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.921, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.918, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [16 x float] }, ptr %alloca, align 4 @@ -7145,7 +7157,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.919, i64 4 }, { ptr, i64 } { ptr @str.920, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.923, i64 4 }, { ptr, i64 } { ptr @str.924, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7164,24 +7176,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.921, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.925, 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.922, 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 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.925, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.929, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.926, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { float, float }, ptr %alloca, align 4 @@ -7224,7 +7236,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.927, i64 5 }, { ptr, i64 } { ptr @str.928, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.931, i64 5 }, { ptr, i64 } { ptr @str.932, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7243,24 +7255,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.929, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.933, 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.930, 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 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.933, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.937, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.934, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, i32 }, ptr %alloca, align 4 @@ -7301,7 +7313,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.935, i64 10 }, { ptr, i64 } { ptr @str.936, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.939, i64 10 }, { ptr, i64 } { ptr @str.940, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7320,24 +7332,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.937, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.941, 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.938, 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 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.941, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.945, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.942, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.946, 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 @@ -7384,9 +7396,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.948, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.952, 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.943, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.947, 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 @@ -7405,8 +7417,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.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 } { ptr @str.954, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.953, 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 @@ -7425,9 +7437,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.955, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.959, 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.951, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.955, 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 @@ -7446,8 +7458,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.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.961, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.960, 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 @@ -7477,9 +7489,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.965, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 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.962, 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 @@ -7496,8 +7508,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.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 } { 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.283 @@ -7575,9 +7587,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.976, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.980, 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.968, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.972, 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 @@ -7596,8 +7608,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.285 @@ -7616,9 +7628,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.985, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.989, 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.979, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.983, 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 @@ -7637,8 +7649,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.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 } { ptr @str.991, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.990, 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 @@ -7663,9 +7675,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.992, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.996, 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.988, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.992, 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 @@ -7679,8 +7691,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.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 } { ptr @str.998, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.997, 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 @@ -7732,7 +7744,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.995, 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.300 @@ -7749,12 +7761,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.996, 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.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.997, 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.304 @@ -7783,7 +7795,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.998, 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.305 @@ -7800,12 +7812,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.999, 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.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.1000, 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.309 @@ -7835,7 +7847,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.1001, 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.310 @@ -7852,12 +7864,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.1002, 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.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.1003, 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.314 @@ -7885,7 +7897,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.1004, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1008, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.315 @@ -7902,12 +7914,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.1005, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1009, 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.1006, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1010, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.319 @@ -7936,7 +7948,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.1007, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1011, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.320 @@ -7953,12 +7965,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.1008, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1012, 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.1009, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1013, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.324 @@ -7986,7 +7998,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.1010, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1014, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.325 @@ -8003,12 +8015,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.1011, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1015, 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.1012, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1016, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.329 @@ -8039,7 +8051,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.1013, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1017, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.330 @@ -8056,12 +8068,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.1014, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1018, 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.1015, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1019, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.334 @@ -8092,7 +8104,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.1016, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1020, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.335 @@ -8109,12 +8121,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.1017, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1021, 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.1018, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1022, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.339 @@ -8144,7 +8156,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.1019, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1023, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.347 @@ -8163,12 +8175,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.1020, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1024, 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.1021, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1025, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.351 @@ -8197,7 +8209,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.1022, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1026, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.352 @@ -8216,12 +8228,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.1023, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1027, 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.1024, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1028, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.356 @@ -8250,7 +8262,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.1025, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1029, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.357 @@ -8269,12 +8281,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.1026, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1030, 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.1027, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1031, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.361 @@ -8304,7 +8316,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.1028, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1032, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.362 @@ -8323,12 +8335,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.1029, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1033, 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.1030, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1034, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.366 @@ -8358,7 +8370,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.1031, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1035, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.367 @@ -8377,12 +8389,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.1032, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1036, 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.1033, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1037, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.371 @@ -8424,12 +8436,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.1036, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1035, i64 5 }, { 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 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.1034, i64 4 }, %if.then.407 ], [ %callN, %if.else.408 ] + %bp = phi { ptr, i64 } [ { ptr @str.1038, i64 4 }, %if.then.407 ], [ %callN, %if.else.408 ] ret { ptr, i64 } %bp } @@ -8452,12 +8464,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.1039, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1038, i64 11 }, { 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 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.1037, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.1041, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -8480,12 +8492,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.1042, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1041, 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.428 if.merge.428: ; preds = %if.else.427, %if.then.426 - %bp = phi { ptr, i64 } [ { ptr @str.1040, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.1044, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -8508,12 +8520,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.1045, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1044, i64 11 }, { 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 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.1043, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.1047, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -8536,12 +8548,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.1048, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1047, 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.434 if.merge.434: ; preds = %if.else.433, %if.then.432 - %bp = phi { ptr, i64 } [ { ptr @str.1046, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.1050, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -8563,12 +8575,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.1051, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1050, i64 5 }, { 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 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.1049, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.1053, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -8591,12 +8603,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.1054, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1053, i64 9 }, { 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 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.1052, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.1056, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -8619,12 +8631,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.1057, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1056, i64 18 }, { 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 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.1055, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.1059, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -8647,12 +8659,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.1060, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1059, i64 5 }, { 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 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.1058, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.1062, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -8675,12 +8687,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.1063, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1062, i64 3 }, { 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 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.1061, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.1065, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -8703,12 +8715,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.1066, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1065, i64 4 }, { 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 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.1064, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.1068, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -8731,12 +8743,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.1069, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1068, i64 9 }, { 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 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.1067, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.1071, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -8759,12 +8771,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.1072, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1071, i64 4 }, { 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 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.1070, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.1074, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -8786,12 +8798,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.1075, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1074, i64 8 }, { 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 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.1073, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.1077, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -8814,12 +8826,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.1078, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1077, 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.464 if.merge.464: ; preds = %if.else.463, %if.then.462 - %bp = phi { ptr, i64 } [ { ptr @str.1076, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.1080, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -8841,12 +8853,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.1081, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1080, i64 9 }, { 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 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.1079, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.1083, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -8869,12 +8881,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.1084, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1083, i64 7 }, { 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 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.1082, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.1086, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -8897,12 +8909,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.1087, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1086, i64 5 }, { 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 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.1085, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.1089, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -8925,12 +8937,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.1090, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1089, i64 7 }, { 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 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.1088, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.1092, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -8953,12 +8965,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.1093, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1092, i64 4 }, { 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 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.1091, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.1095, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -8981,12 +8993,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.1096, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1095, 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.482 if.merge.482: ; preds = %if.else.481, %if.then.480 - %bp = phi { ptr, i64 } [ { ptr @str.1094, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.1098, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -9009,12 +9021,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.1099, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1098, i64 5 }, { ptr, i64 } %callN) + %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 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.1097, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.1101, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -9037,12 +9049,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.1102, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1101, i64 7 }, { ptr, i64 } %callN) + %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) br label %if.merge.488 if.merge.488: ; preds = %if.else.487, %if.then.486 - %bp = phi { ptr, i64 } [ { ptr @str.1100, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] + %bp = phi { ptr, i64 } [ { ptr @str.1104, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] ret { ptr, i64 } %bp } @@ -9065,12 +9077,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.1105, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1104, i64 12 }, { ptr, i64 } %callN) + %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 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.1103, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] + %bp = phi { ptr, i64 } [ { ptr @str.1107, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] ret { ptr, i64 } %bp } @@ -9093,12 +9105,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.1108, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1107, i64 6 }, { ptr, i64 } %callN) + %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) br label %if.merge.494 if.merge.494: ; preds = %if.else.493, %if.then.492 - %bp = phi { ptr, i64 } [ { ptr @str.1106, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] + %bp = phi { ptr, i64 } [ { ptr @str.1110, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] ret { ptr, i64 } %bp } @@ -9121,12 +9133,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.1111, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1110, i64 7 }, { ptr, i64 } %callN) + %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 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.1109, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] + %bp = phi { ptr, i64 } [ { ptr @str.1113, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] ret { ptr, i64 } %bp } @@ -9149,12 +9161,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.1114, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1113, i64 4 }, { ptr, i64 } %callN) + %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 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.1112, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] + %bp = phi { ptr, i64 } [ { ptr @str.1116, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] ret { ptr, i64 } %bp } @@ -9177,12 +9189,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.1117, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1116, i64 6 }, { ptr, i64 } %callN) + %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 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.1115, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] + %bp = phi { ptr, i64 } [ { ptr @str.1119, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] ret { ptr, i64 } %bp } @@ -9205,12 +9217,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.1120, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1119, i64 5 }, { ptr, i64 } %callN) + %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 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.1118, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] + %bp = phi { ptr, i64 } [ { ptr @str.1122, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] ret { ptr, i64 } %bp } @@ -9233,12 +9245,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.1123, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1122, i64 6 }, { ptr, i64 } %callN) + %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 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.1121, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] + %bp = phi { ptr, i64 } [ { ptr @str.1125, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] ret { ptr, i64 } %bp } @@ -9261,12 +9273,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.1126, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1125, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1130, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1129, 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.1124, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] + %bp = phi { ptr, i64 } [ { ptr @str.1128, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] ret { ptr, i64 } %bp } @@ -9289,12 +9301,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.1129, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1128, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1133, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1132, 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.1127, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] + %bp = phi { ptr, i64 } [ { ptr @str.1131, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] ret { ptr, i64 } %bp } @@ -9317,12 +9329,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.1132, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1131, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1136, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1135, 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.1130, i64 4 }, %if.then.516 ], [ %callN, %if.else.517 ] + %bp = phi { ptr, i64 } [ { ptr @str.1134, i64 4 }, %if.then.516 ], [ %callN, %if.else.517 ] ret { ptr, i64 } %bp } @@ -9338,7 +9350,7 @@ entry: br i1 %lnot, label %if.then.525, label %if.merge.526 if.then.525: ; preds = %entry - ret { ptr, i64 } { ptr @str.1133, i64 4 } + ret { ptr, i64 } { ptr @str.1137, i64 4 } if.merge.526: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -9362,7 +9374,7 @@ entry: br i1 %lnot, label %if.then.527, label %if.merge.528 if.then.527: ; preds = %entry - ret { ptr, i64 } { ptr @str.1134, i64 4 } + ret { ptr, i64 } { ptr @str.1138, i64 4 } if.merge.528: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -9386,7 +9398,7 @@ entry: br i1 %lnot, label %if.then.529, label %if.merge.530 if.then.529: ; preds = %entry - ret { ptr, i64 } { ptr @str.1135, i64 4 } + ret { ptr, i64 } { ptr @str.1139, i64 4 } if.merge.530: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -9410,7 +9422,7 @@ entry: br i1 %lnot, label %if.then.531, label %if.merge.532 if.then.531: ; preds = %entry - ret { ptr, i64 } { ptr @str.1136, i64 4 } + ret { ptr, i64 } { ptr @str.1140, 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 b65441f..acd8421 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.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 +@str.474 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.475 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.476 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.477 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.478 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.479 = 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.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 }] +@tag.str.480 = private constant [9 x i8] c"Overflow\00" +@tag.str.481 = private constant [3 x i8] c"Io\00" +@tag.str.482 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.483 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.484 = private constant [10 x i8] c"BadEscape\00" +@tag.str.485 = private constant [10 x i8] c"BadNumber\00" +@tag.str.486 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.487 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.488 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.489 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.490 = private constant [13 x i8] c"MissingValue\00" +@tag.str.491 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.492 = 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.480, i64 8 }, { ptr, i64 } { ptr @tag.str.481, i64 2 }, { ptr, i64 } { ptr @tag.str.482, i64 15 }, { ptr, i64 } { ptr @tag.str.483, i64 13 }, { ptr, i64 } { ptr @tag.str.484, i64 9 }, { ptr, i64 } { ptr @tag.str.485, i64 9 }, { ptr, i64 } { ptr @tag.str.486, i64 15 }, { ptr, i64 } { ptr @tag.str.487, i64 14 }, { ptr, i64 } { ptr @tag.str.488, i64 14 }, { ptr, i64 } { ptr @tag.str.489, i64 11 }, { ptr, i64 } { ptr @tag.str.490, i64 12 }, { ptr, i64 } { ptr @tag.str.491, i64 15 }, { ptr, i64 } { ptr @tag.str.492, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@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 [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 +@tn.str.493 = private constant [5 x i8] c"bool\00" +@tn.str.494 = private constant [3 x i8] c"s8\00" +@tn.str.495 = private constant [4 x i8] c"s16\00" +@tn.str.496 = private constant [4 x i8] c"s32\00" +@tn.str.497 = private constant [4 x i8] c"s64\00" +@tn.str.498 = private constant [3 x i8] c"u8\00" +@tn.str.499 = private constant [4 x i8] c"u16\00" +@tn.str.500 = private constant [4 x i8] c"u32\00" +@tn.str.501 = private constant [4 x i8] c"u64\00" +@tn.str.502 = private constant [4 x i8] c"f32\00" +@tn.str.503 = private constant [4 x i8] c"f64\00" +@tn.str.504 = private constant [7 x i8] c"string\00" +@tn.str.505 = private constant [4 x i8] c"Any\00" +@tn.str.506 = private constant [9 x i8] c"noreturn\00" +@tn.str.507 = private constant [6 x i8] c"isize\00" +@tn.str.508 = private constant [6 x i8] c"usize\00" +@tn.str.509 = private constant [5 x i8] c"void\00" +@tn.str.510 = private constant [6 x i8] c"*void\00" +@tn.str.511 = private constant [16 x i8] c"Source_Location\00" +@tn.str.512 = private constant [10 x i8] c"Allocator\00" +@tn.str.513 = private constant [8 x i8] c"Context\00" +@tn.str.514 = private constant [7 x i8] c"[4]s64\00" +@tn.str.515 = private constant [9 x i8] c"[]string\00" +@tn.str.516 = private constant [11 x i8] c"CAllocator\00" +@tn.str.517 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.518 = private constant [4 x i8] c"GPA\00" +@tn.str.519 = private constant [5 x i8] c"*GPA\00" +@tn.str.520 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.521 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.522 = private constant [6 x i8] c"Arena\00" +@tn.str.523 = private constant [7 x i8] c"*Arena\00" +@tn.str.524 = private constant [6 x i8] c"[*]u8\00" +@tn.str.525 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.526 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.527 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.528 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.529 = private constant [9 x i8] c"OpenMode\00" +@tn.str.530 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.531 = private constant [5 x i8] c"File\00" +@tn.str.532 = private constant [6 x i8] c"*File\00" +@tn.str.533 = private constant [6 x i8] c"?File\00" +@tn.str.534 = private constant [8 x i8] c"?string\00" +@tn.str.535 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.536 = private constant [4 x i8] c"*u8\00" +@tn.str.537 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.538 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.539 = private constant [5 x i8] c"*s32\00" +@tn.str.540 = private constant [9 x i8] c"SockAddr\00" +@tn.str.541 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.542 = private constant [5 x i8] c"*u32\00" +@tn.str.543 = private constant [10 x i8] c"JsonError\00" +@tn.str.544 = private constant [6 x i8] c"Array\00" +@tn.str.545 = private constant [7 x i8] c"Object\00" +@tn.str.546 = private constant [6 x i8] c"Value\00" +@tn.str.547 = private constant [7 x i8] c"Member\00" +@tn.str.548 = private constant [9 x i8] c"[*]Value\00" +@tn.str.549 = private constant [7 x i8] c"*Array\00" +@tn.str.550 = private constant [10 x i8] c"[*]Member\00" +@tn.str.551 = private constant [8 x i8] c"*Object\00" +@tn.str.552 = private constant [5 x i8] c"[]u8\00" +@tn.str.553 = private constant [5 x i8] c"Sink\00" +@tn.str.554 = private constant [6 x i8] c"*Sink\00" +@tn.str.555 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.556 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.557 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.558 = private constant [7 x i8] c"Parser\00" +@tn.str.559 = private constant [8 x i8] c"*Parser\00" +@tn.str.560 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.561 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.562 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.563 = private constant [13 x i8] c"Architecture\00" +@tn.str.564 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.565 = private constant [11 x i8] c"() -> bool\00" +@tn.str.566 = private constant [5 x i8] c"*s64\00" +@tn.str.567 = private constant [9 x i8] c"CliError\00" +@tn.str.568 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.569 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.570 = private constant [8 x i8] c"Command\00" +@tn.str.571 = private constant [10 x i8] c"FlagValue\00" +@tn.str.572 = private constant [5 x i8] c"Diag\00" +@tn.str.573 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.574 = private constant [7 x i8] c"Parsed\00" +@tn.str.575 = private constant [8 x i8] c"*Parsed\00" +@tn.str.576 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.577 = private constant [10 x i8] c"[]Command\00" +@tn.str.578 = private constant [6 x i8] c"*Diag\00" +@tn.str.579 = private constant [7 x i8] c"[8]s64\00" +@tn.str.580 = private constant [7 x i8] c"[64]u8\00" +@tn.str.581 = private constant [7 x i8] c"Sha256\00" +@tn.str.582 = private constant [8 x i8] c"*Sha256\00" +@tn.str.583 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.584 = private constant [8 x i8] c"[64]s64\00" +@tn.str.585 = private constant [8 x i8] c"[16]f32\00" +@tn.str.586 = private constant [5 x i8] c"Mat4\00" +@tn.str.587 = private constant [5 x i8] c"Vec2\00" +@tn.str.588 = private constant [6 x i8] c"Point\00" +@tn.str.589 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.590 = private constant [7 x i8] c"**void\00" +@tn.str.591 = private constant [8 x i8] c"*string\00" +@tn.str.592 = private constant [6 x i8] c"[]Any\00" +@tn.str.593 = private constant [5 x i8] c"*Any\00" +@tn.str.594 = private constant [7 x i8] c"*[]Any\00" +@tn.str.595 = private constant [6 x i8] c"*bool\00" +@tn.str.596 = private constant [7 x i8] c"*Point\00" +@tn.str.597 = private constant [7 x i8] c"[1]Any\00" +@tn.str.598 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.599 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.600 = private constant [5 x i8] c"*f64\00" +@tn.str.601 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.602 = private constant [11 x i8] c"*Allocator\00" +@tn.str.603 = private constant [9 x i8] c"*Context\00" +@tn.str.604 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.605 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.606 = private constant [8 x i8] c"*Member\00" +@tn.str.607 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.608 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.609 = private constant [9 x i8] c"*Command\00" +@tn.str.610 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.611 = private constant [6 x i8] c"*Mat4\00" +@tn.str.612 = private constant [6 x i8] c"*Vec2\00" +@tn.str.613 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.614 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.615 = private constant [7 x i8] c"*Value\00" +@tn.str.616 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.617 = private constant [14 x i8] c"*Architecture\00" +@tn.str.618 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.619 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.620 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.621 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.622 = private constant [9 x i8] c"*[16]f32\00" +@tn.str.623 = private constant [10 x i8] c"*[]string\00" +@tn.str.624 = private constant [6 x i8] c"*[]u8\00" +@tn.str.625 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.626 = private constant [11 x i8] c"*[]Command\00" +@tn.str.627 = private constant [6 x i8] c"**GPA\00" +@tn.str.628 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.629 = private constant [8 x i8] c"**Arena\00" +@tn.str.630 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.631 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.632 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.633 = private constant [7 x i8] c"**File\00" +@tn.str.634 = private constant [5 x i8] c"**u8\00" +@tn.str.635 = private constant [6 x i8] c"**s32\00" +@tn.str.636 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.637 = private constant [6 x i8] c"**u32\00" +@tn.str.638 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.639 = private constant [8 x i8] c"**Array\00" +@tn.str.640 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.641 = private constant [9 x i8] c"**Object\00" +@tn.str.642 = private constant [7 x i8] c"**Sink\00" +@tn.str.643 = private constant [9 x i8] c"**Parser\00" +@tn.str.644 = private constant [6 x i8] c"**s64\00" +@tn.str.645 = private constant [9 x i8] c"**Parsed\00" +@tn.str.646 = private constant [7 x i8] c"**Diag\00" +@tn.str.647 = private constant [9 x i8] c"**Sha256\00" +@tn.str.648 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.649 = private constant [8 x i8] c"***void\00" +@tn.str.650 = private constant [9 x i8] c"**string\00" +@tn.str.651 = private constant [6 x i8] c"**Any\00" +@tn.str.652 = private constant [8 x i8] c"**[]Any\00" +@tn.str.653 = private constant [7 x i8] c"**bool\00" +@tn.str.654 = private constant [8 x i8] c"**Point\00" +@tn.str.655 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.656 = private constant [7 x i8] c"*?File\00" +@tn.str.657 = private constant [9 x i8] c"*?string\00" +@tn.str.658 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.659 = 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.493, i64 4 }, { 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 2 }, { ptr, i64 } { ptr @tn.str.499, i64 3 }, { ptr, i64 } { ptr @tn.str.500, i64 3 }, { ptr, i64 } { ptr @tn.str.501, i64 3 }, { ptr, i64 } { ptr @tn.str.502, i64 3 }, { ptr, i64 } { ptr @tn.str.503, i64 3 }, { ptr, i64 } { ptr @tn.str.504, i64 6 }, { ptr, i64 } { ptr @tn.str.505, i64 3 }, { ptr, i64 } { ptr @tn.str.506, i64 8 }, { ptr, i64 } { ptr @tn.str.507, i64 5 }, { ptr, i64 } { ptr @tn.str.508, i64 5 }, { ptr, i64 } { ptr @tn.str.509, i64 4 }, { ptr, i64 } { ptr @tn.str.510, i64 5 }, { ptr, i64 } { ptr @tn.str.511, i64 15 }, { ptr, i64 } { ptr @tn.str.512, i64 9 }, { ptr, i64 } { ptr @tn.str.513, i64 7 }, { ptr, i64 } { ptr @tn.str.514, i64 6 }, { ptr, i64 } { ptr @tn.str.515, i64 8 }, { ptr, i64 } { ptr @tn.str.516, i64 10 }, { ptr, i64 } { ptr @tn.str.517, i64 11 }, { ptr, i64 } { ptr @tn.str.518, i64 3 }, { ptr, i64 } { ptr @tn.str.519, i64 4 }, { ptr, i64 } { ptr @tn.str.520, i64 10 }, { ptr, i64 } { ptr @tn.str.521, i64 11 }, { ptr, i64 } { ptr @tn.str.522, i64 5 }, { ptr, i64 } { ptr @tn.str.523, i64 6 }, { ptr, i64 } { ptr @tn.str.524, i64 5 }, { ptr, i64 } { ptr @tn.str.525, i64 8 }, { ptr, i64 } { ptr @tn.str.526, i64 9 }, { ptr, i64 } { ptr @tn.str.527, i64 17 }, { ptr, i64 } { ptr @tn.str.528, i64 18 }, { ptr, i64 } { ptr @tn.str.529, i64 8 }, { ptr, i64 } { ptr @tn.str.530, i64 8 }, { ptr, i64 } { ptr @tn.str.531, i64 4 }, { ptr, i64 } { ptr @tn.str.532, i64 5 }, { ptr, i64 } { ptr @tn.str.533, i64 5 }, { ptr, i64 } { ptr @tn.str.534, i64 7 }, { ptr, i64 } { ptr @tn.str.535, i64 10 }, { ptr, i64 } { ptr @tn.str.536, i64 3 }, { ptr, i64 } { ptr @tn.str.537, i64 13 }, { ptr, i64 } { ptr @tn.str.538, i64 14 }, { ptr, i64 } { ptr @tn.str.539, i64 4 }, { ptr, i64 } { ptr @tn.str.540, i64 8 }, { ptr, i64 } { ptr @tn.str.541, i64 9 }, { ptr, i64 } { ptr @tn.str.542, i64 4 }, { ptr, i64 } { ptr @tn.str.543, i64 9 }, { ptr, i64 } { ptr @tn.str.544, i64 5 }, { ptr, i64 } { ptr @tn.str.545, i64 6 }, { ptr, i64 } { ptr @tn.str.546, i64 5 }, { ptr, i64 } { ptr @tn.str.547, i64 6 }, { ptr, i64 } { ptr @tn.str.548, i64 8 }, { ptr, i64 } { ptr @tn.str.549, i64 6 }, { ptr, i64 } { ptr @tn.str.550, i64 9 }, { ptr, i64 } { ptr @tn.str.551, i64 7 }, { ptr, i64 } { ptr @tn.str.552, i64 4 }, { ptr, i64 } { ptr @tn.str.553, i64 4 }, { ptr, i64 } { ptr @tn.str.554, i64 5 }, { ptr, i64 } { ptr @tn.str.555, i64 16 }, { ptr, i64 } { ptr @tn.str.556, i64 14 }, { ptr, i64 } { ptr @tn.str.557, i64 21 }, { ptr, i64 } { ptr @tn.str.558, i64 6 }, { ptr, i64 } { ptr @tn.str.559, i64 7 }, { ptr, i64 } { ptr @tn.str.560, i64 24 }, { ptr, i64 } { ptr @tn.str.561, i64 23 }, { ptr, i64 } { ptr @tn.str.562, i64 15 }, { ptr, i64 } { ptr @tn.str.563, i64 12 }, { ptr, i64 } { ptr @tn.str.564, i64 12 }, { ptr, i64 } { ptr @tn.str.565, i64 10 }, { ptr, i64 } { ptr @tn.str.566, i64 4 }, { ptr, i64 } { ptr @tn.str.567, i64 8 }, { ptr, i64 } { ptr @tn.str.568, i64 8 }, { ptr, i64 } { ptr @tn.str.569, i64 10 }, { ptr, i64 } { ptr @tn.str.570, i64 7 }, { ptr, i64 } { ptr @tn.str.571, i64 9 }, { ptr, i64 } { ptr @tn.str.572, i64 4 }, { ptr, i64 } { ptr @tn.str.573, i64 13 }, { ptr, i64 } { ptr @tn.str.574, i64 6 }, { ptr, i64 } { ptr @tn.str.575, i64 7 }, { ptr, i64 } { ptr @tn.str.576, i64 18 }, { ptr, i64 } { ptr @tn.str.577, i64 9 }, { ptr, i64 } { ptr @tn.str.578, i64 5 }, { ptr, i64 } { ptr @tn.str.579, i64 6 }, { ptr, i64 } { ptr @tn.str.580, i64 6 }, { ptr, i64 } { ptr @tn.str.581, i64 6 }, { ptr, i64 } { ptr @tn.str.582, i64 7 }, { ptr, i64 } { ptr @tn.str.583, i64 7 }, { ptr, i64 } { ptr @tn.str.584, i64 7 }, { ptr, i64 } { ptr @tn.str.585, i64 7 }, { ptr, i64 } { ptr @tn.str.586, i64 4 }, { ptr, i64 } { ptr @tn.str.587, i64 4 }, { ptr, i64 } { ptr @tn.str.588, i64 5 }, { ptr, i64 } { ptr @tn.str.589, i64 12 }, { ptr, i64 } { ptr @tn.str.590, i64 6 }, { ptr, i64 } { ptr @tn.str.591, i64 7 }, { ptr, i64 } { ptr @tn.str.592, i64 5 }, { ptr, i64 } { ptr @tn.str.593, i64 4 }, { ptr, i64 } { ptr @tn.str.594, i64 6 }, { ptr, i64 } { ptr @tn.str.595, i64 5 }, { ptr, i64 } { ptr @tn.str.596, i64 6 }, { ptr, i64 } { ptr @tn.str.597, i64 6 }, { ptr, i64 } { ptr @tn.str.598, i64 7 }, { ptr, i64 } { ptr @tn.str.599, i64 7 }, { ptr, i64 } { ptr @tn.str.600, i64 4 }, { ptr, i64 } { ptr @tn.str.601, i64 16 }, { ptr, i64 } { ptr @tn.str.602, i64 10 }, { ptr, i64 } { ptr @tn.str.603, i64 8 }, { ptr, i64 } { ptr @tn.str.604, i64 11 }, { ptr, i64 } { ptr @tn.str.605, i64 14 }, { ptr, i64 } { ptr @tn.str.606, i64 7 }, { ptr, i64 } { ptr @tn.str.607, i64 13 }, { ptr, i64 } { ptr @tn.str.608, i64 9 }, { ptr, i64 } { ptr @tn.str.609, i64 8 }, { ptr, i64 } { ptr @tn.str.610, i64 10 }, { ptr, i64 } { ptr @tn.str.611, i64 5 }, { ptr, i64 } { ptr @tn.str.612, i64 5 }, { ptr, i64 } { ptr @tn.str.613, i64 9 }, { ptr, i64 } { ptr @tn.str.614, i64 9 }, { ptr, i64 } { ptr @tn.str.615, i64 6 }, { ptr, i64 } { ptr @tn.str.616, i64 16 }, { ptr, i64 } { ptr @tn.str.617, i64 13 }, { ptr, i64 } { ptr @tn.str.618, i64 14 }, { ptr, i64 } { ptr @tn.str.619, i64 7 }, { ptr, i64 } { ptr @tn.str.620, i64 7 }, { ptr, i64 } { ptr @tn.str.621, i64 8 }, { ptr, i64 } { ptr @tn.str.622, i64 8 }, { ptr, i64 } { ptr @tn.str.623, i64 9 }, { ptr, i64 } { ptr @tn.str.624, i64 5 }, { ptr, i64 } { ptr @tn.str.625, i64 11 }, { ptr, i64 } { ptr @tn.str.626, i64 10 }, { ptr, i64 } { ptr @tn.str.627, i64 5 }, { ptr, i64 } { ptr @tn.str.628, i64 12 }, { ptr, i64 } { ptr @tn.str.629, i64 7 }, { ptr, i64 } { ptr @tn.str.630, i64 6 }, { ptr, i64 } { ptr @tn.str.631, i64 10 }, { ptr, i64 } { ptr @tn.str.632, i64 19 }, { ptr, i64 } { ptr @tn.str.633, i64 6 }, { ptr, i64 } { ptr @tn.str.634, i64 4 }, { ptr, i64 } { ptr @tn.str.635, i64 5 }, { ptr, i64 } { ptr @tn.str.636, i64 10 }, { ptr, i64 } { ptr @tn.str.637, i64 5 }, { ptr, i64 } { ptr @tn.str.638, i64 9 }, { ptr, i64 } { ptr @tn.str.639, i64 7 }, { ptr, i64 } { ptr @tn.str.640, i64 10 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.645, i64 8 }, { ptr, i64 } { ptr @tn.str.646, i64 6 }, { ptr, i64 } { ptr @tn.str.647, i64 8 }, { ptr, i64 } { ptr @tn.str.648, i64 13 }, { ptr, i64 } { ptr @tn.str.649, i64 7 }, { ptr, i64 } { ptr @tn.str.650, i64 8 }, { ptr, i64 } { ptr @tn.str.651, i64 5 }, { ptr, i64 } { ptr @tn.str.652, i64 7 }, { ptr, i64 } { ptr @tn.str.653, i64 6 }, { ptr, i64 } { ptr @tn.str.654, i64 7 }, { ptr, i64 } { ptr @tn.str.655, i64 8 }, { ptr, i64 } { ptr @tn.str.656, i64 6 }, { ptr, i64 } { ptr @tn.str.657, i64 8 }, { ptr, i64 } { ptr @tn.str.658, i64 15 }, { ptr, i64 } { ptr @tn.str.659, i64 8 }] @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 [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 +@str.662 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.663 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.664 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.665 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.666 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.667 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.668 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.669 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.670 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.671 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.672 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.673 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.674 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.675 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.676 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.677 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.678 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \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")); \00", align 1 +@str.681 = private unnamed_addr constant [30 x i8] c"=== 20. UFCS Return Type ===\0A\00", align 1 +@str.682 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.683 = private unnamed_addr constant [30 x i8] c"=== 20. UFCS Return Type ===\0A\00", align 1 +@str.684 = private unnamed_addr constant [12 x i8] c"direct: {}\0A\00", align 1 +@str.685 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.686 = private unnamed_addr constant [12 x i8] c"direct: {}\0A\00", align 1 +@str.687 = private unnamed_addr constant [10 x i8] c"ufcs: {}\0A\00", align 1 +@str.688 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.689 = private unnamed_addr constant [10 x i8] c"ufcs: {}\0A\00", align 1 +@str.690 = private unnamed_addr constant [16 x i8] c"Source_Location\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 @fld.str = private constant [5 x i8] c"file\00" -@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 [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 +@fld.str.694 = private constant [5 x i8] c"line\00" +@fld.str.695 = private constant [4 x i8] c"col\00" +@fld.str.696 = 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.694, i64 4 }, { ptr, i64 } { ptr @fld.str.695, i64 3 }, { ptr, i64 } { ptr @fld.str.696, i64 4 }] +@str.697 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.698 = private unnamed_addr constant [10 x i8] c"Allocator\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 +@fld.str.702 = private constant [4 x i8] c"ctx\00" +@fld.str.703 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.704 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.705 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.702, i64 3 }, { ptr, i64 } { ptr @fld.str.703, i64 11 }, { ptr, i64 } { ptr @fld.str.704, i64 13 }] +@str.706 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.707 = private unnamed_addr constant [8 x i8] c"Context\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 +@fld.str.711 = private constant [10 x i8] c"allocator\00" +@fld.str.712 = private constant [5 x i8] c"data\00" +@field_names.713 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.711, i64 9 }, { ptr, i64 } { ptr @fld.str.712, i64 4 }] +@str.714 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.715 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.719 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.720 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.721 = private unnamed_addr constant [4 x i8] c"GPA\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 +@fld.str.725 = private constant [12 x i8] c"alloc_count\00" +@field_names.726 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.725, i64 11 }] +@str.727 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.728 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.733 = private constant [4 x i8] c"cap\00" +@field_names.734 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.732, i64 4 }, { ptr, i64 } { ptr @fld.str.733, i64 3 }] +@str.735 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.736 = private unnamed_addr constant [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.741 = private constant [10 x i8] c"end_index\00" +@fld.str.742 = private constant [7 x i8] c"parent\00" +@field_names.743 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.740, i64 5 }, { ptr, i64 } { ptr @fld.str.741, i64 9 }, { ptr, i64 } { ptr @fld.str.742, i64 6 }] +@str.744 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.745 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.750 = private constant [4 x i8] c"len\00" +@fld.str.751 = private constant [4 x i8] c"pos\00" +@field_names.752 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.749, i64 3 }, { ptr, i64 } { ptr @fld.str.750, i64 3 }, { ptr, i64 } { ptr @fld.str.751, i64 3 }] +@str.753 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.754 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.755 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.756 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.757 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.758 = private constant [7 x i8] c"parent\00" +@fld.str.759 = private constant [12 x i8] c"alloc_count\00" +@fld.str.760 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.761 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.762 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.758, i64 6 }, { ptr, i64 } { ptr @fld.str.759, i64 11 }, { ptr, i64 } { ptr @fld.str.760, i64 13 }, { ptr, i64 } { ptr @fld.str.761, i64 17 }] +@str.763 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.764 = private unnamed_addr constant [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.769 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.768, i64 2 }] +@str.770 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.771 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.772 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.773 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.774 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.775 = private constant [5 x i8] c"file\00" +@fld.str.776 = private constant [5 x i8] c"line\00" +@fld.str.777 = private constant [4 x i8] c"col\00" +@fld.str.778 = private constant [5 x i8] c"func\00" +@fld.str.779 = private constant [10 x i8] c"line_text\00" +@field_names.780 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.775, i64 4 }, { ptr, i64 } { ptr @fld.str.776, i64 4 }, { ptr, i64 } { ptr @fld.str.777, i64 3 }, { ptr, i64 } { ptr @fld.str.778, i64 4 }, { ptr, i64 } { ptr @fld.str.779, i64 9 }] +@str.781 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.782 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.783 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.784 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.785 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.786 = private constant [10 x i8] c"exit_code\00" +@fld.str.787 = private constant [7 x i8] c"stdout\00" +@field_names.788 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.786, i64 9 }, { ptr, i64 } { ptr @fld.str.787, i64 6 }] +@str.789 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.790 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.791 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.792 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.793 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.794 = private constant [8 x i8] c"sin_len\00" +@fld.str.795 = private constant [11 x i8] c"sin_family\00" +@fld.str.796 = private constant [9 x i8] c"sin_port\00" +@fld.str.797 = private constant [9 x i8] c"sin_addr\00" +@fld.str.798 = private constant [9 x i8] c"sin_zero\00" +@field_names.799 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.794, i64 7 }, { ptr, i64 } { ptr @fld.str.795, i64 10 }, { ptr, i64 } { ptr @fld.str.796, i64 8 }, { ptr, i64 } { ptr @fld.str.797, i64 8 }, { ptr, i64 } { ptr @fld.str.798, i64 8 }] +@str.800 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.801 = private unnamed_addr constant [6 x i8] c"Array\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"Object\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 [6 x i8] c"items\00" +@fld.str.815 = private constant [4 x i8] c"len\00" +@fld.str.816 = private constant [4 x i8] c"cap\00" +@field_names.817 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.814, i64 5 }, { ptr, i64 } { ptr @fld.str.815, i64 3 }, { ptr, i64 } { ptr @fld.str.816, i64 3 }] +@str.818 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.819 = private unnamed_addr constant [7 x i8] c"Member\00", align 1 +@str.820 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.821 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.822 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.823 = private constant [4 x i8] c"key\00" +@fld.str.824 = private constant [4 x i8] c"val\00" +@field_names.825 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.823, i64 3 }, { ptr, i64 } { ptr @fld.str.824, i64 3 }] +@str.826 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.827 = private unnamed_addr constant [5 x i8] c"Sink\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"dst\00" +@fld.str.832 = private constant [4 x i8] c"pos\00" +@fld.str.833 = private constant [5 x i8] c"file\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 4 }] +@str.835 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.836 = private unnamed_addr constant [7 x i8] c"Parser\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 +@fld.str.840 = private constant [4 x i8] c"src\00" +@fld.str.841 = private constant [4 x i8] c"pos\00" +@fld.str.842 = private constant [6 x i8] c"alloc\00" +@field_names.843 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.840, i64 3 }, { ptr, i64 } { ptr @fld.str.841, i64 3 }, { ptr, i64 } { ptr @fld.str.842, i64 5 }] +@str.844 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.845 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.846 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.847 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.848 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.849 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.850 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.851 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.856 = private constant [12 x i8] c"takes_value\00" +@fld.str.857 = private constant [9 x i8] c"required\00" +@field_names.858 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.855, i64 4 }, { ptr, i64 } { ptr @fld.str.856, i64 11 }, { ptr, i64 } { ptr @fld.str.857, i64 8 }] +@str.859 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.860 = private unnamed_addr constant [8 x i8] c"Command\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 [6 x i8] c"group\00" +@fld.str.865 = private constant [8 x i8] c"command\00" +@fld.str.866 = private constant [6 x i8] c"flags\00" +@field_names.867 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.864, i64 5 }, { ptr, i64 } { ptr @fld.str.865, i64 7 }, { ptr, i64 } { ptr @fld.str.866, i64 5 }] +@str.868 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.869 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.870 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.871 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.872 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.873 = private constant [4 x i8] c"set\00" +@fld.str.874 = private constant [6 x i8] c"value\00" +@field_names.875 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.873, i64 3 }, { ptr, i64 } { ptr @fld.str.874, i64 5 }] +@str.876 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.877 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.878 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.879 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.880 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.881 = private constant [6 x i8] c"index\00" +@fld.str.882 = private constant [6 x i8] c"token\00" +@field_names.883 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.881, i64 5 }, { ptr, i64 } { ptr @fld.str.882, i64 5 }] +@str.884 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.885 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.886 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.887 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.888 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.889 = private constant [6 x i8] c"group\00" +@fld.str.890 = private constant [8 x i8] c"command\00" +@fld.str.891 = private constant [10 x i8] c"cmd_index\00" +@fld.str.892 = private constant [5 x i8] c"json\00" +@fld.str.893 = private constant [5 x i8] c"rest\00" +@fld.str.894 = private constant [5 x i8] c"spec\00" +@fld.str.895 = private constant [7 x i8] c"values\00" +@field_names.896 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.889, i64 5 }, { ptr, i64 } { ptr @fld.str.890, i64 7 }, { ptr, i64 } { ptr @fld.str.891, i64 9 }, { ptr, i64 } { ptr @fld.str.892, i64 4 }, { ptr, i64 } { ptr @fld.str.893, i64 4 }, { ptr, i64 } { ptr @fld.str.894, i64 4 }, { ptr, i64 } { ptr @fld.str.895, i64 6 }] +@str.897 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.898 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.899 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.900 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.901 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.902 = private constant [2 x i8] c"h\00" +@fld.str.903 = private constant [4 x i8] c"buf\00" +@fld.str.904 = private constant [8 x i8] c"buf_len\00" +@fld.str.905 = private constant [10 x i8] c"total_len\00" +@field_names.906 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.902, i64 1 }, { ptr, i64 } { ptr @fld.str.903, i64 3 }, { ptr, i64 } { ptr @fld.str.904, i64 7 }, { ptr, i64 } { ptr @fld.str.905, i64 9 }] +@str.907 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.908 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 +@str.909 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.910 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.911 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.912 = private constant [5 x i8] c"data\00" +@field_names.913 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.912, i64 4 }] +@str.914 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.915 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 +@str.916 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.917 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.918 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.919 = private constant [2 x i8] c"x\00" +@fld.str.920 = private constant [2 x i8] c"y\00" +@field_names.921 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.919, i64 1 }, { ptr, i64 } { ptr @fld.str.920, i64 1 }] +@str.922 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.923 = private unnamed_addr constant [6 x i8] c"Point\00", align 1 +@str.924 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.925 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.926 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.927 = private constant [2 x i8] c"x\00" +@fld.str.928 = private constant [2 x i8] c"y\00" +@field_names.929 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.927, i64 1 }, { ptr, i64 } { ptr @fld.str.928, i64 1 }] +@str.930 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.931 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.932 = private constant [5 x i8] c"read\00" +@fld.str.933 = private constant [6 x i8] c"write\00" +@fld.str.934 = private constant [7 x i8] c"append\00" +@fld.str.935 = private constant [11 x i8] c"read_write\00" +@field_names.936 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.932, i64 4 }, { ptr, i64 } { ptr @fld.str.933, i64 5 }, { ptr, i64 } { ptr @fld.str.934, i64 6 }, { ptr, i64 } { ptr @fld.str.935, i64 10 }] +@str.937 = private unnamed_addr constant [2 x i8] c"(\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 +@fld.str.940 = private constant [4 x i8] c"set\00" +@fld.str.941 = private constant [8 x i8] c"current\00" +@fld.str.942 = private constant [4 x i8] c"end\00" +@field_names.943 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.940, i64 3 }, { ptr, i64 } { ptr @fld.str.941, i64 7 }, { ptr, i64 } { ptr @fld.str.942, i64 3 }] +@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 [6 x i8] c"null_\00" +@fld.str.948 = private constant [6 x i8] c"bool_\00" +@fld.str.949 = private constant [5 x i8] c"int_\00" +@fld.str.950 = private constant [4 x i8] c"str\00" +@fld.str.951 = private constant [6 x i8] c"array\00" +@fld.str.952 = private constant [7 x i8] c"object\00" +@field_names.953 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.947, i64 5 }, { ptr, i64 } { ptr @fld.str.948, i64 5 }, { ptr, i64 } { ptr @fld.str.949, i64 4 }, { ptr, i64 } { ptr @fld.str.950, i64 3 }, { ptr, i64 } { ptr @fld.str.951, i64 5 }, { ptr, i64 } { ptr @fld.str.952, i64 6 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.957 = private constant [6 x i8] c"macos\00" +@fld.str.958 = private constant [6 x i8] c"linux\00" +@fld.str.959 = private constant [8 x i8] c"windows\00" +@fld.str.960 = private constant [5 x i8] c"wasm\00" +@fld.str.961 = private constant [4 x i8] c"ios\00" +@fld.str.962 = private constant [8 x i8] c"android\00" +@fld.str.963 = private constant [8 x i8] c"unknown\00" +@field_names.964 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.957, i64 5 }, { ptr, i64 } { ptr @fld.str.958, i64 5 }, { ptr, i64 } { ptr @fld.str.959, i64 7 }, { ptr, i64 } { ptr @fld.str.960, i64 4 }, { ptr, i64 } { ptr @fld.str.961, i64 3 }, { ptr, i64 } { ptr @fld.str.962, i64 7 }, { 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 +@fld.str.968 = private constant [8 x i8] c"aarch64\00" +@fld.str.969 = private constant [7 x i8] c"x86_64\00" +@fld.str.970 = private constant [7 x i8] c"wasm32\00" +@fld.str.971 = private constant [7 x i8] c"wasm64\00" +@fld.str.972 = private constant [8 x i8] c"unknown\00" +@field_names.973 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.968, i64 7 }, { ptr, i64 } { ptr @fld.str.969, i64 6 }, { ptr, i64 } { ptr @fld.str.970, i64 6 }, { ptr, i64 } { ptr @fld.str.971, i64 6 }, { ptr, i64 } { ptr @fld.str.972, i64 7 }] +@str.974 = private unnamed_addr constant [2 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 [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 [2 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 [3 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 [2 x i8] c"]\00", align 1 +@str.1008 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.1011 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1012 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1013 = private unnamed_addr constant [6 x i8] c"*void\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 [12 x i8] c"*CAllocator\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 [5 x i8] c"*GPA\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 [12 x i8] c"*ArenaChunk\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 [7 x i8] c"*Arena\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"[*]u8\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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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 [6 x i8] c"*File\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 [4 x i8] c"*u8\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 [5 x i8] c"*s32\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 [10 x i8] c"*SockAddr\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 [5 x i8] c"*u32\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 [9 x i8] c"[*]Value\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 [7 x i8] c"*Array\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 [10 x i8] c"[*]Member\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 [8 x i8] c"*Object\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 [6 x i8] c"*Sink\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 [8 x i8] c"*Parser\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 [5 x i8] c"*s64\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 [8 x i8] c"*Parsed\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 [6 x i8] c"*Diag\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"*Sha256\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 [13 x i8] c"**CAllocator\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"**void\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 [8 x i8] c"*string\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 [5 x i8] c"*Any\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 [7 x i8] c"*[]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 [6 x i8] c"*bool\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 [7 x i8] c"*Point\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 [5 x i8] c"null\00", align 1 -@str.1104 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1103 = private unnamed_addr constant [8 x i8] c"*[1]Any\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 [5 x i8] c"null\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"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -656,85 +656,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -877,7 +799,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.470, i64 1 } + ret { ptr, i64 } { ptr @str.474, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1004,7 +926,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.471, i64 4 }, %if.then.78 ], [ { ptr @str.472, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.475, i64 4 }, %if.then.78 ], [ { ptr @str.476, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1338,7 +1260,7 @@ entry: br i1 %icmp, label %if.then.393, label %if.merge.394 if.then.393: ; preds = %entry - ret { ptr, i64 } { ptr @str.473, i64 1 } + ret { ptr, i64 } { ptr @str.477, i64 1 } if.merge.394: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1488,7 +1410,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.474, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.478, 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 @@ -1515,12 +1437,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1548,26 +1470,26 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 93, label %match.arm.47 i64 105, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 100, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1603,7 +1525,7 @@ match.merge.37: ; preds = %dispatch.merge.496, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.475, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.479, 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,12 +1570,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1707,7 +1629,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.282 [ - i64 35, label %dispatch.case.283 + i64 22, label %dispatch.case.283 i64 81, label %dispatch.case.284 i64 87, label %dispatch.case.285 i64 88, label %dispatch.case.286 @@ -1721,7 +1643,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.326 [ - i64 36, label %dispatch.case.327 + i64 23, label %dispatch.case.327 i64 60, label %dispatch.case.328 i64 77, label %dispatch.case.329 i64 85, label %dispatch.case.330 @@ -1734,13 +1656,13 @@ 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 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 - i64 33, label %dispatch.case.366 + i64 25, label %dispatch.case.360 + i64 27, label %dispatch.case.361 + i64 29, label %dispatch.case.362 + i64 31, label %dispatch.case.363 + i64 32, label %dispatch.case.364 + i64 34, label %dispatch.case.365 + i64 36, label %dispatch.case.366 i64 40, label %dispatch.case.367 i64 44, label %dispatch.case.368 i64 47, label %dispatch.case.369 @@ -1834,7 +1756,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.656, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.660, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1856,56 +1778,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2067,7 +1989,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.657, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.661, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.264 dispatch.case.266: ; preds = %match.arm.44 @@ -2108,7 +2030,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.658, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.662, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.281 dispatch.case.283: ; preds = %match.arm.47 @@ -2173,7 +2095,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.659, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.663, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.325 dispatch.case.327: ; preds = %match.arm.48 @@ -2222,7 +2144,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.660, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.664, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.357 dispatch.case.359: ; preds = %match.arm.49 @@ -2448,7 +2370,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.661, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.665, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.496 dispatch.case.498: ; preds = %match.arm.50 @@ -2490,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.662, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.666, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2586,7 +2508,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.663, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.667, 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 @@ -2594,7 +2516,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.664, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2604,13 +2526,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.665, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.669, 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.666, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.670, 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 @@ -2618,7 +2540,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.667, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.671, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2632,7 +2554,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.668, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.672, 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 @@ -2640,7 +2562,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.669, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2651,7 +2573,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.670, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.674, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2708,7 +2630,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.671, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.675, 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 @@ -2716,7 +2638,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.672, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2727,7 +2649,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.673, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.677, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2747,7 +2669,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.674, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.678, 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 @@ -2755,7 +2677,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.675, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -2766,7 +2688,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.676, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.680, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2776,67 +2698,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3012,166 +3018,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3369,64 +3375,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3456,97 +3462,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3585,7 +3591,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind declare void @Mat4.identity(ptr sret({ [16 x float] }), ptr) #0 @@ -3654,1033 +3660,1039 @@ 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.127(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.128(i64, ptr) #0 +declare void @BuildOptions.add_framework.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.129(i64, ptr) #0 +declare void @BuildOptions.set_output_path.131(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.132(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.133(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.132(i64) #0 +declare i64 @BuildOptions.asset_dir_count.134(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.135(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.136(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.137(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.138(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.137(i64) #0 +declare ptr @BuildOptions.binary_path.139(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.141(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.142(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.143(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.142(i64) #0 +declare ptr @BuildOptions.bundle_path.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.143(i64) #0 +declare ptr @BuildOptions.bundle_id.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.144(i64) #0 +declare ptr @BuildOptions.codesign_identity.146(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.145(i64) #0 +declare ptr @BuildOptions.provisioning_profile.147(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.146(i64) #0 +declare ptr @BuildOptions.target_triple.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.147(i64) #0 +declare i1 @BuildOptions.is_macos.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.148(i64) #0 +declare i1 @BuildOptions.is_ios.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.149(i64) #0 +declare i1 @BuildOptions.is_ios_device.151(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.152(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.151(i64) #0 +declare i1 @BuildOptions.is_android.153(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.152(i64) #0 +declare i64 @BuildOptions.framework_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.154(i64) #0 +declare i64 @BuildOptions.framework_path_count.156(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.157(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.158(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.159(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.158(i64) #0 +declare ptr @BuildOptions.manifest_path.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.159(i64) #0 +declare ptr @BuildOptions.keystore_path.161(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.160(i64) #0 +declare i64 @BuildOptions.jni_main_count.162(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.163(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.164(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.163() #0 +declare i64 @build_options.165() #0 ; Function Attrs: nounwind -declare void @assert.164(ptr, i1) #0 +declare void @assert.166(ptr, i1) #0 ; Function Attrs: nounwind -declare void @out.165(ptr) #0 +declare void @out.167(ptr) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.166(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.168(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.167(ptr, ptr, i64) #0 +declare ptr @cstring.169(ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.168(ptr, ptr, ptr) #0 +declare ptr @int_to_string.170(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.169(ptr) #0 +declare ptr @uint_to_string.171(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.170(ptr, ptr, i64) #0 +declare ptr @bool_to_string.172(ptr, i1) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.171(ptr, ptr, ptr) #0 +declare ptr @float_to_string.173(ptr, double) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.172(ptr, ptr, i64) #0 +declare void @hex_group.174(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.173(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare [4 x i64] @decompose_u16x4.175(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.174(ptr, ptr) #0 +declare ptr @int_to_hex_string.176(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.175(ptr, ptr) #0 +declare ptr @concat.177(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.176(ptr, ptr, i64) #0 +declare ptr @substr.178(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.177(ptr, ptr, ptr) #0 +declare ptr @path_join.179(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.178(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare ptr @any_to_string.180(ptr, [2 x i64]) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.179(ptr, ptr) #0 +declare ptr @build_format.181(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.180(ptr, ptr, i64) #0 +declare void @out.182(ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.181(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.183(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.182(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.184(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.183(ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.185(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.184(ptr, ptr) #0 +declare i64 @GPA.init.186(ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.185(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.187(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.186(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.188(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @cstring.187(ptr, i64) #0 +declare void @Arena.add_chunk.189(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_string.188(ptr, i64) #0 +declare void @Arena.init.190(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @uint_to_string.189(ptr, i64) #0 +declare void @Arena.reset.191(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @bool_to_string.190(ptr, i1) #0 +declare void @Arena.deinit.192(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @float_to_string.191(ptr, double) #0 +declare ptr @Arena.alloc_bytes.193(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @hex_group.192(ptr, ptr, i64, i64) #0 +declare void @Arena.dealloc_bytes.194(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [4 x i64] @decompose_u16x4.193(ptr, i64) #0 +declare void @BufAlloc.init.195(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_hex_string.194(ptr, i64) #0 +declare void @BufAlloc.reset.196(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @concat.195(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.197(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @substr.196(ptr, ptr, i64, i64) #0 +declare void @BufAlloc.dealloc_bytes.198(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @path_join.197(ptr, ptr) #0 +declare void @TrackingAllocator.init.199(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @any_to_string.198(ptr, [2 x i64]) #0 +declare i64 @TrackingAllocator.leak_count.200(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @build_format.199(ptr, ptr) #0 +declare void @TrackingAllocator.report.201(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.200(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.202(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.201(ptr, ptr, i64) #0 +declare void @TrackingAllocator.dealloc_bytes.203(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.202(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.204(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.203(ptr) #0 +declare ptr @CAllocator.alloc_bytes.205(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.204(ptr, ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.206(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.205(ptr, ptr, ptr) #0 +declare i64 @GPA.init.207(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.206(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.208(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.207(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.209(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.reset.208(ptr, ptr) #0 +declare void @Arena.add_chunk.210(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.209(ptr, ptr) #0 +declare void @Arena.init.211(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.210(ptr, ptr, i64) #0 +declare void @Arena.reset.212(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.211(ptr, ptr, ptr) #0 +declare void @Arena.deinit.213(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.212(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.214(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.213(ptr, ptr) #0 +declare void @Arena.dealloc_bytes.215(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.214(ptr, ptr, i64) #0 +declare void @BufAlloc.init.216(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.215(ptr, ptr, ptr) #0 +declare void @BufAlloc.reset.217(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.216(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.218(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.217(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.219(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.218(ptr, ptr) #0 +declare void @TrackingAllocator.init.220(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.219(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.221(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.220(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.222(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @escape.221(ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.223(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @log_emit.222(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.224(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.223(ptr, i32, ...) #0 +declare ptr @escape.225(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.224(i32) #0 +declare void @log_emit.226(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.225(i32, ptr, i64) #0 +declare i32 @open.227(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.226(i32, i64, i32) #0 +declare i32 @close.228(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.227(ptr) #0 +declare i64 @read.229(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.228(ptr) #0 +declare i64 @lseek.230(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.229(ptr, i32) #0 +declare i32 @unlink.231(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.230(ptr, i32) #0 +declare i32 @rmdir.232(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.231(ptr, i32) #0 +declare i32 @mkdir.233(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.232(ptr, ptr) #0 +declare i32 @access.234(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.233(ptr, ptr) #0 +declare i32 @chmod.235(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.234(ptr, ptr) #0 +declare i32 @rename.236(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.235(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.237(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.236(ptr, ptr, ptr) #0 +declare i1 @File.close.238(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.237(ptr, ptr, i64, i64) #0 +declare i64 @File.read.239(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.238(ptr, i64) #0 +declare i64 @File.write.240(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.239(ptr, ptr, i64) #0 +declare i64 @File.seek.241(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.240(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.242(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.241(ptr, ptr, ptr) #0 +declare i64 @open_file.243(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.242(ptr, ptr, ptr) #0 +declare void @read_file.244(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.243(ptr, ptr) #0 +declare i1 @write_file.245(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.244(ptr, ptr) #0 +declare i1 @append_file.246(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.245(ptr, ptr) #0 +declare i1 @exists.247(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.246(ptr, ptr) #0 +declare i1 @delete_file.248(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.247(ptr, ptr, i32) #0 +declare i1 @delete_dir.249(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.248(ptr, ptr, ptr) #0 +declare i1 @create_dir.250(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.249(ptr, ptr) #0 +declare i1 @set_mode.251(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.250(ptr, ptr, ptr) #0 +declare i1 @move.252(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.251(ptr, ptr) #0 +declare i1 @create_dir_all.253(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.252(ptr, ptr) #0 +declare i1 @copy_file.254(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @spaces.253(ptr, i32) #0 +declare ptr @basename.255(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.254() #0 +declare ptr @dirname.256(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.255() #0 +declare ptr @spaces.257(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.256(i32) #0 +declare i32 @sx_trace_len.258() #0 ; Function Attrs: nounwind -declare ptr @to_string.257(ptr) #0 +declare i32 @sx_trace_truncated.259() #0 ; Function Attrs: nounwind -declare void @print_current.258(ptr) #0 +declare i64 @sx_trace_frame_at.260(i32) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.259(ptr) #0 +declare ptr @to_string.261(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.260(ptr, ptr) #0 +declare void @print_current.262(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.261(ptr) #0 +declare void @print_interpreter_frames.263(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.262(ptr, i64, i64, ptr) #0 +declare ptr @popen.264(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.263(ptr) #0 +declare i32 @pclose.265(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.264(ptr) #0 +declare i64 @fread.266(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.265(ptr) #0 +declare i32 @feof.267(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.266(ptr) #0 +declare ptr @getenv.268(ptr) #0 ; Function Attrs: nounwind -declare void @run.267(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare i64 @strlen.269(ptr) #0 ; Function Attrs: nounwind -declare void @env.268(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.270(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.269(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @run.271(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.270(i32) #0 +declare void @env.272(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.271(ptr, i8, ptr) #0 +declare void @find_executable.273(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.272(ptr, i1, ptr, ptr) #0 +declare void @_exit.274(i32) #0 ; Function Attrs: nounwind -declare i32 @socket.273(i32, i32, i32) #0 +declare void @exit.275(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @setsockopt.274(i32, i32, i32, ptr, i32) #0 +declare void @assert.276(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @bind.275(i32, ptr, i32) #0 +declare i32 @socket.277(i32, i32, i32) #0 ; Function Attrs: nounwind -declare i32 @listen.276(i32, i32) #0 +declare i32 @setsockopt.278(i32, i32, i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @accept.277(i32, ptr, ptr) #0 +declare i32 @bind.279(i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @read.278(i32, ptr, i64) #0 +declare i32 @listen.280(i32, i32) #0 ; Function Attrs: nounwind -declare i32 @close.279(i32) #0 +declare i32 @accept.281(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i16 @htons.280(ptr, i64) #0 +declare i64 @read.282(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.281(ptr, ptr, ptr, i64, i64, i64) #0 +declare i32 @close.283(i32) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.282(ptr, ptr, i64) #0 +declare i16 @htons.284(ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.283(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.285(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.284(ptr) #0 +declare ptr @CAllocator.alloc_bytes.286(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.285(ptr, ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.287(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.286(ptr, ptr, ptr) #0 +declare i64 @GPA.init.288(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.287(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.289(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.288(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.290(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.reset.289(ptr, ptr) #0 +declare void @Arena.add_chunk.291(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.290(ptr, ptr) #0 +declare void @Arena.init.292(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.291(ptr, ptr, i64) #0 +declare void @Arena.reset.293(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.292(ptr, ptr, ptr) #0 +declare void @Arena.deinit.294(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.293(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.295(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.294(ptr, ptr) #0 +declare void @Arena.dealloc_bytes.296(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.295(ptr, ptr, i64) #0 +declare void @BufAlloc.init.297(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.296(ptr, ptr, ptr) #0 +declare void @BufAlloc.reset.298(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.297(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.299(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.298(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.300(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.299(ptr, ptr) #0 +declare void @TrackingAllocator.init.301(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.300(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.302(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.301(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.303(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.302(ptr, i32, ...) #0 +declare ptr @TrackingAllocator.alloc_bytes.304(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.303(i32) #0 +declare void @TrackingAllocator.dealloc_bytes.305(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.304(i32, ptr, i64) #0 +declare i32 @open.306(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.305(i32, i64, i32) #0 +declare i32 @close.307(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.306(ptr) #0 +declare i64 @read.308(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.307(ptr) #0 +declare i64 @lseek.309(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.308(ptr, i32) #0 +declare i32 @unlink.310(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.309(ptr, i32) #0 +declare i32 @rmdir.311(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.310(ptr, i32) #0 +declare i32 @mkdir.312(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.311(ptr, ptr) #0 +declare i32 @access.313(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.312(ptr, ptr) #0 +declare i32 @chmod.314(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.313(ptr, ptr) #0 +declare i32 @rename.315(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.314(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.316(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.315(ptr, ptr, ptr) #0 +declare i1 @File.close.317(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.316(ptr, ptr, i64, i64) #0 +declare i64 @File.read.318(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.317(ptr, i64) #0 +declare i64 @File.write.319(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.318(ptr, ptr, i64) #0 +declare i64 @File.seek.320(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.319(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.321(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.320(ptr, ptr, ptr) #0 +declare i64 @open_file.322(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.321(ptr, ptr, ptr) #0 +declare void @read_file.323(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.322(ptr, ptr) #0 +declare i1 @write_file.324(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.323(ptr, ptr) #0 +declare i1 @append_file.325(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.324(ptr, ptr) #0 +declare i1 @exists.326(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.325(ptr, ptr) #0 +declare i1 @delete_file.327(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.326(ptr, ptr, i32) #0 +declare i1 @delete_dir.328(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.327(ptr, ptr, ptr) #0 +declare i1 @create_dir.329(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.328(ptr, ptr) #0 +declare i1 @set_mode.330(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.329(ptr, ptr, ptr) #0 +declare i1 @move.331(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.330(ptr, ptr) #0 +declare i1 @create_dir_all.332(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.331(ptr, ptr) #0 +declare i1 @copy_file.333(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.add.332(ptr, ptr, ptr, ptr) #0 +declare ptr @basename.334(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.deinit.333(ptr, ptr, ptr) #0 +declare ptr @dirname.335(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.put.334(ptr, ptr, ptr, ptr, ptr) #0 +declare void @Array.add.336(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.deinit.335(ptr, ptr, ptr) #0 +declare void @Array.deinit.337(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put_byte.336(ptr, ptr, i8) #0 +declare void @Object.put.338(ptr, ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put.337(ptr, ptr, ptr) #0 +declare void @Object.deinit.339(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.flush.338(ptr, ptr) #0 +declare i32 @Sink.put_byte.340(ptr, ptr, i8) #0 ; Function Attrs: nounwind -declare i8 @hex_digit.339(ptr, i64) #0 +declare i32 @Sink.put.341(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_u_escape.340(ptr, i8, ptr) #0 +declare i32 @Sink.flush.342(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_string.341(ptr, ptr, ptr) #0 +declare i8 @hex_digit.343(ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @write_int.342(ptr, i64, ptr) #0 +declare i32 @write_u_escape.344(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_value.343(ptr, ptr, ptr) #0 +declare i32 @write_string.345(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_array.344(ptr, ptr, ptr) #0 +declare i32 @write_int.346(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_object.345(ptr, ptr, ptr) #0 +declare i32 @write_value.347(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @write_to_buffer.346(ptr, ptr, ptr) #0 +declare i32 @write_array.348(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_to_file.347(ptr, ptr, ptr, ptr) #0 +declare i32 @write_object.349(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @hex_value.348(ptr, i8) #0 +declare [2 x i64] @write_to_buffer.350(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @encode_utf8.349(ptr, i64, ptr) #0 +declare i32 @write_to_file.351(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.skip_ws.350(ptr, ptr) #0 +declare [2 x i64] @hex_value.352(ptr, i8) #0 ; Function Attrs: nounwind -declare i32 @Parser.expect_lit.351(ptr, ptr, ptr) #0 +declare i64 @encode_utf8.353(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.read_hex4.352(ptr, ptr, i64, i64) #0 +declare void @Parser.skip_ws.354(ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.decode_into.353(ptr, ptr, i64, i64, ptr) #0 +declare i32 @Parser.expect_lit.355(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_string.354(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.read_hex4.356(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.parse_number.355(ptr, ptr) #0 +declare [2 x i64] @Parser.decode_into.357(ptr, ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_array.356(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare void @Parser.parse_string.358(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_object.357(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.parse_number.359(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_value.358(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare void @Parser.parse_array.360(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.359(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 +declare void @Parser.parse_object.361(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.360(i64, ptr) #0 +declare void @Parser.parse_value.362(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.361(i64, ptr) #0 +declare void @parse.363(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.362(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.364(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.363(i64, ptr) #0 +declare void @BuildOptions.add_framework.365(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.364(i64, ptr, ptr) #0 +declare void @BuildOptions.set_output_path.366(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.365(i64) #0 +declare void @BuildOptions.set_wasm_shell.367(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.366(i64, i64) #0 +declare void @BuildOptions.add_asset_dir.368(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.367(i64, i64) #0 +declare i64 @BuildOptions.asset_dir_count.369(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.368(i64, ptr) #0 +declare ptr @BuildOptions.asset_dir_src_at.370(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.369(i64, ptr) #0 +declare ptr @BuildOptions.asset_dir_dest_at.371(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.370(i64) #0 +declare void @BuildOptions.set_post_link_callback.372(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.371(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.373(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.372(i64, ptr) #0 +declare ptr @BuildOptions.binary_path.374(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.373(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.375(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.374(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.376(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.375(i64) #0 +declare void @BuildOptions.set_codesign_identity.377(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.376(i64) #0 +declare void @BuildOptions.set_provisioning_profile.378(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.377(i64) #0 +declare ptr @BuildOptions.bundle_path.379(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.378(i64) #0 +declare ptr @BuildOptions.bundle_id.380(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.379(i64) #0 +declare ptr @BuildOptions.codesign_identity.381(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.380(i64) #0 +declare ptr @BuildOptions.provisioning_profile.382(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.381(i64) #0 +declare ptr @BuildOptions.target_triple.383(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.382(i64) #0 +declare i1 @BuildOptions.is_macos.384(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.383(i64) #0 +declare i1 @BuildOptions.is_ios.385(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.384(i64) #0 +declare i1 @BuildOptions.is_ios_device.386(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.385(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.387(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.386(i64, i64) #0 +declare i1 @BuildOptions.is_android.388(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.387(i64) #0 +declare i64 @BuildOptions.framework_count.389(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.388(i64, i64) #0 +declare ptr @BuildOptions.framework_at.390(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.389(i64, ptr) #0 +declare i64 @BuildOptions.framework_path_count.391(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.390(i64, ptr) #0 +declare ptr @BuildOptions.framework_path_at.392(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.391(i64) #0 +declare void @BuildOptions.set_manifest_path.393(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.392(i64) #0 +declare void @BuildOptions.set_keystore_path.394(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.393(i64) #0 +declare ptr @BuildOptions.manifest_path.395(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.394(i64, i64) #0 +declare ptr @BuildOptions.keystore_path.396(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.395(i64, i64) #0 +declare i64 @BuildOptions.jni_main_count.397(i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.396() #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.398(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @spaces.397(ptr, i32) #0 +declare ptr @BuildOptions.jni_main_java_source_at.399(i64, i64) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.398() #0 +declare i64 @build_options.400() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.399() #0 +declare ptr @spaces.401(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.400(i32) #0 +declare i32 @sx_trace_len.402() #0 ; Function Attrs: nounwind -declare ptr @to_string.401(ptr) #0 +declare i32 @sx_trace_truncated.403() #0 ; Function Attrs: nounwind -declare void @print_current.402(ptr) #0 +declare i64 @sx_trace_frame_at.404(i32) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.403(ptr) #0 +declare ptr @to_string.405(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.404(ptr, ptr) #0 +declare void @print_current.406(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.405(ptr) #0 +declare void @print_interpreter_frames.407(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.406(ptr, i64, i64, ptr) #0 +declare ptr @popen.408(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.407(ptr) #0 +declare i32 @pclose.409(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.408(ptr) #0 +declare i64 @fread.410(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.409(ptr) #0 +declare i32 @feof.411(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.410(ptr) #0 +declare ptr @getenv.412(ptr) #0 ; Function Attrs: nounwind -declare void @run.411(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare i64 @strlen.413(ptr) #0 ; Function Attrs: nounwind -declare void @env.412(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.414(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.413(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @run.415(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.414(i32) #0 +declare void @env.416(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.415(ptr, i8, ptr) #0 +declare void @find_executable.417(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.416(ptr, i1, ptr, ptr) #0 +declare void @_exit.418(i32) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgv.417() #0 +declare void @exit.419(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgc.418() #0 +declare void @assert.420(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit_ok.419(ptr) #0 +declare ptr @_NSGetArgv.421() #0 ; Function Attrs: nounwind -declare void @exit_usage.420(ptr) #0 +declare ptr @_NSGetArgc.422() #0 ; Function Attrs: nounwind -declare i64 @os_argc.421(ptr) #0 +declare void @exit_ok.423(ptr) #0 ; Function Attrs: nounwind -declare ptr @os_args.422(ptr, ptr) #0 +declare void @exit_usage.424(ptr) #0 ; Function Attrs: nounwind -declare i1 @Parsed.is_set.423(ptr, ptr, ptr) #0 +declare i64 @os_argc.425(ptr) #0 ; Function Attrs: nounwind -declare ptr @Parsed.value_of.424(ptr, ptr, ptr) #0 +declare ptr @os_args.426(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @is_long_flag.425(ptr, ptr) #0 +declare i1 @Parsed.is_set.427(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare ptr @Parsed.value_of.428(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.427(ptr, i32, ...) #0 +declare i1 @is_long_flag.429(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.428(i32) #0 +declare void @parse.430(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 @read.429(i32, ptr, i64) #0 +declare i32 @open.431(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.430(i32, i64, i32) #0 +declare i32 @close.432(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.431(ptr) #0 +declare i64 @read.433(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.432(ptr) #0 +declare i64 @lseek.434(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.433(ptr, i32) #0 +declare i32 @unlink.435(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.434(ptr, i32) #0 +declare i32 @rmdir.436(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.435(ptr, i32) #0 +declare i32 @mkdir.437(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.436(ptr, ptr) #0 +declare i32 @access.438(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.437(ptr, ptr) #0 +declare i32 @chmod.439(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.438(ptr, ptr) #0 +declare i32 @rename.440(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.439(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.441(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.440(ptr, ptr, ptr) #0 +declare i1 @File.close.442(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.441(ptr, ptr, i64, i64) #0 +declare i64 @File.read.443(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.442(ptr, i64) #0 +declare i64 @File.write.444(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.443(ptr, ptr, i64) #0 +declare i64 @File.seek.445(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.444(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.446(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.445(ptr, ptr, ptr) #0 +declare i64 @open_file.447(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.446(ptr, ptr, ptr) #0 +declare void @read_file.448(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.447(ptr, ptr) #0 +declare i1 @write_file.449(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.448(ptr, ptr) #0 +declare i1 @append_file.450(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.449(ptr, ptr) #0 +declare i1 @exists.451(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.450(ptr, ptr) #0 +declare i1 @delete_file.452(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.451(ptr, ptr, i32) #0 +declare i1 @delete_dir.453(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.452(ptr, ptr, ptr) #0 +declare i1 @create_dir.454(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.453(ptr, ptr) #0 +declare i1 @set_mode.455(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.454(ptr, ptr, ptr) #0 +declare i1 @move.456(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.455(ptr, ptr) #0 +declare i1 @create_dir_all.457(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.456(ptr, ptr) #0 +declare i1 @copy_file.458(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @rotr.457(ptr, i64, i64) #0 +declare ptr @basename.459(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma0.458(ptr, i64) #0 +declare ptr @dirname.460(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma1.459(ptr, i64) #0 +declare i64 @rotr.461(ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @small_sigma0.460(ptr, i64) #0 +declare i64 @big_sigma0.462(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @small_sigma1.461(ptr, i64) #0 +declare i64 @big_sigma1.463(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.process_block.462(ptr, ptr) #0 +declare i64 @small_sigma0.464(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.update.463(ptr, ptr, ptr) #0 +declare i64 @small_sigma1.465(ptr, i64) #0 ; Function Attrs: nounwind -declare [64 x i8] @Sha256.final.464(ptr, ptr) #0 +declare void @Sha256.process_block.466(ptr, ptr) #0 ; Function Attrs: nounwind -declare i8 @nibble_hex.465(ptr, i64) #0 +declare void @Sha256.update.467(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @init.466(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 +declare [64 x i8] @Sha256.final.468(ptr, ptr) #0 ; Function Attrs: nounwind -declare [64 x i8] @sha256_hex.467(ptr, ptr) #0 +declare i8 @nibble_hex.469(ptr, i64) #0 ; Function Attrs: nounwind -declare void @sha256_file.468(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 +declare void @init.470(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 ; Function Attrs: nounwind -declare void @assert.469(ptr, i1) #0 +declare [64 x i8] @sha256_hex.471(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @sha256_file.472(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @assert.473(ptr, i1) #0 ; Function Attrs: nounwind declare ptr @cwd_greet(ptr) #0 @@ -4740,14 +4752,14 @@ entry: define internal void @print__ct_s86e89ca9c0674196__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.677, i64 29 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.681, 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.678, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.682, 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) @@ -4763,7 +4775,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.679, i64 29 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.683, i64 29 }) ret { ptr, i64 } %call } @@ -4771,7 +4783,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.680, i64 11 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.684, 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 @@ -4787,7 +4799,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.681, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.685, 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) @@ -4815,7 +4827,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.682, i64 11 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.686, i64 11 }) ret { ptr, i64 } %call } @@ -4823,7 +4835,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.683, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.687, 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 @@ -4839,7 +4851,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.684, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.688, 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) @@ -4867,7 +4879,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.685, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.689, i64 9 }) ret { ptr, i64 } %call } @@ -4878,7 +4890,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.686, i64 15 }, { ptr, i64 } { ptr @str.687, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.690, i64 15 }, { ptr, i64 } { ptr @str.691, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4897,12 +4909,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.688, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, 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.689, 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.128 @@ -4914,7 +4926,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.693, 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 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4971,7 +4983,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.694, i64 9 }, { ptr, i64 } { ptr @str.695, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, i64 9 }, { ptr, i64 } { ptr @str.699, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4990,24 +5002,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.696, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.700, 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.697, 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 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 [3 x { ptr, i64 }], ptr @field_names.701, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.705, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 }) + %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -5051,20 +5063,21 @@ fv.case21: ; preds = %if.merge.133 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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.703, i64 10 }, { ptr, i64 } { ptr @str.704, i64 1 }) + %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.707, i64 7 }, { ptr, i64 } { ptr @str.708, 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 +while.hdr.134: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 2 br i1 %icmp, label %while.body.135, label %while.exit.136 while.body.135: ; preds = %while.hdr.134 @@ -5074,24 +5087,102 @@ while.body.135: ; preds = %while.hdr.134 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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.709, 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 }) + %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 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.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.713, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 }) + %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 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.134 + +fv.default: ; preds = %if.merge.138 + br label %fv.merge + +fv.case: ; preds = %if.merge.138 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.138 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.715, i64 10 }, { ptr, i64 } { ptr @str.716, 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 = %if.merge.143, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + 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.717, 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.718, 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 [0 x { ptr, i64 }], ptr @field_names.719, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5102,7 +5193,7 @@ if.merge.138: ; preds = %if.then.137, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.134 + br label %while.hdr.139 } ; Function Attrs: nounwind @@ -5110,43 +5201,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 3 }, { ptr, i64 } { ptr @str.722, 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 + br label %while.hdr.144 -while.hdr.139: ; preds = %fv.merge, %entry +while.hdr.144: ; 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 + br i1 %icmp, label %while.body.145, label %while.exit.146 -while.body.140: ; preds = %while.hdr.139 +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.142, label %if.merge.143 + br i1 %icmpN, label %if.then.147, label %if.merge.148 -while.exit.141: ; preds = %while.hdr.139 +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.711, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.723, i64 1 }) ret { ptr, i64 } %callN -if.then.142: ; preds = %while.body.140 +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.712, 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.143 + br label %if.merge.148 -if.merge.143: ; preds = %if.then.142, %while.body.140 +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 [1 x { ptr, i64 }], ptr @field_names.714, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.726, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 }) + %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64 }, ptr %alloca, align 8 @@ -5163,12 +5254,12 @@ 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.139 + br label %while.hdr.144 -fv.default: ; preds = %if.merge.143 +fv.default: ; preds = %if.merge.148 br label %fv.merge -fv.case: ; preds = %if.merge.143 +fv.case: ; preds = %if.merge.148 %fv.field = extractvalue { i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge @@ -5179,43 +5270,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 10 }, { ptr, i64 } { ptr @str.729, 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 + br label %while.hdr.149 -while.hdr.144: ; preds = %fv.merge, %entry +while.hdr.149: ; 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 + br i1 %icmp, label %while.body.150, label %while.exit.151 -while.body.145: ; preds = %while.hdr.144 +while.body.150: ; preds = %while.hdr.149 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.147, label %if.merge.148 + br i1 %icmpN, label %if.then.152, label %if.merge.153 -while.exit.146: ; preds = %while.hdr.144 +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.718, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.730, i64 1 }) ret { ptr, i64 } %callN -if.then.147: ; preds = %while.body.145 +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.719, i64 2 }) + %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 - br label %if.merge.148 + br label %if.merge.153 -if.merge.148: ; preds = %if.then.147, %while.body.145 +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 [2 x { ptr, i64 }], ptr @field_names.722, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.734, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 }) + %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -5233,18 +5324,18 @@ 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.144 + br label %while.hdr.149 -fv.default: ; preds = %if.merge.148 +fv.default: ; preds = %if.merge.153 br label %fv.merge -fv.case: ; preds = %if.merge.148 +fv.case: ; preds = %if.merge.153 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.148 +fv.case17: ; preds = %if.merge.153 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -5256,91 +5347,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.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 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.149 - -while.hdr.149: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.150, label %while.exit.151 - -while.body.150: ; preds = %while.hdr.149 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.152, label %if.merge.153 - -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.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.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.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 { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.149 - -fv.default: ; preds = %if.merge.153 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.153 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 8 }, { ptr, i64 } { ptr @str.734, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.736, i64 5 }, { ptr, i64 } { ptr @str.737, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5359,27 +5366,27 @@ 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.735, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.738, 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.736, 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.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.740, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.743, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.741, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -5401,17 +5408,101 @@ fv.default: ; preds = %if.merge.158 br label %fv.merge fv.case: ; preds = %if.merge.158 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.158 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.158 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64, i64 }, align 8 + store { ptr, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.745, i64 8 }, { ptr, i64 } { ptr @str.746, 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.159 + +while.hdr.159: ; preds = %fv.merge, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 3 + br i1 %icmp, label %while.body.160, label %while.exit.161 + +while.body.160: ; preds = %while.hdr.159 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.162, label %if.merge.163 + +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.747, 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.748, 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 [3 x { ptr, i64 }], ptr @field_names.752, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %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 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + i64 2, label %fv.case20 + ] + +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.159 + +fv.default: ; preds = %if.merge.163 + br label %fv.merge + +fv.case: ; preds = %if.merge.163 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.163 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.163 %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge @@ -5423,43 +5514,43 @@ 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.742, i64 17 }, { ptr, i64 } { ptr @str.743, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.754, i64 17 }, { ptr, i64 } { ptr @str.755, 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.159 + br label %while.hdr.164 -while.hdr.159: ; preds = %fv.merge, %entry +while.hdr.164: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 4 - br i1 %icmp, label %while.body.160, label %while.exit.161 + br i1 %icmp, label %while.body.165, label %while.exit.166 -while.body.160: ; preds = %while.hdr.159 +while.body.165: ; preds = %while.hdr.164 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.162, label %if.merge.163 + br i1 %icmpN, label %if.then.167, label %if.merge.168 -while.exit.161: ; preds = %while.hdr.159 +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.744, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.756, i64 1 }) ret { ptr, i64 } %callN -if.then.162: ; preds = %while.body.160 +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.745, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.757, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.163 + br label %if.merge.168 -if.merge.163: ; preds = %if.then.162, %while.body.160 +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 [4 x { ptr, i64 }], ptr @field_names.750, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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.751, 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, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -5479,110 +5570,31 @@ 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.159 - -fv.default: ; preds = %if.merge.163 - br label %fv.merge - -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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.163 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.163 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 - br label %fv.merge - -fv.case23: ; preds = %if.merge.163 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { -entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 - %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.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 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.164 - -while.hdr.164: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.165, label %while.exit.166 - -while.body.165: ; preds = %while.hdr.164 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.167, label %if.merge.168 - -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.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.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.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.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 - %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.164 fv.default: ; preds = %if.merge.168 br label %fv.merge fv.case: ; preds = %if.merge.168 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.168 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.168 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.168 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -5591,7 +5603,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.760, i64 4 }, { ptr, i64 } { ptr @str.761, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 4 }, { 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 @@ -5610,24 +5622,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.762, 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.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.763, 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.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.765, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.769, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.770, 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 @@ -5664,7 +5676,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.767, i64 10 }, { ptr, i64 } { ptr @str.768, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 10 }, { ptr, i64 } { ptr @str.772, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5683,24 +5695,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.769, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.773, 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.770, 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 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.776, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.780, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.781, 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 @@ -5766,7 +5778,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.778, i64 13 }, { ptr, i64 } { ptr @str.779, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.782, i64 13 }, { ptr, i64 } { ptr @str.783, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5785,24 +5797,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.780, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.784, 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.781, 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 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.784, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.788, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.789, 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 @@ -5844,7 +5856,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.786, i64 8 }, { ptr, i64 } { ptr @str.787, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.790, i64 8 }, { ptr, i64 } { ptr @str.791, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5863,24 +5875,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.788, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.792, 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.789, 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 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.795, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.799, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.800, 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 @@ -5941,7 +5953,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.797, i64 5 }, { ptr, i64 } { ptr @str.798, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 5 }, { ptr, i64 } { ptr @str.802, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5960,24 +5972,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.799, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.803, 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.800, 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 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.804, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.808, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.805, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 @@ -6023,7 +6035,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.806, i64 6 }, { ptr, i64 } { ptr @str.807, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.810, i64 6 }, { ptr, i64 } { ptr @str.811, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6042,24 +6054,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.808, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.812, 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.809, 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 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.813, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.817, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.814, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 @@ -6107,7 +6119,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.815, i64 6 }, { ptr, i64 } { ptr @str.816, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.819, i64 6 }, { ptr, i64 } { ptr @str.820, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6126,24 +6138,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.817, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.821, 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.818, 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 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.821, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.825, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.826, 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 @@ -6187,7 +6199,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.823, i64 4 }, { ptr, i64 } { ptr @str.824, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.827, i64 4 }, { ptr, i64 } { ptr @str.828, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6206,24 +6218,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.825, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.829, 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.826, 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 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.830, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.834, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.835, 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 @@ -6273,7 +6285,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.832, i64 6 }, { ptr, i64 } { ptr @str.833, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.836, i64 6 }, { ptr, i64 } { ptr @str.837, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6292,24 +6304,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.834, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.838, 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.835, 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 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.839, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.843, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.844, 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 @@ -6358,7 +6370,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.841, i64 12 }, { ptr, i64 } { ptr @str.842, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.845, i64 12 }, { ptr, i64 } { ptr @str.846, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6377,24 +6389,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.843, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.847, 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.844, 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 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.845, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.849, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.846, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6414,7 +6426,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.847, i64 8 }, { ptr, i64 } { ptr @str.848, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.851, i64 8 }, { ptr, i64 } { ptr @str.852, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6433,24 +6445,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.849, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.853, 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.850, 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 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.854, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.858, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.855, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -6502,7 +6514,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.856, i64 7 }, { ptr, i64 } { ptr @str.857, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.860, i64 7 }, { ptr, i64 } { ptr @str.861, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6521,24 +6533,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.858, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.862, 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.859, 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 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.863, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.867, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.864, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -6590,7 +6602,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.865, i64 9 }, { ptr, i64 } { ptr @str.866, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.869, i64 9 }, { ptr, i64 } { ptr @str.870, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6609,24 +6621,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.867, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.871, 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.868, 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 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.871, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.875, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.876, 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 @@ -6669,7 +6681,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.873, i64 4 }, { ptr, i64 } { ptr @str.874, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.877, i64 4 }, { ptr, i64 } { ptr @str.878, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6688,24 +6700,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.875, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.879, 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.876, 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 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.879, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.883, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.880, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -6751,7 +6763,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.881, i64 6 }, { ptr, i64 } { ptr @str.882, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.885, i64 6 }, { ptr, i64 } { ptr @str.886, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6770,24 +6782,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.883, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.887, 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.884, 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 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.892, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.896, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.893, 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 %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 @@ -6844,7 +6856,7 @@ fv.case28: ; preds = %if.merge.243 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.243 @@ -6869,7 +6881,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.894, i64 6 }, { ptr, i64 } { ptr @str.895, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.898, i64 6 }, { ptr, i64 } { ptr @str.899, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6888,24 +6900,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.896, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.900, 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.897, 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 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.902, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.906, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.903, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6961,7 +6973,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.904, i64 4 }, { ptr, i64 } { ptr @str.905, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.908, i64 4 }, { ptr, i64 } { ptr @str.909, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6980,24 +6992,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.906, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.910, 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.907, 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 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.909, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.913, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.914, 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 @@ -7032,7 +7044,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.911, i64 4 }, { ptr, i64 } { ptr @str.912, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.915, i64 4 }, { ptr, i64 } { ptr @str.916, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7051,24 +7063,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.913, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.917, 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.914, 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 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.917, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.921, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.918, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { float, float }, ptr %alloca, align 4 @@ -7111,7 +7123,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.919, i64 5 }, { ptr, i64 } { ptr @str.920, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.923, i64 5 }, { ptr, i64 } { ptr @str.924, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7130,24 +7142,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.921, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.925, 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.922, 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 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.925, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.929, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.926, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, i32 }, ptr %alloca, align 4 @@ -7192,9 +7204,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.932, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.936, 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.927, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.931, 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 @@ -7213,8 +7225,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.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 } { ptr @str.938, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.937, 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 @@ -7233,9 +7245,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.939, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.943, 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.935, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.939, 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 @@ -7254,8 +7266,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.274 @@ -7285,9 +7297,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.949, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.953, 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.942, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.946, 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 @@ -7304,8 +7316,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.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 } { ptr @str.955, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.954, 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 @@ -7383,9 +7395,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.960, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.964, 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.952, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.956, 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 @@ -7404,8 +7416,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.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.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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.278 @@ -7424,9 +7436,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.969, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.973, 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.967, 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 @@ -7445,8 +7457,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.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 } { ptr @str.975, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.974, 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 @@ -7463,7 +7475,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.972, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.976, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.290 @@ -7480,12 +7492,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.973, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.977, 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.974, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.978, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.294 @@ -7514,7 +7526,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.975, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.979, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.295 @@ -7531,12 +7543,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.976, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.980, 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.977, 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 br label %if.merge.299 @@ -7566,7 +7578,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.978, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.982, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.300 @@ -7583,12 +7595,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.979, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.983, 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.980, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.984, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.304 @@ -7616,7 +7628,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.981, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.985, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.305 @@ -7633,12 +7645,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.982, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.986, 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.983, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.987, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.309 @@ -7667,7 +7679,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.984, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.988, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.310 @@ -7684,12 +7696,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.985, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.989, 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.986, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.990, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.314 @@ -7717,7 +7729,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.987, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.991, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.315 @@ -7734,12 +7746,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.988, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.992, 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.989, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.993, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.319 @@ -7770,7 +7782,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.990, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.994, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.320 @@ -7787,12 +7799,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.991, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.995, 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.992, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.996, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.324 @@ -7822,7 +7834,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.993, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.997, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.332 @@ -7841,12 +7853,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.994, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.998, 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.995, 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.336 @@ -7875,7 +7887,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.996, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1000, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.337 @@ -7894,12 +7906,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.997, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1001, 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.998, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1002, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.341 @@ -7928,7 +7940,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.999, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1003, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.342 @@ -7947,12 +7959,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.1000, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1004, 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.1001, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1005, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.346 @@ -7982,7 +7994,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.1002, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1006, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.347 @@ -8001,12 +8013,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.1003, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1007, 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.1004, 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.351 @@ -8036,7 +8048,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.1005, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1009, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.352 @@ -8055,12 +8067,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.1006, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1010, 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.1007, 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 br label %if.merge.356 @@ -8102,12 +8114,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.1010, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1009, i64 5 }, { ptr, i64 } %callN) + %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 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.1008, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] + %bp = phi { ptr, i64 } [ { ptr @str.1012, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] ret { ptr, i64 } %bp } @@ -8130,12 +8142,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.1013, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1012, i64 11 }, { ptr, i64 } %callN) + %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 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.1011, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.1015, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -8158,12 +8170,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.1016, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1015, i64 4 }, { ptr, i64 } %callN) + %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 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.1014, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.1018, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -8186,12 +8198,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.1019, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1018, i64 11 }, { ptr, i64 } %callN) + %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 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.1017, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.1021, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -8214,12 +8226,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.1022, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1021, i64 6 }, { ptr, i64 } %callN) + %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 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.1020, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.1024, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -8241,12 +8253,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.1025, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1024, i64 5 }, { ptr, i64 } %callN) + %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) br label %if.merge.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.1023, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.1027, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -8269,12 +8281,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.1028, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1027, i64 9 }, { ptr, i64 } %callN) + %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 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.1026, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.1030, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -8297,12 +8309,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.1031, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1030, i64 18 }, { ptr, i64 } %callN) + %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 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.1029, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.1033, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -8325,12 +8337,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.1034, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1033, i64 5 }, { ptr, i64 } %callN) + %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 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.1032, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.1036, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -8353,12 +8365,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.1037, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1036, i64 3 }, { ptr, i64 } %callN) + %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 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.1035, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.1039, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -8381,12 +8393,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.1040, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1039, i64 4 }, { ptr, i64 } %callN) + %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 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.1038, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.1042, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -8409,12 +8421,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.1043, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1042, i64 9 }, { ptr, i64 } %callN) + %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 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.1041, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.1045, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -8437,12 +8449,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.1046, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1045, i64 4 }, { ptr, i64 } %callN) + %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 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.1044, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.1048, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -8464,12 +8476,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.1049, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1048, i64 8 }, { ptr, i64 } %callN) + %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 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.1047, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.1051, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -8492,12 +8504,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.1052, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1051, i64 6 }, { ptr, i64 } %callN) + %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 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.1050, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.1054, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -8519,12 +8531,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.1055, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1054, i64 9 }, { ptr, i64 } %callN) + %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 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.1053, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.1057, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -8547,12 +8559,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.1058, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1057, i64 7 }, { ptr, i64 } %callN) + %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 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.1056, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.1060, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -8575,12 +8587,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.1061, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1060, i64 5 }, { ptr, i64 } %callN) + %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 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.1059, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.1063, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -8603,12 +8615,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.1064, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1063, i64 7 }, { ptr, i64 } %callN) + %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 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.1062, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.1066, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -8631,12 +8643,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.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.1071, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1070, 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.1065, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.1069, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -8659,12 +8671,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.1070, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1069, i64 7 }, { ptr, i64 } %callN) + %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 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.1068, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.1072, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -8687,12 +8699,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.1073, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1072, i64 5 }, { ptr, i64 } %callN) + %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 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.1071, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.1075, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -8715,12 +8727,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.1076, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1075, i64 7 }, { ptr, i64 } %callN) + %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) br label %if.merge.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.1074, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.1078, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -8743,12 +8755,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.1079, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1078, i64 12 }, { ptr, i64 } %callN) + %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 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.1077, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.1081, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -8771,12 +8783,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.1082, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1081, i64 6 }, { ptr, i64 } %callN) + %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) br label %if.merge.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.1080, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.1084, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -8799,12 +8811,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.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.1089, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1088, 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.1083, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] + %bp = phi { ptr, i64 } [ { ptr @str.1087, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] ret { ptr, i64 } %bp } @@ -8827,12 +8839,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.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.1092, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1091, 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.1086, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] + %bp = phi { ptr, i64 } [ { ptr @str.1090, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] ret { ptr, i64 } %bp } @@ -8855,12 +8867,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.1091, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1090, i64 6 }, { 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 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.1089, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] + %bp = phi { ptr, i64 } [ { ptr @str.1093, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] ret { ptr, i64 } %bp } @@ -8883,12 +8895,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.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.1098, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1097, 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.1092, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] + %bp = phi { ptr, i64 } [ { ptr @str.1096, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] ret { ptr, i64 } %bp } @@ -8911,12 +8923,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.1097, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1096, i64 6 }, { 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 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.1095, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] + %bp = phi { ptr, i64 } [ { ptr @str.1099, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] ret { ptr, i64 } %bp } @@ -8939,12 +8951,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.1100, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1099, i64 7 }, { 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 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.1098, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] + %bp = phi { ptr, i64 } [ { ptr @str.1102, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] ret { ptr, i64 } %bp } @@ -8960,7 +8972,7 @@ entry: br i1 %lnot, label %if.then.502, label %if.merge.503 if.then.502: ; preds = %entry - ret { ptr, i64 } { ptr @str.1101, i64 4 } + ret { ptr, i64 } { ptr @str.1105, i64 4 } if.merge.503: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8984,7 +8996,7 @@ entry: br i1 %lnot, label %if.then.504, label %if.merge.505 if.then.504: ; preds = %entry - ret { ptr, i64 } { ptr @str.1102, i64 4 } + ret { ptr, i64 } { ptr @str.1106, i64 4 } if.merge.505: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -9008,7 +9020,7 @@ entry: br i1 %lnot, label %if.then.506, label %if.merge.507 if.then.506: ; preds = %entry - ret { ptr, i64 } { ptr @str.1103, i64 4 } + ret { ptr, i64 } { ptr @str.1107, i64 4 } if.merge.507: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -9032,7 +9044,7 @@ entry: br i1 %lnot, label %if.then.508, label %if.merge.509 if.then.508: ; preds = %entry - ret { ptr, i64 } { ptr @str.1104, i64 4 } + ret { ptr, i64 } { ptr @str.1108, 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 56cc24c..76714b2 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [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"*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 [7 x i8] c"[3]Any\00" +@tn.str.250 = private constant [8 x i8] c"*[3]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 [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 [9 x i8] c"**[3]Any\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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 12 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { 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 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 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 8 }, { 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.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"x\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 +@str.330 = private unnamed_addr constant [2 x i8] c"v\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 [1 x i8] zeroinitializer, align 1 +@str.332 = private unnamed_addr constant [2 x i8] c"x\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"y\00", align 1 +@str.335 = private unnamed_addr constant [2 x i8] c"?\00", 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 [1 x i8] zeroinitializer, align 1 +@str.337 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.338 = private unnamed_addr constant [13 x i8] c"default: {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.340 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.341 = private unnamed_addr constant [14 x i8] c"explicit: {}\0A\00", 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 +@str.343 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.344 = private unnamed_addr constant [8 x i8] c"{}{}{}\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 [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 }] +@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 [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.367 = private constant [5 x i8] c"data\00" +@field_names.368 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.366, i64 9 }, { ptr, i64 } { ptr @fld.str.367, i64 4 }] +@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 [8 x i8] c"Context\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 [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 +@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 [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 [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 [5 x i8] c"null\00", align 1 +@str.645 = private unnamed_addr constant [6 x i8] c"*void\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 [12 x i8] c"*CAllocator\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 [5 x i8] c"*GPA\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 [12 x i8] c"*ArenaChunk\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 [7 x i8] c"*Arena\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 [6 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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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 [6 x i8] c"*File\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 [4 x i8] c"*u8\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 [5 x i8] c"*s32\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"*SockAddr\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 [5 x i8] c"*u32\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 [9 x i8] c"[*]Value\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 [7 x i8] c"*Array\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 [10 x i8] c"[*]Member\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"*Object\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"*Sink\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"*Parser\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 [5 x i8] c"*s64\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 [8 x i8] c"*Parsed\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"*Diag\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"*Sha256\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 [13 x i8] c"**CAllocator\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 [7 x i8] c"**void\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 [8 x i8] c"*[3]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 [5 x i8] c"null\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"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -633,85 +633,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -854,7 +776,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -981,7 +903,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1315,7 +1237,7 @@ entry: br i1 %icmp, label %if.then.375, label %if.merge.376 if.then.375: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.376: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1465,7 +1387,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1492,12 +1414,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1522,26 +1444,26 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 98, label %match.arm.47 i64 102, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 96, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1577,7 +1499,7 @@ match.merge.37: ; preds = %dispatch.merge.478, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1622,12 +1544,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1678,7 +1600,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.264 [ - i64 35, label %dispatch.case.265 + i64 22, label %dispatch.case.265 i64 81, label %dispatch.case.266 i64 87, label %dispatch.case.267 i64 88, label %dispatch.case.268 @@ -1692,7 +1614,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.308 [ - i64 36, label %dispatch.case.309 + i64 23, label %dispatch.case.309 i64 60, label %dispatch.case.310 i64 77, label %dispatch.case.311 i64 85, label %dispatch.case.312 @@ -1705,13 +1627,13 @@ 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 28, label %dispatch.case.345 - i64 29, label %dispatch.case.346 - i64 31, label %dispatch.case.347 - i64 33, label %dispatch.case.348 + i64 25, label %dispatch.case.342 + i64 27, label %dispatch.case.343 + i64 29, label %dispatch.case.344 + i64 31, label %dispatch.case.345 + i64 32, label %dispatch.case.346 + i64 34, label %dispatch.case.347 + i64 36, label %dispatch.case.348 i64 40, label %dispatch.case.349 i64 44, label %dispatch.case.350 i64 47, label %dispatch.case.351 @@ -1805,7 +1727,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.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1827,56 +1749,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2014,7 +1936,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.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.246 dispatch.case.248: ; preds = %match.arm.44 @@ -2055,7 +1977,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.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.263 dispatch.case.265: ; preds = %match.arm.47 @@ -2120,7 +2042,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.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.307 dispatch.case.309: ; preds = %match.arm.48 @@ -2169,7 +2091,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.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.339 dispatch.case.341: ; preds = %match.arm.49 @@ -2395,7 +2317,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.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.478 dispatch.case.480: ; preds = %match.arm.50 @@ -2437,7 +2359,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 @@ -2533,7 +2455,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.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 @@ -2541,7 +2463,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.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 @@ -2551,13 +2473,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.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.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.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 @@ -2565,7 +2487,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.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 @@ -2579,7 +2501,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.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 @@ -2587,7 +2509,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.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 @@ -2598,7 +2520,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 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 @@ -2655,7 +2577,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.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 @@ -2663,7 +2585,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.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 @@ -2674,7 +2596,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 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 @@ -2694,7 +2616,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.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 @@ -2702,7 +2624,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.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 @@ -2713,7 +2635,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 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.36 @@ -2723,67 +2645,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2959,166 +2965,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3316,64 +3322,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3403,97 +3409,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3532,7 +3538,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @scale(ptr %0, i32 %1, i32 %2) #0 { @@ -3571,9 +3577,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.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 }) + %callN = call i32 @label(ptr @__sx_default_context, i32 1, { ptr, i64 } { ptr @str.330, i64 1 }, { ptr, i64 } { ptr @str.331, i64 1 }) + %callN = call i32 @label(ptr @__sx_default_context, i32 2, { ptr, i64 } { ptr @str.332, i64 1 }, { ptr, i64 } { ptr @str.333, i64 1 }) + %callN = call i32 @label(ptr @__sx_default_context, i32 3, { ptr, i64 } { ptr @str.334, i64 1 }, { ptr, i64 } { ptr @str.335, i64 1 }) ret i32 0 } @@ -3595,7 +3601,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.334, i64 12 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.336, 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 @@ -3611,7 +3617,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.335, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.337, 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) @@ -3639,7 +3645,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.336, i64 12 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.338, i64 12 }) ret { ptr, i64 } %call } @@ -3647,7 +3653,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.337, i64 13 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.339, 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 @@ -3663,7 +3669,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.338, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.340, 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) @@ -3691,7 +3697,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.339, i64 13 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.341, i64 13 }) ret { ptr, i64 } %call } @@ -3699,7 +3705,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.340, i64 7 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.342, 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 @@ -3733,7 +3739,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.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 %allocaN, align 8 %ba.tmp19 = alloca { ptr, i64 }, align 8 @@ -3774,7 +3780,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.342, i64 7 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.344, i64 7 }) ret { ptr, i64 } %call } @@ -3785,7 +3791,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 @@ -3804,12 +3810,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.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.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.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.125 @@ -3821,7 +3827,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.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 @@ -3878,7 +3884,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.351, i64 9 }, { ptr, i64 } { ptr @str.352, i64 1 }) + %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 @@ -3897,24 +3903,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.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.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.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.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 [3 x { ptr, i64 }], ptr @field_names.358, 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.359, 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 @@ -3958,20 +3964,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.360, i64 10 }, { ptr, i64 } { ptr @str.361, i64 1 }) + %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.362, i64 7 }, { 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.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, 2 br i1 %icmp, label %while.body.132, label %while.exit.133 while.body.132: ; preds = %while.hdr.131 @@ -3981,24 +3988,102 @@ 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.362, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, 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 }) + %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.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.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.365, 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 }, 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.131 + +fv.default: ; preds = %if.merge.135 + br label %fv.merge + +fv.case: ; preds = %if.merge.135 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.135 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.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.372, 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.373, 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.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 @@ -4009,7 +4094,7 @@ if.merge.135: ; preds = %if.then.134, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 + br label %while.hdr.136 } ; Function Attrs: nounwind @@ -4017,43 +4102,43 @@ 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 }) + %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.136 + br label %while.hdr.141 -while.hdr.136: ; preds = %fv.merge, %entry +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.137, label %while.exit.138 + br i1 %icmp, label %while.body.142, label %while.exit.143 -while.body.137: ; preds = %while.hdr.136 +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.139, label %if.merge.140 + br i1 %icmpN, label %if.then.144, label %if.merge.145 -while.exit.138: ; preds = %while.hdr.136 +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.368, 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.139: ; preds = %while.body.137 +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.369, 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.140 + br label %if.merge.145 -if.merge.140: ; preds = %if.then.139, %while.body.137 +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.371, i64 0, i64 %loadN + %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.372, 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 { i64 }, ptr %alloca, align 8 @@ -4070,12 +4155,12 @@ 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 + br label %while.hdr.141 -fv.default: ; preds = %if.merge.140 +fv.default: ; preds = %if.merge.145 br label %fv.merge -fv.case: ; preds = %if.merge.140 +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 @@ -4086,43 +4171,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %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.141 + br label %while.hdr.146 -while.hdr.141: ; preds = %fv.merge, %entry +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.142, label %while.exit.143 + br i1 %icmp, label %while.body.147, label %while.exit.148 -while.body.142: ; preds = %while.hdr.141 +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.144, label %if.merge.145 + br i1 %icmpN, label %if.then.149, label %if.merge.150 -while.exit.143: ; preds = %while.hdr.141 +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.385, i64 1 }) ret { ptr, i64 } %callN -if.then.144: ; preds = %while.body.142 +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.386, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 + br label %if.merge.150 -if.merge.145: ; preds = %if.then.144, %while.body.142 +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.379, i64 0, i64 %loadN + %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.380, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -4140,18 +4225,18 @@ 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.141 + br label %while.hdr.146 -fv.default: ; preds = %if.merge.145 +fv.default: ; preds = %if.merge.150 br label %fv.merge -fv.case: ; preds = %if.merge.145 +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 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.145 +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 @@ -4163,91 +4248,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 }) - %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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.146 - -fv.default: ; preds = %if.merge.150 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.150 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.390, i64 8 }, { ptr, i64 } { ptr @str.391, 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 @@ -4266,27 +4267,27 @@ 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.392, 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.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.393, 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.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.397, 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.398, 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, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4308,29 +4309,30 @@ fv.default: ; preds = %if.merge.155 br label %fv.merge fv.case: ; preds = %if.merge.155 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.155 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.155 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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 }) + %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.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 @@ -4339,7 +4341,7 @@ entry: while.hdr.156: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.157, label %while.exit.158 while.body.157: ; preds = %while.hdr.156 @@ -4349,19 +4351,19 @@ 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.401, 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.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.402, 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.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.407, 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 @@ -4369,17 +4371,16 @@ if.merge.160: ; preds = %if.then.159, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4392,35 +4393,29 @@ fv.default: ; preds = %if.merge.160 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.160 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.160 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %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 @@ -4429,7 +4424,7 @@ entry: while.hdr.161: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.162, label %while.exit.163 while.body.162: ; preds = %while.hdr.161 @@ -4451,23 +4446,25 @@ if.then.164: ; preds = %while.body.162 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.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 }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4480,16 +4477,25 @@ fv.default: ; preds = %if.merge.165 br label %fv.merge fv.case: ; preds = %if.merge.165 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.165 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.165 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4498,7 +4504,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 @@ -4517,24 +4523,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.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.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.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.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.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 @@ -4571,7 +4577,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 @@ -4590,24 +4596,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.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.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.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.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.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 @@ -4673,7 +4679,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 @@ -4692,24 +4698,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.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.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.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.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.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 @@ -4751,7 +4757,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 @@ -4770,24 +4776,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.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.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.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.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.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 @@ -4848,7 +4854,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 @@ -4867,24 +4873,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.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.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.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.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.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 @@ -4930,7 +4936,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 @@ -4949,24 +4955,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.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.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.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.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.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 @@ -5014,7 +5020,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 @@ -5033,24 +5039,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.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.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.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.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.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 @@ -5094,7 +5100,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 @@ -5113,24 +5119,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.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.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.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.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.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 @@ -5180,7 +5186,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 @@ -5199,24 +5205,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.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.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.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.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.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 @@ -5265,7 +5271,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 @@ -5284,24 +5290,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.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.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.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.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.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 @@ -5321,7 +5327,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 @@ -5340,24 +5346,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.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.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.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.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.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 @@ -5409,7 +5415,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 @@ -5428,24 +5434,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.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.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.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.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.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 @@ -5497,7 +5503,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 @@ -5516,24 +5522,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.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.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.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.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.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 @@ -5576,7 +5582,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 @@ -5595,24 +5601,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.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.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.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.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.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 @@ -5658,7 +5664,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 @@ -5677,24 +5683,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.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.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.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.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.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 @@ -5751,7 +5757,7 @@ fv.case28: ; preds = %if.merge.240 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.240 @@ -5776,7 +5782,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 @@ -5795,24 +5801,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.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.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.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.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.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 @@ -5871,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 [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 @@ -5892,8 +5898,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.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.254 @@ -5912,9 +5918,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 @@ -5933,8 +5939,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.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.256 @@ -5964,9 +5970,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 @@ -5983,8 +5989,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.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.258 @@ -6062,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 [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 @@ -6083,8 +6089,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.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.260 @@ -6103,9 +6109,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 @@ -6124,8 +6130,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.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.262 @@ -6142,7 +6148,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.272 @@ -6159,12 +6165,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.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.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 @@ -6193,7 +6199,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.277 @@ -6210,12 +6216,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.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.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.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.281 @@ -6245,7 +6251,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.282 @@ -6262,12 +6268,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.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.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.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.286 @@ -6295,7 +6301,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.287 @@ -6312,12 +6318,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.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.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.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.291 @@ -6346,7 +6352,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.292 @@ -6363,12 +6369,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.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.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.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.296 @@ -6397,7 +6403,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.297 @@ -6414,12 +6420,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.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.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.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.301 @@ -6450,7 +6456,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.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.302 @@ -6467,12 +6473,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.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.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.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.306 @@ -6502,7 +6508,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.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.314 @@ -6521,12 +6527,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.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.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.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.318 @@ -6555,7 +6561,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.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.319 @@ -6574,12 +6580,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.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.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.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.323 @@ -6608,7 +6614,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.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.324 @@ -6627,12 +6633,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.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.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.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.328 @@ -6662,7 +6668,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.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.329 @@ -6681,12 +6687,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.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.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.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.333 @@ -6716,7 +6722,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.639, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.641, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.334 @@ -6735,12 +6741,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.640, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.642, 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.641, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.643, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.338 @@ -6782,12 +6788,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.644, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 5 }, { 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 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.642, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] + %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] ret { ptr, i64 } %bp } @@ -6810,12 +6816,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.647, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 11 }, { 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 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.645, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] + %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] ret { ptr, i64 } %bp } @@ -6838,12 +6844,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.650, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 4 }, { 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 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.648, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] + %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] ret { ptr, i64 } %bp } @@ -6866,12 +6872,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.653, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 11 }, { 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 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.651, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6894,12 +6900,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.656, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 6 }, { 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 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.654, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6921,12 +6927,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.659, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 5 }, { 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 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.657, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6949,12 +6955,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.662, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 9 }, { 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 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.660, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6977,12 +6983,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.665, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 18 }, { 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 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.663, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -7005,12 +7011,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.668, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 5 }, { 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 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.666, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -7033,12 +7039,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.671, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 3 }, { 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 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.669, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -7061,12 +7067,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.674, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 4 }, { 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 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.672, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -7089,12 +7095,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.677, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 9 }, { 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 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.675, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -7117,12 +7123,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.680, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 4 }, { 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 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.678, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -7144,12 +7150,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.683, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 8 }, { 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 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.681, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7172,12 +7178,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.686, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 6 }, { 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 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.684, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7199,12 +7205,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.689, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 9 }, { 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 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.687, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7227,12 +7233,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.692, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 7 }, { 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 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.690, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7255,12 +7261,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.695, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 5 }, { 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 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.693, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7283,12 +7289,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.698, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 7 }, { 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 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.696, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7311,12 +7317,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.701, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 4 }, { 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 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.699, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7339,12 +7345,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.704, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 7 }, { 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 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.702, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7367,12 +7373,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.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.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7395,12 +7401,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.710, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 7 }, { 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 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.708, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7423,12 +7429,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.713, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 12 }, { 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 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.711, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7451,12 +7457,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.716, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 6 }, { 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 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.714, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7479,12 +7485,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.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.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7507,12 +7513,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.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.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7535,12 +7541,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.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.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7563,12 +7569,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.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.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7591,12 +7597,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.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.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7619,12 +7625,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.734, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.733, i64 7 }, { 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 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.732, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.734, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7640,7 +7646,7 @@ entry: br i1 %lnot, label %if.then.484, label %if.merge.485 if.then.484: ; preds = %entry - ret { ptr, i64 } { ptr @str.735, i64 4 } + ret { ptr, i64 } { ptr @str.737, i64 4 } if.merge.485: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7664,7 +7670,7 @@ entry: br i1 %lnot, label %if.then.486, label %if.merge.487 if.then.486: ; preds = %entry - ret { ptr, i64 } { ptr @str.736, i64 4 } + ret { ptr, i64 } { ptr @str.738, i64 4 } if.merge.487: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7688,7 +7694,7 @@ entry: br i1 %lnot, label %if.then.488, label %if.merge.489 if.then.488: ; preds = %entry - ret { ptr, i64 } { ptr @str.737, i64 4 } + ret { ptr, i64 } { ptr @str.739, i64 4 } if.merge.489: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7712,7 +7718,7 @@ entry: br i1 %lnot, label %if.then.490, label %if.merge.491 if.then.490: ; preds = %entry - ret { ptr, i64 } { ptr @str.738, i64 4 } + ret { ptr, i64 } { ptr @str.740, 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 311f65f..a15d43a 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [13 x i8] c"**CAllocator\00" +@tn.str.241 = private constant [7 x i8] c"**void\00" +@tn.str.242 = private constant [5 x i8] c"*f32\00" +@tn.str.243 = private constant [8 x i8] c"*string\00" +@tn.str.244 = private constant [6 x i8] c"[]Any\00" +@tn.str.245 = private constant [5 x i8] c"*Any\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 [7 x i8] c"*[]Any\00" +@tn.str.249 = private constant [6 x i8] c"*bool\00" +@tn.str.250 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.251 = private constant [5 x i8] c"*f64\00" +@tn.str.252 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.253 = private constant [11 x i8] c"*Allocator\00" +@tn.str.254 = private constant [9 x i8] c"*Context\00" +@tn.str.255 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.256 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.257 = private constant [8 x i8] c"*Member\00" +@tn.str.258 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.259 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.260 = private constant [9 x i8] c"*Command\00" +@tn.str.261 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.262 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.263 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.264 = private constant [7 x i8] c"*Value\00" +@tn.str.265 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.266 = private constant [14 x i8] c"*Architecture\00" +@tn.str.267 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.268 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.269 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.270 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.271 = private constant [10 x i8] c"*[]string\00" +@tn.str.272 = private constant [6 x i8] c"*[]u8\00" +@tn.str.273 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.274 = private constant [11 x i8] c"*[]Command\00" +@tn.str.275 = private constant [6 x i8] c"**GPA\00" +@tn.str.276 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.277 = private constant [8 x i8] c"**Arena\00" +@tn.str.278 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.279 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.280 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.281 = private constant [7 x i8] c"**File\00" +@tn.str.282 = private constant [5 x i8] c"**u8\00" +@tn.str.283 = private constant [6 x i8] c"**s32\00" +@tn.str.284 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.285 = private constant [6 x i8] c"**u32\00" +@tn.str.286 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.287 = private constant [8 x i8] c"**Array\00" +@tn.str.288 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.289 = private constant [9 x i8] c"**Object\00" +@tn.str.290 = private constant [7 x i8] c"**Sink\00" +@tn.str.291 = private constant [9 x i8] c"**Parser\00" +@tn.str.292 = private constant [6 x i8] c"**s64\00" +@tn.str.293 = private constant [9 x i8] c"**Parsed\00" +@tn.str.294 = private constant [7 x i8] c"**Diag\00" +@tn.str.295 = private constant [9 x i8] c"**Sha256\00" +@tn.str.296 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.297 = private constant [8 x i8] c"***void\00" +@tn.str.298 = private constant [6 x i8] c"**f32\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"*?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 [161 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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 12 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { ptr, i64 } { ptr @tn.str.242, i64 4 }, { 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 6 }, { ptr, i64 } { ptr @tn.str.247, i64 7 }, { ptr, i64 } { ptr @tn.str.248, i64 6 }, { ptr, i64 } { ptr @tn.str.249, i64 5 }, { ptr, i64 } { ptr @tn.str.250, i64 7 }, { ptr, i64 } { ptr @tn.str.251, i64 4 }, { ptr, i64 } { ptr @tn.str.252, i64 16 }, { ptr, i64 } { ptr @tn.str.253, i64 10 }, { ptr, i64 } { ptr @tn.str.254, i64 8 }, { ptr, i64 } { ptr @tn.str.255, i64 11 }, { ptr, i64 } { ptr @tn.str.256, i64 14 }, { ptr, i64 } { ptr @tn.str.257, i64 7 }, { ptr, i64 } { ptr @tn.str.258, i64 13 }, { ptr, i64 } { ptr @tn.str.259, i64 9 }, { ptr, i64 } { ptr @tn.str.260, i64 8 }, { ptr, i64 } { ptr @tn.str.261, i64 10 }, { ptr, i64 } { ptr @tn.str.262, i64 9 }, { ptr, i64 } { ptr @tn.str.263, i64 9 }, { ptr, i64 } { ptr @tn.str.264, i64 6 }, { ptr, i64 } { ptr @tn.str.265, i64 16 }, { ptr, i64 } { ptr @tn.str.266, i64 13 }, { ptr, i64 } { ptr @tn.str.267, i64 14 }, { ptr, i64 } { ptr @tn.str.268, i64 7 }, { ptr, i64 } { ptr @tn.str.269, i64 7 }, { ptr, i64 } { ptr @tn.str.270, i64 8 }, { ptr, i64 } { ptr @tn.str.271, i64 9 }, { ptr, i64 } { ptr @tn.str.272, i64 5 }, { ptr, i64 } { ptr @tn.str.273, i64 11 }, { ptr, i64 } { ptr @tn.str.274, i64 10 }, { ptr, i64 } { ptr @tn.str.275, i64 5 }, { ptr, i64 } { ptr @tn.str.276, i64 12 }, { ptr, i64 } { ptr @tn.str.277, i64 7 }, { ptr, i64 } { ptr @tn.str.278, i64 6 }, { ptr, i64 } { ptr @tn.str.279, i64 10 }, { ptr, i64 } { ptr @tn.str.280, i64 19 }, { ptr, i64 } { ptr @tn.str.281, i64 6 }, { ptr, i64 } { ptr @tn.str.282, i64 4 }, { ptr, i64 } { ptr @tn.str.283, i64 5 }, { ptr, i64 } { ptr @tn.str.284, i64 10 }, { ptr, i64 } { ptr @tn.str.285, i64 5 }, { ptr, i64 } { ptr @tn.str.286, i64 9 }, { ptr, i64 } { ptr @tn.str.287, i64 7 }, { ptr, i64 } { ptr @tn.str.288, i64 10 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.293, i64 8 }, { ptr, i64 } { ptr @tn.str.294, i64 6 }, { ptr, i64 } { ptr @tn.str.295, i64 8 }, { ptr, i64 } { ptr @tn.str.296, i64 13 }, { ptr, i64 } { ptr @tn.str.297, i64 7 }, { ptr, i64 } { ptr @tn.str.298, i64 5 }, { 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 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 @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 [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 [4 x i8] c"ok\0A\00", 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 +@str.331 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.332 = private unnamed_addr constant [13 x i8] c"result = {}\0A\00", align 1 +@str.333 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.334 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.335 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.336 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@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 }] +@fld.str.337 = private constant [5 x i8] c"line\00" +@fld.str.338 = private constant [4 x i8] c"col\00" +@fld.str.339 = 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.337, i64 4 }, { ptr, i64 } { ptr @fld.str.338, 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 [10 x i8] c"Allocator\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 [4 x i8] c"ctx\00" +@fld.str.346 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.347 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.348 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.345, i64 3 }, { ptr, i64 } { ptr @fld.str.346, i64 11 }, { ptr, i64 } { ptr @fld.str.347, i64 13 }] +@str.349 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.350 = private unnamed_addr constant [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.355 = private constant [5 x i8] c"data\00" +@field_names.356 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.354, i64 9 }, { ptr, i64 } { ptr @fld.str.355, 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 [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 [8 x i8] c"Context\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 [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 +@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 [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.412 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.411, i64 2 }] +@str.413 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.414 = private unnamed_addr constant [11 x i8] c"TraceFrame\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 [5 x i8] c"file\00" +@fld.str.419 = private constant [5 x i8] c"line\00" +@fld.str.420 = private constant [4 x i8] c"col\00" +@fld.str.421 = private constant [5 x i8] c"func\00" +@fld.str.422 = private constant [10 x i8] c"line_text\00" +@field_names.423 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.418, i64 4 }, { ptr, i64 } { ptr @fld.str.419, i64 4 }, { ptr, i64 } { ptr @fld.str.420, i64 3 }, { ptr, i64 } { ptr @fld.str.421, i64 4 }, { ptr, i64 } { ptr @fld.str.422, i64 9 }] +@str.424 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.425 = private unnamed_addr constant [14 x i8] c"ProcessResult\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 [10 x i8] c"exit_code\00" +@fld.str.430 = private constant [7 x i8] c"stdout\00" +@field_names.431 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.429, i64 9 }, { ptr, i64 } { ptr @fld.str.430, i64 6 }] +@str.432 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.433 = private unnamed_addr constant [9 x i8] c"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.438 = private constant [11 x i8] c"sin_family\00" +@fld.str.439 = private constant [9 x i8] c"sin_port\00" +@fld.str.440 = private constant [9 x i8] c"sin_addr\00" +@fld.str.441 = private constant [9 x i8] c"sin_zero\00" +@field_names.442 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.437, i64 7 }, { ptr, i64 } { ptr @fld.str.438, i64 10 }, { ptr, i64 } { ptr @fld.str.439, i64 8 }, { ptr, i64 } { ptr @fld.str.440, i64 8 }, { ptr, i64 } { ptr @fld.str.441, i64 8 }] +@str.443 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.444 = private unnamed_addr constant [6 x i8] c"Array\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 [6 x i8] c"items\00" +@fld.str.449 = private constant [4 x i8] c"len\00" +@fld.str.450 = private constant [4 x i8] c"cap\00" +@field_names.451 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.448, i64 5 }, { ptr, i64 } { ptr @fld.str.449, i64 3 }, { ptr, i64 } { ptr @fld.str.450, i64 3 }] +@str.452 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.453 = private unnamed_addr constant [7 x i8] c"Object\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 [6 x i8] c"items\00" +@fld.str.458 = private constant [4 x i8] c"len\00" +@fld.str.459 = private constant [4 x i8] c"cap\00" +@field_names.460 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.457, i64 5 }, { ptr, i64 } { ptr @fld.str.458, i64 3 }, { ptr, i64 } { ptr @fld.str.459, i64 3 }] +@str.461 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.462 = private unnamed_addr constant [7 x i8] c"Member\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 [4 x i8] c"key\00" +@fld.str.467 = private constant [4 x i8] c"val\00" +@field_names.468 = private constant [2 x { ptr, i64 }] [{ 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 [5 x i8] c"Sink\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"dst\00" +@fld.str.475 = private constant [4 x i8] c"pos\00" +@fld.str.476 = private constant [5 x i8] c"file\00" +@field_names.477 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.474, i64 3 }, { ptr, i64 } { ptr @fld.str.475, i64 3 }, { ptr, i64 } { ptr @fld.str.476, i64 4 }] +@str.478 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.479 = private unnamed_addr constant [7 x i8] c"Parser\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"src\00" +@fld.str.484 = private constant [4 x i8] c"pos\00" +@fld.str.485 = private constant [6 x i8] c"alloc\00" +@field_names.486 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.483, i64 3 }, { ptr, i64 } { ptr @fld.str.484, i64 3 }, { ptr, i64 } { ptr @fld.str.485, i64 5 }] +@str.487 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.488 = private unnamed_addr constant [13 x i8] c"BuildOptions\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 +@field_names.492 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.493 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.494 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.495 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.496 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.497 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.498 = private constant [5 x i8] c"name\00" +@fld.str.499 = private constant [12 x i8] c"takes_value\00" +@fld.str.500 = private constant [9 x i8] c"required\00" +@field_names.501 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.498, i64 4 }, { ptr, i64 } { ptr @fld.str.499, i64 11 }, { 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 [8 x i8] c"Command\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"group\00" +@fld.str.508 = private constant [8 x i8] c"command\00" +@fld.str.509 = private constant [6 x i8] c"flags\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 7 }, { ptr, i64 } { ptr @fld.str.509, i64 5 }] +@str.511 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.512 = private unnamed_addr constant [10 x i8] c"FlagValue\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 [4 x i8] c"set\00" +@fld.str.517 = private constant [6 x i8] c"value\00" +@field_names.518 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.516, i64 3 }, { 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 [5 x i8] c"Diag\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"index\00" +@fld.str.525 = private constant [6 x i8] c"token\00" +@field_names.526 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.524, i64 5 }, { 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 [7 x i8] c"Parsed\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"group\00" +@fld.str.533 = private constant [8 x i8] c"command\00" +@fld.str.534 = private constant [10 x i8] c"cmd_index\00" +@fld.str.535 = private constant [5 x i8] c"json\00" +@fld.str.536 = private constant [5 x i8] c"rest\00" +@fld.str.537 = private constant [5 x i8] c"spec\00" +@fld.str.538 = private constant [7 x i8] c"values\00" +@field_names.539 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.532, i64 5 }, { ptr, i64 } { ptr @fld.str.533, i64 7 }, { ptr, i64 } { ptr @fld.str.534, i64 9 }, { ptr, i64 } { ptr @fld.str.535, i64 4 }, { ptr, i64 } { ptr @fld.str.536, i64 4 }, { ptr, i64 } { ptr @fld.str.537, i64 4 }, { ptr, i64 } { ptr @fld.str.538, i64 6 }] +@str.540 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.541 = private unnamed_addr constant [7 x i8] c"Sha256\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 [2 x i8] c"h\00" +@fld.str.546 = private constant [4 x i8] c"buf\00" +@fld.str.547 = private constant [8 x i8] c"buf_len\00" +@fld.str.548 = private constant [10 x i8] c"total_len\00" +@field_names.549 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.545, i64 1 }, { ptr, i64 } { ptr @fld.str.546, i64 3 }, { ptr, i64 } { ptr @fld.str.547, i64 7 }, { ptr, i64 } { ptr @fld.str.548, i64 9 }] +@str.550 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.551 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.552 = private constant [5 x i8] c"read\00" +@fld.str.553 = private constant [6 x i8] c"write\00" +@fld.str.554 = private constant [7 x i8] c"append\00" +@fld.str.555 = private constant [11 x i8] c"read_write\00" +@field_names.556 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.552, i64 4 }, { ptr, i64 } { ptr @fld.str.553, i64 5 }, { ptr, i64 } { ptr @fld.str.554, i64 6 }, { ptr, i64 } { ptr @fld.str.555, i64 10 }] +@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 +@str.559 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.560 = private constant [4 x i8] c"set\00" +@fld.str.561 = private constant [8 x i8] c"current\00" +@fld.str.562 = private constant [4 x i8] c"end\00" +@field_names.563 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.560, i64 3 }, { ptr, i64 } { ptr @fld.str.561, i64 7 }, { ptr, i64 } { ptr @fld.str.562, i64 3 }] +@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 [6 x i8] c"null_\00" +@fld.str.568 = private constant [6 x i8] c"bool_\00" +@fld.str.569 = private constant [5 x i8] c"int_\00" +@fld.str.570 = private constant [4 x i8] c"str\00" +@fld.str.571 = private constant [6 x i8] c"array\00" +@fld.str.572 = private constant [7 x i8] c"object\00" +@field_names.573 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.567, i64 5 }, { ptr, i64 } { ptr @fld.str.568, i64 5 }, { ptr, i64 } { ptr @fld.str.569, i64 4 }, { ptr, i64 } { ptr @fld.str.570, i64 3 }, { ptr, i64 } { ptr @fld.str.571, i64 5 }, { ptr, i64 } { ptr @fld.str.572, i64 6 }] +@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"macos\00" +@fld.str.578 = private constant [6 x i8] c"linux\00" +@fld.str.579 = private constant [8 x i8] c"windows\00" +@fld.str.580 = private constant [5 x i8] c"wasm\00" +@fld.str.581 = private constant [4 x i8] c"ios\00" +@fld.str.582 = private constant [8 x i8] c"android\00" +@fld.str.583 = private constant [8 x i8] c"unknown\00" +@field_names.584 = private constant [7 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 7 }, { ptr, i64 } { ptr @fld.str.580, i64 4 }, { ptr, i64 } { ptr @fld.str.581, i64 3 }, { ptr, i64 } { ptr @fld.str.582, i64 7 }, { ptr, i64 } { ptr @fld.str.583, i64 7 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.588 = private constant [8 x i8] c"aarch64\00" +@fld.str.589 = private constant [7 x i8] c"x86_64\00" +@fld.str.590 = private constant [7 x i8] c"wasm32\00" +@fld.str.591 = private constant [7 x i8] c"wasm64\00" +@fld.str.592 = private constant [8 x i8] c"unknown\00" +@field_names.593 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.588, i64 7 }, { ptr, i64 } { ptr @fld.str.589, i64 6 }, { ptr, i64 } { ptr @fld.str.590, i64 6 }, { ptr, i64 } { ptr @fld.str.591, i64 6 }, { ptr, i64 } { ptr @fld.str.592, i64 7 }] +@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 [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 [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 [5 x i8] c"null\00", align 1 +@str.630 = private unnamed_addr constant [6 x i8] c"*void\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 [12 x i8] c"*CAllocator\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 [5 x i8] c"*GPA\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 [12 x i8] c"*ArenaChunk\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 [7 x i8] c"*Arena\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 [6 x i8] c"[*]u8\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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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 [6 x i8] c"*File\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 [4 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 [5 x i8] c"*s32\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 [10 x i8] c"*SockAddr\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 [5 x i8] c"*u32\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 [9 x i8] c"[*]Value\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 [7 x i8] c"*Array\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"[*]Member\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 [8 x i8] c"*Object\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 [6 x i8] c"*Sink\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 [8 x i8] c"*Parser\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"*s64\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"*Parsed\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"*Diag\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"*Sha256\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 [13 x i8] c"**CAllocator\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 [7 x i8] c"**void\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"*f32\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"*string\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"*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 [8 x i8] c"*[1]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 [7 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 [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"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 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -618,85 +618,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -839,7 +761,7 @@ entry: br i1 %icmp, label %if.then.61, label %if.merge.62 if.then.61: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.62: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -966,7 +888,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.128, i64 4 }, %if.then.83 ], [ { ptr @str.129, i64 5 }, %if.else.84 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.83 ], [ { ptr @str.131, i64 5 }, %if.else.84 ] ret { ptr, i64 } %bp } @@ -1300,7 +1222,7 @@ entry: br i1 %icmp, label %if.then.374, label %if.merge.375 if.then.374: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.375: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1450,7 +1372,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1477,12 +1399,12 @@ entry: i64 19, label %match.arm.48 i64 20, 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 24, label %match.arm.48 + i64 26, label %match.arm.48 + i64 28, label %match.arm.48 i64 30, label %match.arm.48 - i64 32, label %match.arm.48 - i64 34, label %match.arm.48 + i64 33, label %match.arm.48 + i64 35, label %match.arm.48 i64 39, label %match.arm.48 i64 43, label %match.arm.48 i64 45, label %match.arm.48 @@ -1507,25 +1429,25 @@ entry: i64 51, label %match.arm.50 i64 64, label %match.arm.50 i64 75, label %match.arm.50 - i64 35, label %match.arm.52 + i64 22, label %match.arm.52 i64 81, label %match.arm.52 i64 87, label %match.arm.52 i64 88, label %match.arm.52 i64 92, label %match.arm.52 i64 99, label %match.arm.52 - i64 36, label %match.arm.53 + i64 23, label %match.arm.53 i64 60, label %match.arm.53 i64 77, label %match.arm.53 i64 85, label %match.arm.53 i64 97, label %match.arm.53 i64 18, 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 25, label %match.arm.54 + i64 27, label %match.arm.54 i64 29, label %match.arm.54 i64 31, label %match.arm.54 - i64 33, label %match.arm.54 + i64 32, label %match.arm.54 + i64 34, label %match.arm.54 + i64 36, label %match.arm.54 i64 40, label %match.arm.54 i64 44, label %match.arm.54 i64 47, label %match.arm.54 @@ -1561,7 +1483,7 @@ match.merge.42: ; preds = %dispatch.merge.477, ret { ptr, i64 } %loadN match.arm.43: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1606,12 +1528,12 @@ match.arm.48: ; preds = %entry, %entry, %ent i64 19, label %dispatch.case.101 i64 20, label %dispatch.case.102 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 24, label %dispatch.case.104 + i64 26, label %dispatch.case.105 + i64 28, label %dispatch.case.106 i64 30, label %dispatch.case.107 - i64 32, label %dispatch.case.108 - i64 34, label %dispatch.case.109 + i64 33, label %dispatch.case.108 + i64 35, label %dispatch.case.109 i64 39, label %dispatch.case.110 i64 43, label %dispatch.case.111 i64 45, label %dispatch.case.112 @@ -1662,7 +1584,7 @@ match.arm.52: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.269 [ - i64 35, label %dispatch.case.270 + i64 22, label %dispatch.case.270 i64 81, label %dispatch.case.271 i64 87, label %dispatch.case.272 i64 88, label %dispatch.case.273 @@ -1675,7 +1597,7 @@ match.arm.53: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.307 [ - i64 36, label %dispatch.case.308 + i64 23, label %dispatch.case.308 i64 60, label %dispatch.case.309 i64 77, label %dispatch.case.310 i64 85, label %dispatch.case.311 @@ -1688,13 +1610,13 @@ 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 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 - i64 33, label %dispatch.case.347 + i64 25, label %dispatch.case.341 + i64 27, label %dispatch.case.342 + i64 29, label %dispatch.case.343 + i64 31, label %dispatch.case.344 + i64 32, label %dispatch.case.345 + i64 34, label %dispatch.case.346 + i64 36, label %dispatch.case.347 i64 40, label %dispatch.case.348 i64 44, label %dispatch.case.349 i64 47, label %dispatch.case.350 @@ -1788,7 +1710,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.306, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.308, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.99 dispatch.case.101: ; preds = %match.arm.48 @@ -1810,56 +1732,56 @@ dispatch.case.102: ; preds = %match.arm.48 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 {}, ptr %ua.ptr69, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) + %ua.load70 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %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 { 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.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, 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.99 dispatch.case.106: ; preds = %match.arm.48 %ua.raw80 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr81 = inttoptr i64 %ua.raw80 to ptr - %ua.load82 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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.99 dispatch.case.107: ; preds = %match.arm.48 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.99 dispatch.case.108: ; preds = %match.arm.48 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.99 dispatch.case.109: ; preds = %match.arm.48 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.99 @@ -1997,7 +1919,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.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.251 dispatch.case.253: ; preds = %match.arm.49 @@ -2038,7 +1960,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.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.268 dispatch.case.270: ; preds = %match.arm.52 @@ -2095,7 +2017,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.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.306 dispatch.case.308: ; preds = %match.arm.53 @@ -2144,7 +2066,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.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.338 dispatch.case.340: ; preds = %match.arm.54 @@ -2370,7 +2292,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.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.477 dispatch.case.479: ; preds = %match.arm.55 @@ -2412,7 +2334,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.312, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2508,7 +2430,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.313, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.315, 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 @@ -2516,7 +2438,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.314, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.316, 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 @@ -2526,13 +2448,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.315, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.317, 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.316, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.318, 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 @@ -2540,7 +2462,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.317, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2554,7 +2476,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.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 @@ -2562,7 +2484,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.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 @@ -2573,7 +2495,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.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 @@ -2630,7 +2552,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.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 @@ -2638,7 +2560,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.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 @@ -2649,7 +2571,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.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 @@ -2669,7 +2591,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.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 @@ -2677,7 +2599,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.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 { ptr, i64 }, ptr %alloca, align 8 @@ -2688,7 +2610,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.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 br label %if.merge.41 @@ -2698,67 +2620,151 @@ if.merge.41: ; preds = %if.then.40, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2934,166 +2940,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3291,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.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3378,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.95(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.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3507,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -3520,7 +3526,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.327, i64 3) + %0 = call i64 @write(i32 1, ptr @str.329, i64 3) br label %if.merge.1 if.merge.1: ; preds = %if.then.0, %entry @@ -3561,7 +3567,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.328, i64 12 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.330, 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 @@ -3578,7 +3584,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.329, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.331, 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) @@ -3607,7 +3613,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.330, i64 12 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.332, i64 12 }) ret { ptr, i64 } %call } @@ -3618,7 +3624,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.331, i64 15 }, { ptr, i64 } { ptr @str.332, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.333, i64 15 }, { ptr, i64 } { ptr @str.334, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3637,12 +3643,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.333, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, 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.334, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.130 @@ -3654,7 +3660,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.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 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3711,7 +3717,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.339, i64 9 }, { ptr, i64 } { ptr @str.340, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.341, i64 9 }, { ptr, i64 } { ptr @str.342, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3730,24 +3736,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.341, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, 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.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 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 [3 x { ptr, i64 }], ptr @field_names.346, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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 { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -3791,20 +3797,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.348, i64 10 }, { ptr, i64 } { ptr @str.349, i64 1 }) + %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.350, i64 7 }, { 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 = %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, 2 br i1 %icmp, label %while.body.137, label %while.exit.138 while.body.137: ; preds = %while.hdr.136 @@ -3814,24 +3821,102 @@ 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.350, i64 1 }) + %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.351, 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 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.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.353, i64 2 }) + %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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.136 + +fv.default: ; preds = %if.merge.140 + br label %fv.merge + +fv.case: ; preds = %if.merge.140 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.140 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.358, i64 10 }, { 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 = %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.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 [0 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 %alloca, align 1 @@ -3842,7 +3927,7 @@ if.merge.140: ; preds = %if.then.139, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.136 + br label %while.hdr.141 } ; Function Attrs: nounwind @@ -3850,43 +3935,43 @@ 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 }) + %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.141 + br label %while.hdr.146 -while.hdr.141: ; preds = %fv.merge, %entry +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.142, label %while.exit.143 + br i1 %icmp, label %while.body.147, label %while.exit.148 -while.body.142: ; preds = %while.hdr.141 +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.144, label %if.merge.145 + br i1 %icmpN, label %if.then.149, label %if.merge.150 -while.exit.143: ; preds = %while.hdr.141 +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.356, i64 1 }) + %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 +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.357, 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 - br label %if.merge.145 + br label %if.merge.150 -if.merge.145: ; preds = %if.then.144, %while.body.142 +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.359, i64 0, i64 %loadN + %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.360, 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 %alloca, align 8 @@ -3903,12 +3988,12 @@ 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.141 + br label %while.hdr.146 -fv.default: ; preds = %if.merge.145 +fv.default: ; preds = %if.merge.150 br label %fv.merge -fv.case: ; preds = %if.merge.145 +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 @@ -3919,43 +4004,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %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.146 + br label %while.hdr.151 -while.hdr.146: ; preds = %fv.merge, %entry +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.147, label %while.exit.148 + br i1 %icmp, label %while.body.152, label %while.exit.153 -while.body.147: ; preds = %while.hdr.146 +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.149, label %if.merge.150 + br i1 %icmpN, label %if.then.154, label %if.merge.155 -while.exit.148: ; preds = %while.hdr.146 +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.363, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 1 }) ret { ptr, i64 } %callN -if.then.149: ; preds = %while.body.147 +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.364, i64 2 }) + %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.150 + br label %if.merge.155 -if.merge.150: ; preds = %if.then.149, %while.body.147 +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.367, i64 0, i64 %loadN + %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.368, 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 %alloca, align 8 @@ -3973,18 +4058,18 @@ 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.146 + br label %while.hdr.151 -fv.default: ; preds = %if.merge.150 +fv.default: ; preds = %if.merge.155 br label %fv.merge -fv.case: ; preds = %if.merge.150 +fv.case: ; preds = %if.merge.155 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.150 +fv.case17: ; preds = %if.merge.155 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -3996,91 +4081,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.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 - 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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.151 - -fv.default: ; preds = %if.merge.155 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.155 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 8 }, { ptr, i64 } { ptr @str.379, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.379, i64 5 }, { 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 @@ -4099,27 +4100,27 @@ 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.380, 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.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.381, 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.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.385, 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.386, 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 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4141,29 +4142,30 @@ fv.default: ; preds = %if.merge.160 br label %fv.merge fv.case: ; preds = %if.merge.160 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.160 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.387, i64 17 }, { ptr, i64 } { ptr @str.388, i64 1 }) + %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 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4172,7 +4174,7 @@ entry: while.hdr.161: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.162, label %while.exit.163 while.body.162: ; preds = %while.hdr.161 @@ -4182,19 +4184,19 @@ 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.389, 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.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.390, 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.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.395, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4202,17 +4204,16 @@ if.merge.165: ; preds = %if.then.164, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4225,35 +4226,29 @@ fv.default: ; preds = %if.merge.165 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.165 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.165 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.397, i64 7 }, { ptr, i64 } { ptr @str.398, i64 1 }) + 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 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4262,7 +4257,7 @@ entry: while.hdr.166: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.167, label %while.exit.168 while.body.167: ; preds = %while.hdr.166 @@ -4284,23 +4279,25 @@ if.then.169: ; preds = %while.body.167 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.403, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4313,16 +4310,25 @@ fv.default: ; preds = %if.merge.170 br label %fv.merge fv.case: ; preds = %if.merge.170 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.170 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.170 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.170 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4331,7 +4337,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.405, i64 4 }, { ptr, i64 } { ptr @str.406, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.407, i64 4 }, { 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 @@ -4350,24 +4356,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.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.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.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.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.410, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i32 }, ptr %alloca, align 4 @@ -4404,7 +4410,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.412, i64 10 }, { ptr, i64 } { ptr @str.413, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.414, i64 10 }, { 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 @@ -4423,24 +4429,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.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.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.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.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.421, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4506,7 +4512,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.423, i64 13 }, { ptr, i64 } { ptr @str.424, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.425, i64 13 }, { 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 @@ -4525,24 +4531,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.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.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.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.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.429, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, i64 } }, ptr %alloca, align 8 @@ -4584,7 +4590,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.431, i64 8 }, { ptr, i64 } { ptr @str.432, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.433, i64 8 }, { 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 @@ -4603,24 +4609,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.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.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.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.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.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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4681,7 +4687,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.442, i64 5 }, { ptr, i64 } { ptr @str.443, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.444, i64 5 }, { 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 @@ -4700,24 +4706,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.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.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.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.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.449, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { ptr, i64, i64 }, ptr %alloca, align 8 @@ -4763,7 +4769,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.451, i64 6 }, { ptr, i64 } { ptr @str.452, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.453, i64 6 }, { 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 @@ -4782,24 +4788,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.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.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.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.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.458, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { ptr, i64, i64 }, ptr %alloca, align 8 @@ -4847,7 +4853,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.460, i64 6 }, { ptr, i64 } { ptr @str.461, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.462, i64 6 }, { 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 @@ -4866,24 +4872,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.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.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.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.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.466, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.468, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -4927,7 +4933,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.468, i64 4 }, { ptr, i64 } { ptr @str.469, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.470, i64 4 }, { ptr, i64 } { ptr @str.471, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4946,24 +4952,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.470, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, 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.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 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.475, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.477, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5013,7 +5019,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.477, i64 6 }, { ptr, i64 } { ptr @str.478, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.479, i64 6 }, { ptr, i64 } { ptr @str.480, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5032,24 +5038,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.479, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, 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.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 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.484, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5098,7 +5104,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.486, i64 12 }, { ptr, i64 } { ptr @str.487, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.488, i64 12 }, { 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 @@ -5117,24 +5123,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.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.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.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.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.490, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.492, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5154,7 +5160,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.492, i64 8 }, { ptr, i64 } { ptr @str.493, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.494, i64 8 }, { ptr, i64 } { ptr @str.495, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5173,24 +5179,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.494, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, 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.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 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.499, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5242,7 +5248,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.501, i64 7 }, { ptr, i64 } { ptr @str.502, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.503, i64 7 }, { 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 @@ -5261,24 +5267,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.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.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.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.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.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 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5330,7 +5336,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.510, i64 9 }, { ptr, i64 } { ptr @str.511, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.512, i64 9 }, { 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 @@ -5349,24 +5355,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.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.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.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.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.516, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.518, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5409,7 +5415,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.518, i64 4 }, { ptr, i64 } { ptr @str.519, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.520, i64 4 }, { ptr, i64 } { ptr @str.521, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5428,24 +5434,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.520, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, 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.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 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.524, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5491,7 +5497,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.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 @@ -5510,24 +5516,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.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.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.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.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.537, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.539, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %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 @@ -5584,7 +5590,7 @@ fv.case28: ; preds = %if.merge.245 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.245 @@ -5609,7 +5615,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.539, i64 6 }, { ptr, i64 } { ptr @str.540, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.541, i64 6 }, { ptr, i64 } { ptr @str.542, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5628,24 +5634,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.541, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, 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.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 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.547, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5704,9 +5710,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.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 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.549, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.551, 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 @@ -5725,8 +5731,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.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 } { ptr @str.558, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.557, 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 @@ -5745,9 +5751,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.561, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.557, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.559, 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 @@ -5766,8 +5772,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.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.261 @@ -5797,9 +5803,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.571, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 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.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, [24 x i8] }, ptr %alloca, align 8 @@ -5816,8 +5822,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.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.263 @@ -5895,9 +5901,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.582, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.584, 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, ptr %alloca, align 8 @@ -5916,8 +5922,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.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 } { ptr @str.586, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.585, 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 @@ -5936,9 +5942,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.591, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.593, 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.585, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.587, 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 @@ -5957,8 +5963,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.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 } { ptr @str.595, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.594, 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 @@ -5975,7 +5981,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.594, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.596, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.276 @@ -5992,12 +5998,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.595, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, 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.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 br label %if.merge.280 @@ -6026,7 +6032,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.597, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.599, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.281 @@ -6043,12 +6049,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.598, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, 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.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.285 @@ -6078,7 +6084,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.600, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.602, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.286 @@ -6095,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.601, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, 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.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 br label %if.merge.290 @@ -6128,7 +6134,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.603, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.605, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.291 @@ -6145,12 +6151,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.604, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, 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.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 br label %if.merge.295 @@ -6179,7 +6185,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.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.296 @@ -6196,12 +6202,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.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.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.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.300 @@ -6230,7 +6236,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.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.301 @@ -6247,12 +6253,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.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.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.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.305 @@ -6282,7 +6288,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.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.313 @@ -6301,12 +6307,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.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.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.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.317 @@ -6335,7 +6341,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.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.318 @@ -6354,12 +6360,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.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.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.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.322 @@ -6388,7 +6394,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.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.323 @@ -6407,12 +6413,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.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.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.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.327 @@ -6442,7 +6448,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.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.328 @@ -6461,12 +6467,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.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.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.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.332 @@ -6496,7 +6502,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.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.333 @@ -6515,12 +6521,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.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.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.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.337 @@ -6562,12 +6568,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.629, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.628, i64 5 }, { ptr, i64 } %callN) + %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 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.627, i64 4 }, %if.then.371 ], [ %callN, %if.else.372 ] + %bp = phi { ptr, i64 } [ { ptr @str.629, i64 4 }, %if.then.371 ], [ %callN, %if.else.372 ] ret { ptr, i64 } %bp } @@ -6590,12 +6596,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.632, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.631, i64 11 }, { ptr, i64 } %callN) + %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 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.630, i64 4 }, %if.then.387 ], [ %callN, %if.else.388 ] + %bp = phi { ptr, i64 } [ { ptr @str.632, i64 4 }, %if.then.387 ], [ %callN, %if.else.388 ] ret { ptr, i64 } %bp } @@ -6618,12 +6624,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.635, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, i64 4 }, { ptr, i64 } %callN) + %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 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.633, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] + %bp = phi { ptr, i64 } [ { ptr @str.635, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] ret { ptr, i64 } %bp } @@ -6646,12 +6652,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.638, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 11 }, { ptr, i64 } %callN) + %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 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.636, i64 4 }, %if.then.393 ], [ %callN, %if.else.394 ] + %bp = phi { ptr, i64 } [ { ptr @str.638, i64 4 }, %if.then.393 ], [ %callN, %if.else.394 ] ret { ptr, i64 } %bp } @@ -6674,12 +6680,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.641, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 6 }, { 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 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.639, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] + %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] ret { ptr, i64 } %bp } @@ -6701,12 +6707,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.644, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 5 }, { 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 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.642, i64 4 }, %if.then.399 ], [ %callN, %if.else.400 ] + %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.399 ], [ %callN, %if.else.400 ] ret { ptr, i64 } %bp } @@ -6729,12 +6735,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.647, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 9 }, { 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 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.645, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] + %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] ret { ptr, i64 } %bp } @@ -6757,12 +6763,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.650, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 18 }, { 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 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.648, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] + %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] ret { ptr, i64 } %bp } @@ -6785,12 +6791,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.653, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 5 }, { 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 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.651, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] + %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] ret { ptr, i64 } %bp } @@ -6813,12 +6819,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.656, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 3 }, { 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 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.654, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] + %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] ret { ptr, i64 } %bp } @@ -6841,12 +6847,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.659, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 4 }, { 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 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.657, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] + %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] ret { ptr, i64 } %bp } @@ -6869,12 +6875,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.662, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 9 }, { 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 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.660, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] + %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] ret { ptr, i64 } %bp } @@ -6897,12 +6903,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.665, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 4 }, { 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 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.663, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -6924,12 +6930,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.668, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 8 }, { 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 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.666, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -6952,12 +6958,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.671, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 6 }, { 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 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.669, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -6979,12 +6985,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.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.431 if.merge.431: ; preds = %if.else.430, %if.then.429 - %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -7007,12 +7013,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.677, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 7 }, { 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 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.675, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -7035,12 +7041,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.680, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 5 }, { 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 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.678, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -7063,12 +7069,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.683, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 7 }, { 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 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.681, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -7091,12 +7097,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.686, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 4 }, { 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 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.684, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -7119,12 +7125,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.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.446 if.merge.446: ; preds = %if.else.445, %if.then.444 - %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -7147,12 +7153,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.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.449 if.merge.449: ; preds = %if.else.448, %if.then.447 - %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -7175,12 +7181,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.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.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -7203,12 +7209,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.698, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 12 }, { 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 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.696, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -7231,12 +7237,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.701, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 6 }, { 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 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.699, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -7259,12 +7265,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.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.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -7287,12 +7293,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.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.464 if.merge.464: ; preds = %if.else.463, %if.then.462 - %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -7315,12 +7321,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.710, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 4 }, { 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 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.708, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -7343,12 +7349,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.713, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 7 }, { 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 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.711, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -7371,12 +7377,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.716, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 6 }, { 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 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.714, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -7399,12 +7405,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.719, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.718, i64 5 }, { 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 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.717, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -7420,7 +7426,7 @@ entry: br i1 %lnot, label %if.then.483, label %if.merge.484 if.then.483: ; preds = %entry - ret { ptr, i64 } { ptr @str.720, i64 4 } + ret { ptr, i64 } { ptr @str.722, i64 4 } if.merge.484: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7444,7 +7450,7 @@ entry: br i1 %lnot, label %if.then.485, label %if.merge.486 if.then.485: ; preds = %entry - ret { ptr, i64 } { ptr @str.721, i64 4 } + ret { ptr, i64 } { ptr @str.723, i64 4 } if.merge.486: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7468,7 +7474,7 @@ entry: br i1 %lnot, label %if.then.487, label %if.merge.488 if.then.487: ; preds = %entry - ret { ptr, i64 } { ptr @str.722, i64 4 } + ret { ptr, i64 } { ptr @str.724, i64 4 } if.merge.488: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7492,7 +7498,7 @@ entry: br i1 %lnot, label %if.then.489, label %if.merge.490 if.then.489: ; preds = %entry - ret { ptr, i64 } { ptr @str.723, i64 4 } + ret { ptr, i64 } { ptr @str.725, 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 db604f2..fb5448b 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [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"*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 [5 x i8] c"*f64\00" +@tn.str.250 = private constant [8 x i8] c"*[4]s64\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 [6 x i8] c"**f64\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 [160 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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 12 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { 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 4 }, { ptr, i64 } { ptr @tn.str.250, i64 7 }, { 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 5 }, { 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 [9 x i8] c"sum: {}\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 [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 [1 x i8] zeroinitializer, align 1 +@str.329 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.330 = private unnamed_addr constant [9 x i8] c"sum: {}\0A\00", 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 +@str.332 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.333 = private unnamed_addr constant [9 x i8] c"sum: {}\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 @fld.str = private constant [5 x i8] c"file\00" -@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 }] +@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 [10 x i8] c"Allocator\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 +@fld.str.346 = private constant [4 x i8] c"ctx\00" +@fld.str.347 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.348 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.349 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.346, i64 3 }, { ptr, i64 } { ptr @fld.str.347, i64 11 }, { ptr, i64 } { ptr @fld.str.348, i64 13 }] +@str.350 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.351 = private unnamed_addr constant [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.356 = private constant [5 x i8] c"data\00" +@field_names.357 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.355, i64 9 }, { ptr, i64 } { ptr @fld.str.356, 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.385 = private constant [10 x i8] c"end_index\00" +@fld.str.386 = private constant [7 x i8] c"parent\00" +@field_names.387 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.384, i64 5 }, { ptr, i64 } { ptr @fld.str.385, i64 9 }, { ptr, i64 } { ptr @fld.str.386, i64 6 }] +@str.388 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.389 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.394 = private constant [4 x i8] c"len\00" +@fld.str.395 = private constant [4 x i8] c"pos\00" +@field_names.396 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.393, i64 3 }, { ptr, i64 } { ptr @fld.str.394, i64 3 }, { ptr, i64 } { ptr @fld.str.395, i64 3 }] @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.398 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.402 = private constant [7 x i8] c"parent\00" +@fld.str.403 = private constant [12 x i8] c"alloc_count\00" +@fld.str.404 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.405 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.406 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.402, i64 6 }, { ptr, i64 } { ptr @fld.str.403, i64 11 }, { ptr, i64 } { ptr @fld.str.404, i64 13 }, { ptr, i64 } { ptr @fld.str.405, i64 17 }] +@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".\00", align 1 +@fld.str.553 = private constant [5 x i8] c"read\00" +@fld.str.554 = private constant [6 x i8] c"write\00" +@fld.str.555 = private constant [7 x i8] c"append\00" +@fld.str.556 = private constant [11 x i8] c"read_write\00" +@field_names.557 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.553, i64 4 }, { ptr, i64 } { ptr @fld.str.554, i64 5 }, { ptr, i64 } { ptr @fld.str.555, i64 6 }, { ptr, i64 } { ptr @fld.str.556, i64 10 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.561 = private constant [4 x i8] c"set\00" +@fld.str.562 = private constant [8 x i8] c"current\00" +@fld.str.563 = private constant [4 x i8] c"end\00" +@field_names.564 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.561, i64 3 }, { ptr, i64 } { ptr @fld.str.562, i64 7 }, { ptr, i64 } { ptr @fld.str.563, i64 3 }] +@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 [6 x i8] c"null_\00" +@fld.str.569 = private constant [6 x i8] c"bool_\00" +@fld.str.570 = private constant [5 x i8] c"int_\00" +@fld.str.571 = private constant [4 x i8] c"str\00" +@fld.str.572 = private constant [6 x i8] c"array\00" +@fld.str.573 = private constant [7 x i8] c"object\00" +@field_names.574 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.568, i64 5 }, { ptr, i64 } { ptr @fld.str.569, i64 5 }, { ptr, i64 } { ptr @fld.str.570, i64 4 }, { ptr, i64 } { ptr @fld.str.571, i64 3 }, { ptr, i64 } { ptr @fld.str.572, i64 5 }, { ptr, i64 } { ptr @fld.str.573, i64 6 }] +@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 +@str.577 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.578 = private constant [6 x i8] c"macos\00" +@fld.str.579 = private constant [6 x i8] c"linux\00" +@fld.str.580 = private constant [8 x i8] c"windows\00" +@fld.str.581 = private constant [5 x i8] c"wasm\00" +@fld.str.582 = private constant [4 x i8] c"ios\00" +@fld.str.583 = private constant [8 x i8] c"android\00" +@fld.str.584 = private constant [8 x i8] c"unknown\00" +@field_names.585 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.578, i64 5 }, { ptr, i64 } { ptr @fld.str.579, i64 5 }, { ptr, i64 } { ptr @fld.str.580, i64 7 }, { ptr, i64 } { ptr @fld.str.581, i64 4 }, { ptr, i64 } { ptr @fld.str.582, i64 3 }, { ptr, i64 } { ptr @fld.str.583, i64 7 }, { ptr, i64 } { ptr @fld.str.584, i64 7 }] +@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 [8 x i8] c"aarch64\00" +@fld.str.590 = private constant [7 x i8] c"x86_64\00" +@fld.str.591 = private constant [7 x i8] c"wasm32\00" +@fld.str.592 = private constant [7 x i8] c"wasm64\00" +@fld.str.593 = private constant [8 x i8] c"unknown\00" +@field_names.594 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.589, i64 7 }, { ptr, i64 } { ptr @fld.str.590, i64 6 }, { ptr, i64 } { ptr @fld.str.591, i64 6 }, { ptr, i64 } { ptr @fld.str.592, i64 6 }, { 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 +@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 [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"*f64\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 @@ -619,85 +619,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -840,7 +762,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -967,7 +889,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1301,7 +1223,7 @@ entry: br i1 %icmp, label %if.then.369, label %if.merge.370 if.then.369: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.370: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1451,7 +1373,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1478,12 +1400,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1508,25 +1430,25 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 98, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 96, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1562,7 +1484,7 @@ match.merge.37: ; preds = %dispatch.merge.472, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1607,12 +1529,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1663,7 +1585,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.264 [ - i64 35, label %dispatch.case.265 + i64 22, label %dispatch.case.265 i64 81, label %dispatch.case.266 i64 87, label %dispatch.case.267 i64 88, label %dispatch.case.268 @@ -1676,7 +1598,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.302 [ - i64 36, label %dispatch.case.303 + i64 23, label %dispatch.case.303 i64 60, label %dispatch.case.304 i64 77, label %dispatch.case.305 i64 85, label %dispatch.case.306 @@ -1689,13 +1611,13 @@ 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 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 - i64 33, label %dispatch.case.342 + i64 25, label %dispatch.case.336 + i64 27, label %dispatch.case.337 + i64 29, label %dispatch.case.338 + i64 31, label %dispatch.case.339 + i64 32, label %dispatch.case.340 + i64 34, label %dispatch.case.341 + i64 36, label %dispatch.case.342 i64 40, label %dispatch.case.343 i64 44, label %dispatch.case.344 i64 47, label %dispatch.case.345 @@ -1789,7 +1711,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 @@ -1811,56 +1733,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -1998,7 +1920,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 @@ -2039,7 +1961,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 @@ -2096,7 +2018,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 @@ -2145,7 +2067,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 @@ -2371,7 +2293,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 @@ -2413,7 +2335,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 @@ -2509,7 +2431,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 @@ -2517,7 +2439,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 @@ -2527,13 +2449,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 @@ -2541,7 +2463,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 @@ -2555,7 +2477,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 @@ -2563,7 +2485,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 @@ -2574,7 +2496,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 @@ -2631,7 +2553,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 @@ -2639,7 +2561,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 @@ -2650,7 +2572,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 @@ -2670,7 +2592,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 @@ -2678,7 +2600,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 @@ -2689,7 +2611,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 @@ -2699,67 +2621,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2935,166 +2941,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3292,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.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3379,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.95(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.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3508,7 +3514,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -3556,7 +3562,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.326, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.328, 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 @@ -3571,7 +3577,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 5) @@ -3598,7 +3604,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 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.330, i64 8 }) ret { ptr, i64 } %call } @@ -3619,7 +3625,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.329, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.331, 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 @@ -3635,7 +3641,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 5) @@ -3663,7 +3669,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 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.333, i64 8 }) ret { ptr, i64 } %call } @@ -3674,7 +3680,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.332, i64 15 }, { ptr, i64 } { ptr @str.333, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.334, i64 15 }, { ptr, i64 } { ptr @str.335, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3693,12 +3699,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.334, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, 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.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 br label %if.merge.125 @@ -3710,7 +3716,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.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 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3767,7 +3773,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.340, i64 9 }, { ptr, i64 } { ptr @str.341, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.342, i64 9 }, { ptr, i64 } { ptr @str.343, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3786,24 +3792,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.342, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, 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.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 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 [3 x { ptr, i64 }], ptr @field_names.347, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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, ptr, ptr }, ptr %alloca, align 8 @@ -3847,20 +3853,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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 }, 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.351, i64 7 }, { 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.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, 2 br i1 %icmp, label %while.body.132, label %while.exit.133 while.body.132: ; preds = %while.hdr.131 @@ -3870,24 +3877,102 @@ 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.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.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 }) + %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.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.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.354, 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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 + +fv.default: ; preds = %if.merge.135 + br label %fv.merge + +fv.case: ; preds = %if.merge.135 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.135 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.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.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.361, 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.362, 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.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 %alloca, align 1 @@ -3898,7 +3983,7 @@ if.merge.135: ; preds = %if.then.134, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 + br label %while.hdr.136 } ; Function Attrs: nounwind @@ -3906,43 +3991,43 @@ 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 }) + %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.136 + br label %while.hdr.141 -while.hdr.136: ; preds = %fv.merge, %entry +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.137, label %while.exit.138 + br i1 %icmp, label %while.body.142, label %while.exit.143 -while.body.137: ; preds = %while.hdr.136 +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.139, label %if.merge.140 + br i1 %icmpN, label %if.then.144, label %if.merge.145 -while.exit.138: ; preds = %while.hdr.136 +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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 1 }) ret { ptr, i64 } %callN -if.then.139: ; preds = %while.body.137 +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 }) + %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.140 + br label %if.merge.145 -if.merge.140: ; preds = %if.then.139, %while.body.137 +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.360, i64 0, i64 %loadN + %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.361, i64 2 }) + %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 @@ -3959,12 +4044,12 @@ 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 + br label %while.hdr.141 -fv.default: ; preds = %if.merge.140 +fv.default: ; preds = %if.merge.145 br label %fv.merge -fv.case: ; preds = %if.merge.140 +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 @@ -3975,43 +4060,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %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.141 + br label %while.hdr.146 -while.hdr.141: ; preds = %fv.merge, %entry +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.142, label %while.exit.143 + br i1 %icmp, label %while.body.147, label %while.exit.148 -while.body.142: ; preds = %while.hdr.141 +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.144, label %if.merge.145 + br i1 %icmpN, label %if.then.149, label %if.merge.150 -while.exit.143: ; preds = %while.hdr.141 +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.364, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, i64 1 }) ret { ptr, i64 } %callN -if.then.144: ; preds = %while.body.142 +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.365, i64 2 }) + %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.145 + br label %if.merge.150 -if.merge.145: ; preds = %if.then.144, %while.body.142 +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.368, i64 0, i64 %loadN + %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.369, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -4029,18 +4114,18 @@ 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.141 + br label %while.hdr.146 -fv.default: ; preds = %if.merge.145 +fv.default: ; preds = %if.merge.150 br label %fv.merge -fv.case: ; preds = %if.merge.145 +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 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.145 +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 @@ -4052,91 +4137,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.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 - 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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.146 - -fv.default: ; preds = %if.merge.150 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.150 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.379, i64 8 }, { ptr, i64 } { ptr @str.380, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.380, i64 5 }, { 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 @@ -4155,27 +4156,27 @@ 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.381, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, 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.382, 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 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.386, i64 0, i64 %loadN + %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.387, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4197,29 +4198,30 @@ fv.default: ; preds = %if.merge.155 br label %fv.merge fv.case: ; preds = %if.merge.155 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.155 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.155 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.388, i64 17 }, { ptr, i64 } { ptr @str.389, i64 1 }) + %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.389, i64 8 }, { 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 @@ -4228,7 +4230,7 @@ entry: while.hdr.156: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.157, label %while.exit.158 while.body.157: ; preds = %while.hdr.156 @@ -4238,19 +4240,19 @@ 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.390, 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.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.391, 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.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.396, 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 @@ -4258,17 +4260,16 @@ if.merge.160: ; preds = %if.then.159, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4281,35 +4282,29 @@ fv.default: ; preds = %if.merge.160 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.160 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.160 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.398, i64 7 }, { ptr, i64 } { ptr @str.399, i64 1 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.398, i64 17 }, { 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 @@ -4318,7 +4313,7 @@ entry: while.hdr.161: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.162, label %while.exit.163 while.body.162: ; preds = %while.hdr.161 @@ -4340,23 +4335,25 @@ if.then.164: ; preds = %while.body.162 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.404, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4369,16 +4366,25 @@ fv.default: ; preds = %if.merge.165 br label %fv.merge fv.case: ; preds = %if.merge.165 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.165 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.165 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4387,7 +4393,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.406, i64 4 }, { ptr, i64 } { ptr @str.407, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.408, i64 4 }, { 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 @@ -4406,24 +4412,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.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.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.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.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.411, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -4460,7 +4466,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.413, i64 10 }, { ptr, i64 } { ptr @str.414, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.415, i64 10 }, { 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 @@ -4479,24 +4485,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.415, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, 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.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 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.422, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4562,7 +4568,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.424, i64 13 }, { ptr, i64 } { ptr @str.425, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.426, i64 13 }, { 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 @@ -4581,24 +4587,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.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.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.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.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.430, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, i64 } }, ptr %alloca, align 8 @@ -4640,7 +4646,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.432, i64 8 }, { ptr, i64 } { ptr @str.433, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.434, i64 8 }, { 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 @@ -4659,24 +4665,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.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.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.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.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.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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4737,7 +4743,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.443, i64 5 }, { ptr, i64 } { ptr @str.444, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.445, i64 5 }, { 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 @@ -4756,24 +4762,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.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.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.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.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.450, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { ptr, i64, i64 }, ptr %alloca, align 8 @@ -4819,7 +4825,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.452, i64 6 }, { ptr, i64 } { ptr @str.453, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.454, i64 6 }, { 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 @@ -4838,24 +4844,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.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.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.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.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.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 @@ -4903,7 +4909,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.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 @@ -4922,24 +4928,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.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.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.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.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.467, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, [24 x i8] } }, ptr %alloca, align 8 @@ -4983,7 +4989,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.469, i64 4 }, { ptr, i64 } { ptr @str.470, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.471, i64 4 }, { 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 @@ -5002,24 +5008,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.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.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.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.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.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 }, ptr %alloca, align 8 @@ -5069,7 +5075,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.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 @@ -5088,24 +5094,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.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.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.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.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.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, ptr } }, ptr %alloca, align 8 @@ -5154,7 +5160,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.487, i64 12 }, { ptr, i64 } { ptr @str.488, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.489, i64 12 }, { 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 @@ -5173,24 +5179,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.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.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.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.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.491, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 %alloca, align 1 @@ -5210,7 +5216,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.493, i64 8 }, { ptr, i64 } { ptr @str.494, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.495, i64 8 }, { 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 @@ -5229,24 +5235,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.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.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.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.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.500, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5298,7 +5304,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.502, i64 7 }, { ptr, i64 } { ptr @str.503, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.504, i64 7 }, { 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 @@ -5317,24 +5323,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.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.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.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.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.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 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5386,7 +5392,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.511, i64 9 }, { ptr, i64 } { ptr @str.512, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.513, i64 9 }, { 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 @@ -5405,24 +5411,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.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.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.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.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.517, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5465,7 +5471,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.519, i64 4 }, { ptr, i64 } { ptr @str.520, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.521, i64 4 }, { 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 @@ -5484,24 +5490,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.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.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.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.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.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 { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5547,7 +5553,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.527, i64 6 }, { ptr, i64 } { ptr @str.528, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.529, i64 6 }, { 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 @@ -5566,24 +5572,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.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.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.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.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.538, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.540, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %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 @@ -5640,7 +5646,7 @@ fv.case28: ; preds = %if.merge.240 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.240 @@ -5665,7 +5671,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.540, i64 6 }, { ptr, i64 } { ptr @str.541, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.542, i64 6 }, { ptr, i64 } { ptr @str.543, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5684,24 +5690,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.542, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, 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.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 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.548, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5760,9 +5766,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.555, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.557, 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.550, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.552, 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 @@ -5781,8 +5787,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.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 } { ptr @str.559, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.558, 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 @@ -5801,9 +5807,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.562, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.564, 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.558, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, 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 @@ -5822,8 +5828,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 @@ -5853,9 +5859,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.572, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.574, 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.565, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.567, 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 @@ -5872,8 +5878,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.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 } { ptr @str.576, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.575, 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 @@ -5951,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 [7 x { ptr, i64 }], ptr @field_names.583, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 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.575, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.577, 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 @@ -5972,8 +5978,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.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.260 @@ -5992,9 +5998,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.592, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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.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 @@ -6013,8 +6019,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.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.262 @@ -6031,7 +6037,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.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.271 @@ -6048,12 +6054,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.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.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.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.275 @@ -6082,7 +6088,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.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.276 @@ -6099,12 +6105,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.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.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.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.280 @@ -6134,7 +6140,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.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.281 @@ -6151,12 +6157,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.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.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.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.285 @@ -6184,7 +6190,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.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.286 @@ -6201,12 +6207,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.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.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.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.290 @@ -6235,7 +6241,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.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.291 @@ -6252,12 +6258,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.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.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.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.295 @@ -6286,7 +6292,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.296 @@ -6303,12 +6309,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.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.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.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.300 @@ -6338,7 +6344,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.308 @@ -6357,12 +6363,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.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.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.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.312 @@ -6391,7 +6397,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.313 @@ -6410,12 +6416,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.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.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.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.317 @@ -6444,7 +6450,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.318 @@ -6463,12 +6469,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.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.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.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.322 @@ -6498,7 +6504,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.323 @@ -6517,12 +6523,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.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.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.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.327 @@ -6552,7 +6558,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.328 @@ -6571,12 +6577,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.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.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.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.332 @@ -6618,12 +6624,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.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.368 if.merge.368: ; preds = %if.else.367, %if.then.366 - %bp = phi { ptr, i64 } [ { ptr @str.628, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] + %bp = phi { ptr, i64 } [ { ptr @str.630, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] ret { ptr, i64 } %bp } @@ -6646,12 +6652,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.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.384 if.merge.384: ; preds = %if.else.383, %if.then.382 - %bp = phi { ptr, i64 } [ { ptr @str.631, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] + %bp = phi { ptr, i64 } [ { ptr @str.633, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] ret { ptr, i64 } %bp } @@ -6674,12 +6680,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.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.387 if.merge.387: ; preds = %if.else.386, %if.then.385 - %bp = phi { ptr, i64 } [ { ptr @str.634, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] + %bp = phi { ptr, i64 } [ { ptr @str.636, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] ret { ptr, i64 } %bp } @@ -6702,12 +6708,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.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.390 if.merge.390: ; preds = %if.else.389, %if.then.388 - %bp = phi { ptr, i64 } [ { ptr @str.637, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] + %bp = phi { ptr, i64 } [ { ptr @str.639, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] ret { ptr, i64 } %bp } @@ -6730,12 +6736,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.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.393 if.merge.393: ; preds = %if.else.392, %if.then.391 - %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] + %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] ret { ptr, i64 } %bp } @@ -6757,12 +6763,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.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.396 if.merge.396: ; preds = %if.else.395, %if.then.394 - %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6785,12 +6791,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.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.399 if.merge.399: ; preds = %if.else.398, %if.then.397 - %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6813,12 +6819,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.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.402 if.merge.402: ; preds = %if.else.401, %if.then.400 - %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6841,12 +6847,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.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.405 if.merge.405: ; preds = %if.else.404, %if.then.403 - %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6869,12 +6875,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.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.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6897,12 +6903,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.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.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -6925,12 +6931,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.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.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -6953,12 +6959,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.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.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -6980,12 +6986,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.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.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -7008,12 +7014,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.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.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -7035,12 +7041,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.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.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7063,12 +7069,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.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.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7091,12 +7097,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.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.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7119,12 +7125,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.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.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7147,12 +7153,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.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.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7175,12 +7181,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.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.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7203,12 +7209,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.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.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7231,12 +7237,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.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.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7259,12 +7265,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.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.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7287,12 +7293,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.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.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7315,12 +7321,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.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.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7343,12 +7349,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.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.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7371,12 +7377,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.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.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7399,12 +7405,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.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.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7427,12 +7433,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.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.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7455,12 +7461,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.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.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7476,7 +7482,7 @@ entry: br i1 %lnot, label %if.then.478, label %if.merge.479 if.then.478: ; preds = %entry - ret { ptr, i64 } { ptr @str.721, i64 4 } + ret { ptr, i64 } { ptr @str.723, i64 4 } if.merge.479: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7500,7 +7506,7 @@ entry: br i1 %lnot, label %if.then.480, label %if.merge.481 if.then.480: ; preds = %entry - ret { ptr, i64 } { ptr @str.722, i64 4 } + ret { ptr, i64 } { ptr @str.724, i64 4 } if.merge.481: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7524,7 +7530,7 @@ entry: br i1 %lnot, label %if.then.482, label %if.merge.483 if.then.482: ; preds = %entry - ret { ptr, i64 } { ptr @str.723, i64 4 } + ret { ptr, i64 } { ptr @str.725, i64 4 } if.merge.483: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7548,7 +7554,7 @@ entry: br i1 %lnot, label %if.then.484, label %if.merge.485 if.then.484: ; preds = %entry - ret { ptr, i64 } { ptr @str.724, i64 4 } + ret { ptr, i64 } { ptr @str.726, 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 040b2ef..789a49b 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [8 x i8] c"[16]f32\00" +@tn.str.241 = private constant [5 x i8] c"Mat4\00" +@tn.str.242 = private constant [5 x i8] c"Vec2\00" +@tn.str.243 = private constant [14 x i8] c"Vector(3,f32)\00" +@tn.str.244 = private constant [12 x i8] c"Vec__3__f32\00" +@tn.str.245 = private constant [5 x i8] c"Vec3\00" +@tn.str.246 = private constant [13 x i8] c"Complex__u32\00" +@tn.str.247 = private constant [4 x i8] c"Foo\00" +@tn.str.248 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.249 = private constant [7 x i8] c"**void\00" +@tn.str.250 = private constant [6 x i8] c"*Vec3\00" +@tn.str.251 = private constant [8 x i8] c"*string\00" +@tn.str.252 = private constant [6 x i8] c"[]Any\00" +@tn.str.253 = private constant [5 x i8] c"*Any\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 [7 x i8] c"*[]Any\00" +@tn.str.257 = private constant [6 x i8] c"*bool\00" +@tn.str.258 = private constant [5 x i8] c"*f32\00" +@tn.str.259 = private constant [15 x i8] c"*Vector(3,f32)\00" +@tn.str.260 = private constant [7 x i8] c"[5]f32\00" +@tn.str.261 = private constant [8 x i8] c"*[5]f32\00" +@tn.str.262 = private constant [5 x i8] c"*Foo\00" +@tn.str.263 = private constant [5 x i8] c"*f64\00" +@tn.str.264 = private constant [8 x i8] c"Sx__f32\00" +@tn.str.265 = private constant [9 x i8] c"*Sx__f32\00" +@tn.str.266 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.267 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.268 = private constant [11 x i8] c"*Allocator\00" +@tn.str.269 = private constant [9 x i8] c"*Context\00" +@tn.str.270 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.271 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.272 = private constant [8 x i8] c"*Member\00" +@tn.str.273 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.274 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.275 = private constant [9 x i8] c"*Command\00" +@tn.str.276 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.277 = private constant [6 x i8] c"*Mat4\00" +@tn.str.278 = private constant [6 x i8] c"*Vec2\00" +@tn.str.279 = private constant [13 x i8] c"*Vec__3__f32\00" +@tn.str.280 = private constant [14 x i8] c"*Complex__u32\00" +@tn.str.281 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.282 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.283 = private constant [7 x i8] c"*Value\00" +@tn.str.284 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.285 = private constant [14 x i8] c"*Architecture\00" +@tn.str.286 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.287 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.288 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.289 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.290 = private constant [9 x i8] c"*[16]f32\00" +@tn.str.291 = private constant [10 x i8] c"*[]string\00" +@tn.str.292 = private constant [6 x i8] c"*[]u8\00" +@tn.str.293 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.294 = private constant [11 x i8] c"*[]Command\00" +@tn.str.295 = private constant [6 x i8] c"**GPA\00" +@tn.str.296 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.297 = private constant [8 x i8] c"**Arena\00" +@tn.str.298 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.299 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.300 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.301 = private constant [7 x i8] c"**File\00" +@tn.str.302 = private constant [5 x i8] c"**u8\00" +@tn.str.303 = private constant [6 x i8] c"**s32\00" +@tn.str.304 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.305 = private constant [6 x i8] c"**u32\00" +@tn.str.306 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.307 = private constant [8 x i8] c"**Array\00" +@tn.str.308 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.309 = private constant [9 x i8] c"**Object\00" +@tn.str.310 = private constant [7 x i8] c"**Sink\00" +@tn.str.311 = private constant [9 x i8] c"**Parser\00" +@tn.str.312 = private constant [6 x i8] c"**s64\00" +@tn.str.313 = private constant [9 x i8] c"**Parsed\00" +@tn.str.314 = private constant [7 x i8] c"**Diag\00" +@tn.str.315 = private constant [9 x i8] c"**Sha256\00" +@tn.str.316 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.317 = private constant [8 x i8] c"***void\00" +@tn.str.318 = private constant [7 x i8] c"**Vec3\00" +@tn.str.319 = private constant [9 x i8] c"**string\00" +@tn.str.320 = private constant [6 x i8] c"**Any\00" +@tn.str.321 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.322 = private constant [8 x i8] c"**[]Any\00" +@tn.str.323 = private constant [7 x i8] c"**bool\00" +@tn.str.324 = private constant [6 x i8] c"**f32\00" +@tn.str.325 = private constant [16 x i8] c"**Vector(3,f32)\00" +@tn.str.326 = private constant [9 x i8] c"**[5]f32\00" +@tn.str.327 = private constant [6 x i8] c"**Foo\00" +@tn.str.328 = private constant [6 x i8] c"**f64\00" +@tn.str.329 = private constant [10 x i8] c"**Sx__f32\00" +@tn.str.330 = private constant [7 x i8] c"*?File\00" +@tn.str.331 = private constant [9 x i8] c"*?string\00" +@tn.str.332 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.333 = 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.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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 7 }, { ptr, i64 } { ptr @tn.str.241, i64 4 }, { ptr, i64 } { ptr @tn.str.242, i64 4 }, { ptr, i64 } { ptr @tn.str.243, i64 13 }, { ptr, i64 } { ptr @tn.str.244, i64 11 }, { ptr, i64 } { ptr @tn.str.245, i64 4 }, { ptr, i64 } { ptr @tn.str.246, i64 12 }, { ptr, i64 } { ptr @tn.str.247, i64 3 }, { ptr, i64 } { ptr @tn.str.248, i64 12 }, { 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 5 }, { 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 6 }, { ptr, i64 } { ptr @tn.str.257, i64 5 }, { ptr, i64 } { ptr @tn.str.258, i64 4 }, { ptr, i64 } { ptr @tn.str.259, i64 14 }, { ptr, i64 } { ptr @tn.str.260, i64 6 }, { ptr, i64 } { ptr @tn.str.261, i64 7 }, { ptr, i64 } { ptr @tn.str.262, i64 4 }, { ptr, i64 } { ptr @tn.str.263, i64 4 }, { ptr, i64 } { ptr @tn.str.264, i64 7 }, { ptr, i64 } { ptr @tn.str.265, i64 8 }, { ptr, i64 } { ptr @tn.str.266, i64 7 }, { ptr, i64 } { ptr @tn.str.267, i64 16 }, { ptr, i64 } { ptr @tn.str.268, i64 10 }, { ptr, i64 } { ptr @tn.str.269, i64 8 }, { ptr, i64 } { ptr @tn.str.270, i64 11 }, { ptr, i64 } { ptr @tn.str.271, i64 14 }, { ptr, i64 } { ptr @tn.str.272, i64 7 }, { ptr, i64 } { ptr @tn.str.273, i64 13 }, { ptr, i64 } { ptr @tn.str.274, i64 9 }, { ptr, i64 } { ptr @tn.str.275, i64 8 }, { ptr, i64 } { ptr @tn.str.276, i64 10 }, { ptr, i64 } { ptr @tn.str.277, i64 5 }, { ptr, i64 } { ptr @tn.str.278, i64 5 }, { ptr, i64 } { ptr @tn.str.279, i64 12 }, { ptr, i64 } { ptr @tn.str.280, i64 13 }, { ptr, i64 } { ptr @tn.str.281, i64 9 }, { ptr, i64 } { ptr @tn.str.282, i64 9 }, { ptr, i64 } { ptr @tn.str.283, i64 6 }, { ptr, i64 } { ptr @tn.str.284, i64 16 }, { ptr, i64 } { ptr @tn.str.285, i64 13 }, { ptr, i64 } { ptr @tn.str.286, i64 14 }, { ptr, i64 } { ptr @tn.str.287, i64 7 }, { ptr, i64 } { ptr @tn.str.288, i64 7 }, { ptr, i64 } { ptr @tn.str.289, i64 8 }, { ptr, i64 } { ptr @tn.str.290, i64 8 }, { ptr, i64 } { ptr @tn.str.291, i64 9 }, { ptr, i64 } { ptr @tn.str.292, i64 5 }, { ptr, i64 } { ptr @tn.str.293, i64 11 }, { ptr, i64 } { ptr @tn.str.294, i64 10 }, { ptr, i64 } { ptr @tn.str.295, i64 5 }, { ptr, i64 } { ptr @tn.str.296, i64 12 }, { ptr, i64 } { ptr @tn.str.297, i64 7 }, { ptr, i64 } { ptr @tn.str.298, i64 6 }, { ptr, i64 } { ptr @tn.str.299, i64 10 }, { ptr, i64 } { ptr @tn.str.300, i64 19 }, { ptr, i64 } { ptr @tn.str.301, i64 6 }, { ptr, i64 } { ptr @tn.str.302, i64 4 }, { ptr, i64 } { ptr @tn.str.303, i64 5 }, { ptr, i64 } { ptr @tn.str.304, i64 10 }, { ptr, i64 } { ptr @tn.str.305, i64 5 }, { ptr, i64 } { ptr @tn.str.306, i64 9 }, { ptr, i64 } { ptr @tn.str.307, i64 7 }, { ptr, i64 } { ptr @tn.str.308, i64 10 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.313, i64 8 }, { ptr, i64 } { ptr @tn.str.314, i64 6 }, { ptr, i64 } { ptr @tn.str.315, i64 8 }, { ptr, i64 } { ptr @tn.str.316, i64 13 }, { ptr, i64 } { ptr @tn.str.317, i64 7 }, { ptr, i64 } { ptr @tn.str.318, i64 6 }, { ptr, i64 } { ptr @tn.str.319, i64 8 }, { ptr, i64 } { ptr @tn.str.320, i64 5 }, { ptr, i64 } { ptr @tn.str.321, i64 8 }, { ptr, i64 } { ptr @tn.str.322, i64 7 }, { ptr, i64 } { ptr @tn.str.323, i64 6 }, { ptr, i64 } { ptr @tn.str.324, i64 5 }, { ptr, i64 } { ptr @tn.str.325, i64 15 }, { ptr, i64 } { ptr @tn.str.326, i64 8 }, { ptr, i64 } { ptr @tn.str.327, i64 5 }, { ptr, i64 } { ptr @tn.str.328, i64 5 }, { ptr, i64 } { ptr @tn.str.329, i64 9 }, { ptr, i64 } { ptr @tn.str.330, i64 6 }, { ptr, i64 } { ptr @tn.str.331, i64 8 }, { ptr, i64 } { ptr @tn.str.332, i64 15 }, { ptr, i64 } { ptr @tn.str.333, i64 8 }] @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 [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 [1 x i8] zeroinitializer, align 1 +@str.339 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.340 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.341 = private unnamed_addr constant [15 x i8] c"result := \22\22; \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 [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.346 = private unnamed_addr constant [6 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 [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.351 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.352 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.353 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.354 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.355 = private unnamed_addr constant [5 x i8] c")); \00", 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 [1 x i8] zeroinitializer, align 1 +@str.357 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.358 = private unnamed_addr constant [8 x i8] c"v1: {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.360 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.361 = private unnamed_addr constant [8 x i8] c"v2: {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.363 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.364 = private unnamed_addr constant [10 x i8] c"buff: {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.366 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.367 = private unnamed_addr constant [10 x i8] c"comp: {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.369 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.370 = private unnamed_addr constant [9 x i8] c"add: {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.372 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.373 = private unnamed_addr constant [10 x i8] c"v2.x: {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.375 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.376 = private unnamed_addr constant [11 x i8] c"v2[1]: {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.378 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.379 = private unnamed_addr constant [12 x i8] c"scaled: {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.381 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.382 = private unnamed_addr constant [9 x i8] c"neg: {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.384 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.385 = private unnamed_addr constant [13 x i8] c"sqrt(9): {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.387 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.388 = private unnamed_addr constant [4 x i8] c"{}\0A\00", 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 +@str.390 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.391 = private unnamed_addr constant [4 x i8] c"{}\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 [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 }] +@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 [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 [11 x i8] c"CAllocator\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 +@field_names.421 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.422 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.423 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.428 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.427, i64 11 }] +@str.429 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.430 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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"next\00" +@fld.str.435 = private constant [4 x i8] c"cap\00" +@field_names.436 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.434, i64 4 }, { 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.443 = private constant [10 x i8] c"end_index\00" +@fld.str.444 = private constant [7 x i8] c"parent\00" +@field_names.445 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.442, i64 5 }, { ptr, i64 } { ptr @fld.str.443, i64 9 }, { ptr, i64 } { ptr @fld.str.444, i64 6 }] +@str.446 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.447 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.452 = private constant [4 x i8] c"len\00" +@fld.str.453 = private constant [4 x i8] c"pos\00" +@field_names.454 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.451, i64 3 }, { 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 [8 x i8] c"Context\00", align 1 +@str.456 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.460 = private constant [7 x i8] c"parent\00" +@fld.str.461 = private constant [12 x i8] c"alloc_count\00" +@fld.str.462 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.463 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.464 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 6 }, { ptr, i64 } { ptr @fld.str.461, i64 11 }, { ptr, i64 } { ptr @fld.str.462, i64 13 }, { ptr, i64 } { ptr @fld.str.463, i64 17 }] +@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 [5 x i8] c"Mat4\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 +@fld.str.614 = private constant [5 x i8] c"data\00" +@field_names.615 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.614, i64 4 }] +@str.616 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.617 = private unnamed_addr constant [5 x i8] c"Vec2\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 +@fld.str.621 = private constant [2 x i8] c"x\00" +@fld.str.622 = private constant [2 x i8] c"y\00" +@field_names.623 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.621, i64 1 }, { ptr, i64 } { ptr @fld.str.622, i64 1 }] +@str.624 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.625 = private unnamed_addr constant [12 x i8] c"Vec__3__f32\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 +@fld.str.629 = private constant [5 x i8] c"data\00" +@field_names.630 = private constant [1 x { ptr, i64 }] [{ 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 [5 x i8] c"Vec3\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 +@fld.str.636 = private constant [5 x i8] c"data\00" +@field_names.637 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.636, i64 4 }] +@str.638 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.639 = private unnamed_addr constant [13 x i8] c"Complex__u32\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 +@fld.str.643 = private constant [6 x i8] c"value\00" +@fld.str.644 = private constant [6 x i8] c"count\00" +@field_names.645 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.643, i64 5 }, { ptr, i64 } { ptr @fld.str.644, i64 5 }] +@str.646 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.647 = private unnamed_addr constant [4 x i8] c"Foo\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 +@str.650 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.651 = private constant [6 x i8] c"value\00" +@fld.str.652 = private constant [6 x i8] c"count\00" +@field_names.653 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.651, i64 5 }, { ptr, i64 } { ptr @fld.str.652, i64 5 }] +@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 +@fld.str.656 = private constant [5 x i8] c"read\00" +@fld.str.657 = private constant [6 x i8] c"write\00" +@fld.str.658 = private constant [7 x i8] c"append\00" +@fld.str.659 = private constant [11 x i8] c"read_write\00" +@field_names.660 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.656, i64 4 }, { ptr, i64 } { ptr @fld.str.657, i64 5 }, { ptr, i64 } { ptr @fld.str.658, i64 6 }, { ptr, i64 } { ptr @fld.str.659, i64 10 }] +@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 +@fld.str.664 = private constant [4 x i8] c"set\00" +@fld.str.665 = private constant [8 x i8] c"current\00" +@fld.str.666 = private constant [4 x i8] c"end\00" +@field_names.667 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.664, i64 3 }, { ptr, i64 } { ptr @fld.str.665, i64 7 }, { ptr, i64 } { ptr @fld.str.666, i64 3 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.671 = private constant [6 x i8] c"null_\00" +@fld.str.672 = private constant [6 x i8] c"bool_\00" +@fld.str.673 = private constant [5 x i8] c"int_\00" +@fld.str.674 = private constant [4 x i8] c"str\00" +@fld.str.675 = private constant [6 x i8] c"array\00" +@fld.str.676 = private constant [7 x i8] c"object\00" +@field_names.677 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.671, i64 5 }, { ptr, i64 } { ptr @fld.str.672, i64 5 }, { ptr, i64 } { ptr @fld.str.673, i64 4 }, { ptr, i64 } { ptr @fld.str.674, i64 3 }, { ptr, i64 } { ptr @fld.str.675, i64 5 }, { ptr, i64 } { ptr @fld.str.676, i64 6 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.681 = private constant [6 x i8] c"macos\00" +@fld.str.682 = private constant [6 x i8] c"linux\00" +@fld.str.683 = private constant [8 x i8] c"windows\00" +@fld.str.684 = private constant [5 x i8] c"wasm\00" +@fld.str.685 = private constant [4 x i8] c"ios\00" +@fld.str.686 = private constant [8 x i8] c"android\00" +@fld.str.687 = private constant [8 x i8] c"unknown\00" +@field_names.688 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.681, i64 5 }, { ptr, i64 } { ptr @fld.str.682, i64 5 }, { ptr, i64 } { ptr @fld.str.683, i64 7 }, { ptr, i64 } { ptr @fld.str.684, i64 4 }, { ptr, i64 } { ptr @fld.str.685, i64 3 }, { ptr, i64 } { ptr @fld.str.686, i64 7 }, { ptr, i64 } { ptr @fld.str.687, i64 7 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.692 = private constant [8 x i8] c"aarch64\00" +@fld.str.693 = private constant [7 x i8] c"x86_64\00" +@fld.str.694 = private constant [7 x i8] c"wasm32\00" +@fld.str.695 = private constant [7 x i8] c"wasm64\00" +@fld.str.696 = private constant [8 x i8] c"unknown\00" +@field_names.697 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.692, i64 7 }, { ptr, i64 } { ptr @fld.str.693, i64 6 }, { ptr, i64 } { ptr @fld.str.694, i64 6 }, { ptr, i64 } { ptr @fld.str.695, i64 6 }, { ptr, i64 } { ptr @fld.str.696, i64 7 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.701 = private constant [8 x i8] c"counter\00" +@fld.str.702 = private constant [5 x i8] c"user\00" +@field_names.703 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.701, i64 7 }, { ptr, i64 } { ptr @fld.str.702, i64 4 }] +@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 [2 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 [3 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 [2 x i8] c"]\00", align 1 +@str.711 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.714 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.717 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.720 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.723 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.726 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.729 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.732 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.735 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.738 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.741 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.744 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.745 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.746 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.747 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.748 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.749 = private unnamed_addr constant [6 x i8] c"*void\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 [12 x i8] c"*CAllocator\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"*GPA\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 [12 x i8] c"*ArenaChunk\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"*Arena\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"[*]u8\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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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"*File\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 [4 x i8] c"*u8\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"*s32\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 [10 x i8] c"*SockAddr\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 [5 x i8] c"*u32\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 [9 x i8] c"[*]Value\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 [7 x i8] c"*Array\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 [10 x i8] c"[*]Member\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 [8 x i8] c"*Object\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 [6 x i8] c"*Sink\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 [8 x i8] c"*Parser\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 [5 x i8] c"*s64\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 [8 x i8] c"*Parsed\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 [6 x i8] c"*Diag\00", align 1 +@str.813 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.814 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.815 = private unnamed_addr constant [8 x i8] c"*Sha256\00", align 1 +@str.816 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.817 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.818 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.819 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.820 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.821 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.822 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.823 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.824 = private unnamed_addr constant [6 x i8] c"*Vec3\00", align 1 +@str.825 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.826 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.827 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.828 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.829 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.830 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.831 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.832 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.833 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.834 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.835 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.836 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.837 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.838 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.839 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.840 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.841 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.842 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1 +@str.843 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.844 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.845 = private unnamed_addr constant [15 x i8] c"*Vector(3,f32)\00", align 1 +@str.846 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.847 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.848 = private unnamed_addr constant [8 x i8] c"*[5]f32\00", align 1 +@str.849 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.850 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.851 = private unnamed_addr constant [5 x i8] c"*Foo\00", align 1 +@str.852 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.853 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.854 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1 +@str.855 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.856 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.857 = private unnamed_addr constant [9 x i8] c"*Sx__f32\00", align 1 +@str.858 = private unnamed_addr constant [4 x i8] c"@0x\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 +@str.861 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.862 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -755,85 +755,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -976,7 +898,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1103,7 +1025,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1437,7 +1359,7 @@ entry: br i1 %icmp, label %if.then.434, label %if.merge.435 if.then.434: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.435: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1588,7 +1510,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1615,12 +1537,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1653,7 +1575,7 @@ entry: i64 64, label %match.arm.45 i64 75, label %match.arm.45 i64 96, label %match.arm.46 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 @@ -1661,19 +1583,19 @@ entry: i64 93, label %match.arm.47 i64 107, label %match.arm.47 i64 113, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 105, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1715,7 +1637,7 @@ match.merge.37: ; preds = %dispatch.merge.555, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1760,12 +1682,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1828,7 +1750,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.311 [ - i64 35, label %dispatch.case.312 + i64 22, label %dispatch.case.312 i64 81, label %dispatch.case.313 i64 87, label %dispatch.case.314 i64 88, label %dispatch.case.315 @@ -1843,7 +1765,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw37 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw37, label %dispatch.default.361 [ - i64 36, label %dispatch.case.362 + i64 23, label %dispatch.case.362 i64 60, label %dispatch.case.363 i64 77, label %dispatch.case.364 i64 85, label %dispatch.case.365 @@ -1856,13 +1778,13 @@ 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 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 - i64 33, label %dispatch.case.401 + i64 25, label %dispatch.case.395 + i64 27, label %dispatch.case.396 + i64 29, label %dispatch.case.397 + i64 31, label %dispatch.case.398 + i64 32, label %dispatch.case.399 + i64 34, label %dispatch.case.400 + i64 36, label %dispatch.case.401 i64 40, label %dispatch.case.402 i64 44, label %dispatch.case.403 i64 47, label %dispatch.case.404 @@ -1962,7 +1884,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.332, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.334, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1984,56 +1906,56 @@ dispatch.case.97: ; preds = %match.arm.43 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 {}, ptr %ua.ptr73, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load74) + %ua.load74 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %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 { i64 }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load78) + %ua.load78 = load {}, ptr %ua.ptr77, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %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, i64 }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load82) + %ua.load82 = load { i64 }, ptr %ua.ptr81, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load82) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.101: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) + %ua.load86 = load { ptr, i64 }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.102: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) + %ua.load94 = load { ptr, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw96 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr97 = inttoptr i64 %ua.raw96 to ptr - %ua.load98 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr97, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load98) + %ua.load98 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr97, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load98) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2219,7 +2141,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.333, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.335, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.282 dispatch.case.284: ; preds = %match.arm.44 @@ -2268,7 +2190,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.334, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.336, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.302 dispatch.case.304: ; preds = %match.arm.46 @@ -2285,7 +2207,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.335, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.337, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.310 dispatch.case.312: ; preds = %match.arm.47 @@ -2358,7 +2280,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.336, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.338, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.360 dispatch.case.362: ; preds = %match.arm.48 @@ -2407,7 +2329,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.337, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.339, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.392 dispatch.case.394: ; preds = %match.arm.49 @@ -2675,7 +2597,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.338, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.340, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.555 dispatch.case.557: ; preds = %match.arm.50 @@ -2717,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.339, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.341, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2813,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.340, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, 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 @@ -2821,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.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 i64, ptr %allocaN, align 8 @@ -2831,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.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.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.343, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, 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 @@ -2845,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.344, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2859,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.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 @@ -2867,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.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 i64, ptr %allocaN, align 8 @@ -2878,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.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 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2935,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.348, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.350, 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 @@ -2943,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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2954,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.350, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2974,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.351, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.353, 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 @@ -2982,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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -2993,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.353, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.355, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -3003,67 +2925,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3239,166 +3245,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3596,64 +3602,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3683,97 +3689,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3812,7 +3818,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind declare void @Mat4.identity(ptr sret({ [16 x float] }), ptr) #0 @@ -3991,7 +3997,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.354, i64 7 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.356, 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 @@ -4009,7 +4015,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.355, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.357, 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) @@ -4039,7 +4045,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.356, i64 7 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.358, i64 7 }) ret { ptr, i64 } %call } @@ -4047,7 +4053,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.357, i64 7 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.359, 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 @@ -4065,7 +4071,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.358, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.360, 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) @@ -4095,7 +4101,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.359, i64 7 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.361, i64 7 }) ret { ptr, i64 } %call } @@ -4103,7 +4109,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.360, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.362, 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 @@ -4121,7 +4127,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.361, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.363, 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) @@ -4151,7 +4157,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.362, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.364, i64 9 }) ret { ptr, i64 } %call } @@ -4159,7 +4165,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.363, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.365, 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 @@ -4177,7 +4183,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.364, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.366, 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) @@ -4207,7 +4213,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.365, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.367, i64 9 }) ret { ptr, i64 } %call } @@ -4215,7 +4221,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.366, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.368, 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 @@ -4233,7 +4239,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.367, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.369, 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) @@ -4263,7 +4269,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.368, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.370, i64 8 }) ret { ptr, i64 } %call } @@ -4271,7 +4277,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.369, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.371, 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 @@ -4288,7 +4294,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.370, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.372, 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) @@ -4317,7 +4323,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.371, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.373, i64 9 }) ret { ptr, i64 } %call } @@ -4325,7 +4331,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.372, i64 10 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.374, 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 @@ -4342,7 +4348,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.373, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.375, 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) @@ -4371,7 +4377,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.374, i64 10 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.376, i64 10 }) ret { ptr, i64 } %call } @@ -4379,7 +4385,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.375, i64 11 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.377, 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 @@ -4397,7 +4403,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.376, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.378, 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) @@ -4427,7 +4433,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.377, i64 11 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.379, i64 11 }) ret { ptr, i64 } %call } @@ -4435,7 +4441,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.378, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.380, 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 @@ -4453,7 +4459,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.379, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.381, 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) @@ -4483,7 +4489,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.380, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.382, i64 8 }) ret { ptr, i64 } %call } @@ -4500,7 +4506,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.381, i64 12 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.383, 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 @@ -4516,7 +4522,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 9) @@ -4544,7 +4550,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.383, i64 12 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.385, i64 12 }) ret { ptr, i64 } %call } @@ -4552,7 +4558,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.384, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.386, 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 @@ -4570,7 +4576,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.385, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.387, 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 @@ -4595,7 +4601,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.386, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.388, i64 3 }) ret { ptr, i64 } %call } @@ -4603,7 +4609,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.387, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.389, 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 @@ -4618,7 +4624,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.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 i64, ptr %allocaN, align 8 %ba.val9 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %loadN, 1 @@ -4640,7 +4646,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.389, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.391, i64 3 }) ret { ptr, i64 } %call } @@ -4651,7 +4657,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 @@ -4670,12 +4676,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.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.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.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.131 @@ -4687,7 +4693,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.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 @@ -4744,7 +4750,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.398, i64 9 }, { ptr, i64 } { ptr @str.399, i64 1 }) + %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 @@ -4763,24 +4769,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.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.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.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.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 [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, ptr, ptr }, ptr %alloca, align 8 @@ -4824,20 +4830,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.407, i64 10 }, { ptr, i64 } { ptr @str.408, i64 1 }) + %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 }) %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, 2 br i1 %icmp, label %while.body.138, label %while.exit.139 while.body.138: ; preds = %while.hdr.137 @@ -4847,24 +4854,102 @@ 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.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.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 }) + %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.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.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.412, 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 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.137 + +fv.default: ; preds = %if.merge.141 + br label %fv.merge + +fv.case: ; preds = %if.merge.141 + %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + store { ptr, ptr, ptr } %fv.field, ptr %ba.tmp, align 8 + %ba.p2i = ptrtoint ptr %ba.tmp to i64 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.141 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.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 + 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.419, 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.420, 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.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.422, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -4875,7 +4960,7 @@ if.merge.141: ; preds = %if.then.140, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.137 + br label %while.hdr.142 } ; Function Attrs: nounwind @@ -4883,43 +4968,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.423, i64 3 }, { 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 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.142 + br label %while.hdr.147 -while.hdr.142: ; preds = %fv.merge, %entry +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.143, label %while.exit.144 + br i1 %icmp, label %while.body.148, label %while.exit.149 -while.body.143: ; preds = %while.hdr.142 +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.145, label %if.merge.146 + br i1 %icmpN, label %if.then.150, label %if.merge.151 -while.exit.144: ; preds = %while.hdr.142 +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.415, 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.145: ; preds = %while.body.143 +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.416, 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.146 + br label %if.merge.151 -if.merge.146: ; preds = %if.then.145, %while.body.143 +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.418, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.419, 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 { i64 }, ptr %alloca, align 8 @@ -4936,12 +5021,12 @@ 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 + br label %while.hdr.147 -fv.default: ; preds = %if.merge.146 +fv.default: ; preds = %if.merge.151 br label %fv.merge -fv.case: ; preds = %if.merge.146 +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 @@ -4952,43 +5037,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.430, i64 10 }, { 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 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.147 + br label %while.hdr.152 -while.hdr.147: ; preds = %fv.merge, %entry +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.148, label %while.exit.149 + br i1 %icmp, label %while.body.153, label %while.exit.154 -while.body.148: ; preds = %while.hdr.147 +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.150, label %if.merge.151 + br i1 %icmpN, label %if.then.155, label %if.merge.156 -while.exit.149: ; preds = %while.hdr.147 +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.422, 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.150: ; preds = %while.body.148 +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.423, 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.151 + br label %if.merge.156 -if.merge.151: ; preds = %if.then.150, %while.body.148 +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.426, 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.427, 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 }, ptr %alloca, align 8 @@ -5006,18 +5091,18 @@ 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.147 + br label %while.hdr.152 -fv.default: ; preds = %if.merge.151 +fv.default: ; preds = %if.merge.156 br label %fv.merge -fv.case: ; preds = %if.merge.151 +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 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.151 +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 @@ -5029,91 +5114,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 }) - %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.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.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.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.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 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.152 - -fv.default: ; preds = %if.merge.156 - br label %fv.merge - -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 - br label %fv.merge - -fv.case17: ; preds = %if.merge.156 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.437, i64 8 }, { ptr, i64 } { ptr @str.438, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.438, i64 5 }, { 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 @@ -5132,27 +5133,27 @@ 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.439, 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.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.440, 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.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.444, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.445, 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, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -5174,29 +5175,30 @@ fv.default: ; preds = %if.merge.161 br label %fv.merge fv.case: ; preds = %if.merge.161 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.161 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.161 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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 }) + %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 8 }, { 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 @@ -5205,7 +5207,7 @@ entry: while.hdr.162: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.163, label %while.exit.164 while.body.163: ; preds = %while.hdr.162 @@ -5215,19 +5217,19 @@ 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.448, 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.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.449, 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.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.454, 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 @@ -5235,17 +5237,16 @@ if.merge.166: ; preds = %if.then.165, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -5258,35 +5259,29 @@ fv.default: ; preds = %if.merge.166 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.166 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.166 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.166 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 17 }, { 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 @@ -5295,7 +5290,7 @@ entry: while.hdr.167: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.168, label %while.exit.169 while.body.168: ; preds = %while.hdr.167 @@ -5317,23 +5312,25 @@ if.then.170: ; preds = %while.body.168 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.462, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -5346,16 +5343,25 @@ fv.default: ; preds = %if.merge.171 br label %fv.merge fv.case: ; preds = %if.merge.171 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.171 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.171 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.171 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -5364,7 +5370,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 @@ -5383,24 +5389,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.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.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.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.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.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 @@ -5437,7 +5443,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 @@ -5456,24 +5462,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.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.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.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.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.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 @@ -5539,7 +5545,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 @@ -5558,24 +5564,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.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.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.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.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.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 @@ -5617,7 +5623,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 @@ -5636,24 +5642,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.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.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.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.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.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 @@ -5714,7 +5720,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 @@ -5733,24 +5739,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.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.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.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.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.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 @@ -5796,7 +5802,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 @@ -5815,24 +5821,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.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.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.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.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.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 @@ -5880,7 +5886,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 @@ -5899,24 +5905,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.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.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.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.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.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 @@ -5960,7 +5966,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 @@ -5979,24 +5985,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.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.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.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.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.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 @@ -6046,7 +6052,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 @@ -6065,24 +6071,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.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.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.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.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.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 @@ -6131,7 +6137,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 @@ -6150,24 +6156,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.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.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.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.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.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 @@ -6187,7 +6193,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 @@ -6206,24 +6212,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.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.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.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.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.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 @@ -6275,7 +6281,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 @@ -6294,24 +6300,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.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.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.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.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.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 @@ -6363,7 +6369,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 @@ -6382,24 +6388,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.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.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.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.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.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 @@ -6442,7 +6448,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 @@ -6461,24 +6467,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.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.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.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.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.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 @@ -6524,7 +6530,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 @@ -6543,24 +6549,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.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.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.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.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.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 @@ -6617,7 +6623,7 @@ fv.case28: ; preds = %if.merge.246 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.246 @@ -6642,7 +6648,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 @@ -6661,24 +6667,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.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.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.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.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.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 @@ -6734,7 +6740,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.608, i64 4 }, { ptr, i64 } { ptr @str.609, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.610, i64 4 }, { 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 @@ -6753,24 +6759,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.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.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.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.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.613, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.615, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [16 x float] }, ptr %alloca, align 4 @@ -6805,7 +6811,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.615, i64 4 }, { ptr, i64 } { ptr @str.616, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.617, i64 4 }, { ptr, i64 } { ptr @str.618, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6824,24 +6830,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.617, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.619, 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.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.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.621, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.623, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { float, float }, ptr %alloca, align 4 @@ -6885,7 +6891,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.623, i64 11 }, { ptr, i64 } { ptr @str.624, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.625, i64 11 }, { ptr, i64 } { ptr @str.626, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6904,24 +6910,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.625, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.627, 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.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.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.628, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { <3 x float> }, ptr %alloca, align 16 @@ -6957,7 +6963,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.630, i64 4 }, { ptr, i64 } { ptr @str.631, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.632, i64 4 }, { ptr, i64 } { ptr @str.633, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6976,24 +6982,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.632, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.634, 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.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.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.635, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.637, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { <3 x float> }, ptr %alloca, align 16 @@ -7028,7 +7034,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.637, i64 12 }, { ptr, i64 } { ptr @str.638, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.639, i64 12 }, { ptr, i64 } { ptr @str.640, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7047,24 +7053,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.639, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.641, 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.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.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.643, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.645, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.646, 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 @@ -7105,7 +7111,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.645, i64 3 }, { ptr, i64 } { ptr @str.646, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 3 }, { ptr, i64 } { ptr @str.648, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7124,24 +7130,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.647, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.649, 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.648, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.650, 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.651, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.653, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, i32 }, ptr %alloca, align 4 @@ -7186,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.658, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.660, 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 @@ -7207,8 +7213,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.291 @@ -7227,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.665, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.667, 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.661, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.663, 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 @@ -7248,8 +7254,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.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 } { ptr @str.669, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, 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 @@ -7279,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.675, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.677, 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.668, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, 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 @@ -7298,8 +7304,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.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 } { ptr @str.679, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.678, 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 @@ -7377,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.686, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.688, 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.678, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, 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 @@ -7398,8 +7404,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.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 } { ptr @str.690, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, 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 @@ -7418,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.695, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.697, 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.689, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, 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 @@ -7439,8 +7445,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.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 } { ptr @str.699, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.698, 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 @@ -7464,9 +7470,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.701, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.703, 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.698, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, 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 @@ -7479,8 +7485,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.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 } { ptr @str.705, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, 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 @@ -7527,7 +7533,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.704, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.706, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.305 @@ -7544,12 +7550,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.705, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.707, 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.706, i64 2 }) + %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 br label %if.merge.309 @@ -7578,7 +7584,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.707, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.709, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.320 @@ -7595,12 +7601,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.708, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.710, 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.709, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.711, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.324 @@ -7629,7 +7635,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.710, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.712, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.325 @@ -7646,12 +7652,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.711, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.713, 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.712, i64 2 }) + %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.329 @@ -7681,7 +7687,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.713, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.715, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.330 @@ -7698,12 +7704,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.714, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.716, 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.715, i64 2 }) + %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 br label %if.merge.334 @@ -7731,7 +7737,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.716, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.718, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.335 @@ -7748,12 +7754,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.717, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.719, 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.718, 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.339 @@ -7782,7 +7788,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.719, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.721, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.340 @@ -7799,12 +7805,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.720, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.722, 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.721, i64 2 }) + %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 br label %if.merge.344 @@ -7832,7 +7838,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.722, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.724, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.345 @@ -7849,12 +7855,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.723, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.725, 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.724, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.726, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.349 @@ -7885,7 +7891,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.725, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.727, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.350 @@ -7902,12 +7908,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.726, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.728, 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.727, i64 2 }) + %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.354 @@ -7937,7 +7943,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.728, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.730, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.355 @@ -7954,12 +7960,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.729, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.731, 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.730, 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 br label %if.merge.359 @@ -7989,7 +7995,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.731, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.733, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.367 @@ -8008,12 +8014,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.732, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.734, 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.733, 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.371 @@ -8042,7 +8048,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.734, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.736, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.372 @@ -8061,12 +8067,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.735, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.737, 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.736, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.738, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.376 @@ -8095,7 +8101,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.737, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.739, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.377 @@ -8114,12 +8120,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.738, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.740, 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.739, 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 br label %if.merge.381 @@ -8149,7 +8155,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.740, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.742, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.382 @@ -8168,12 +8174,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.741, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.743, 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.742, 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.386 @@ -8203,7 +8209,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.743, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.745, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.387 @@ -8222,12 +8228,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.744, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.746, 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.745, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.747, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.391 @@ -8269,12 +8275,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.748, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 5 }, { 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 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.746, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] + %bp = phi { ptr, i64 } [ { ptr @str.748, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] ret { ptr, i64 } %bp } @@ -8297,12 +8303,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.751, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.750, i64 11 }, { 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 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.749, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.751, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -8325,12 +8331,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.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.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.752, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.754, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -8353,12 +8359,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.757, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 11 }, { 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 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.755, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.757, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -8381,12 +8387,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.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.458 if.merge.458: ; preds = %if.else.457, %if.then.456 - %bp = phi { ptr, i64 } [ { ptr @str.758, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.760, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -8408,12 +8414,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.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.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.761, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.763, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -8436,12 +8442,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.766, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 9 }, { 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 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.764, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.766, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -8464,12 +8470,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.769, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 18 }, { 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 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.767, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.769, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -8492,12 +8498,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.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.470 if.merge.470: ; preds = %if.else.469, %if.then.468 - %bp = phi { ptr, i64 } [ { ptr @str.770, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.772, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -8520,12 +8526,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.775, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 3 }, { 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 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.773, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.775, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -8548,12 +8554,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.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.476 if.merge.476: ; preds = %if.else.475, %if.then.474 - %bp = phi { ptr, i64 } [ { ptr @str.776, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.778, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -8576,12 +8582,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.781, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 9 }, { 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 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.779, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.781, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -8604,12 +8610,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.784, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 4 }, { 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 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.782, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.784, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -8631,12 +8637,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.787, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 8 }, { 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 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.785, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.787, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -8659,12 +8665,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.790, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 6 }, { 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 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.788, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] + %bp = phi { ptr, i64 } [ { ptr @str.790, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] ret { ptr, i64 } %bp } @@ -8686,12 +8692,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.793, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 9 }, { 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 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.791, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] + %bp = phi { ptr, i64 } [ { ptr @str.793, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] ret { ptr, i64 } %bp } @@ -8714,12 +8720,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.796, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 7 }, { 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 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.794, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] + %bp = phi { ptr, i64 } [ { ptr @str.796, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] ret { ptr, i64 } %bp } @@ -8742,12 +8748,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.799, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 5 }, { 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 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.797, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] + %bp = phi { ptr, i64 } [ { ptr @str.799, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] ret { ptr, i64 } %bp } @@ -8770,12 +8776,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.802, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 7 }, { 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 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.800, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] + %bp = phi { ptr, i64 } [ { ptr @str.802, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] ret { ptr, i64 } %bp } @@ -8798,12 +8804,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.805, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 4 }, { 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 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.803, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] + %bp = phi { ptr, i64 } [ { ptr @str.805, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] ret { ptr, i64 } %bp } @@ -8826,12 +8832,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.808, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.807, i64 7 }, { 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 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.806, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] + %bp = phi { ptr, i64 } [ { ptr @str.808, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] ret { ptr, i64 } %bp } @@ -8854,12 +8860,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.811, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.810, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.813, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.812, 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.809, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] + %bp = phi { ptr, i64 } [ { ptr @str.811, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] ret { ptr, i64 } %bp } @@ -8882,12 +8888,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.814, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.813, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.816, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.815, 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.812, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] + %bp = phi { ptr, i64 } [ { ptr @str.814, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] ret { ptr, i64 } %bp } @@ -8910,12 +8916,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.817, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.816, i64 12 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.819, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.818, 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.815, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] + %bp = phi { ptr, i64 } [ { ptr @str.817, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] ret { ptr, i64 } %bp } @@ -8938,12 +8944,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.820, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.819, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.822, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.821, 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.818, i64 4 }, %if.then.516 ], [ %callN, %if.else.517 ] + %bp = phi { ptr, i64 } [ { ptr @str.820, i64 4 }, %if.then.516 ], [ %callN, %if.else.517 ] ret { ptr, i64 } %bp } @@ -8966,12 +8972,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.823, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.822, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.825, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.824, 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.821, i64 4 }, %if.then.519 ], [ %callN, %if.else.520 ] + %bp = phi { ptr, i64 } [ { ptr @str.823, i64 4 }, %if.then.519 ], [ %callN, %if.else.520 ] ret { ptr, i64 } %bp } @@ -8994,12 +9000,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.826, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.825, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.828, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.827, 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.824, i64 4 }, %if.then.522 ], [ %callN, %if.else.523 ] + %bp = phi { ptr, i64 } [ { ptr @str.826, i64 4 }, %if.then.522 ], [ %callN, %if.else.523 ] ret { ptr, i64 } %bp } @@ -9022,12 +9028,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.829, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.828, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.831, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.830, 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.827, i64 4 }, %if.then.525 ], [ %callN, %if.else.526 ] + %bp = phi { ptr, i64 } [ { ptr @str.829, i64 4 }, %if.then.525 ], [ %callN, %if.else.526 ] ret { ptr, i64 } %bp } @@ -9050,12 +9056,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.832, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.831, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.834, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.833, 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.830, i64 4 }, %if.then.528 ], [ %callN, %if.else.529 ] + %bp = phi { ptr, i64 } [ { ptr @str.832, i64 4 }, %if.then.528 ], [ %callN, %if.else.529 ] ret { ptr, i64 } %bp } @@ -9078,12 +9084,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.835, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.834, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.837, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.836, 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.833, i64 4 }, %if.then.531 ], [ %callN, %if.else.532 ] + %bp = phi { ptr, i64 } [ { ptr @str.835, i64 4 }, %if.then.531 ], [ %callN, %if.else.532 ] ret { ptr, i64 } %bp } @@ -9106,12 +9112,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.838, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.837, i64 5 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.840, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.839, 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.836, i64 4 }, %if.then.534 ], [ %callN, %if.else.535 ] + %bp = phi { ptr, i64 } [ { ptr @str.838, i64 4 }, %if.then.534 ], [ %callN, %if.else.535 ] ret { ptr, i64 } %bp } @@ -9134,12 +9140,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.841, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.840, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.843, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.842, 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.839, i64 4 }, %if.then.537 ], [ %callN, %if.else.538 ] + %bp = phi { ptr, i64 } [ { ptr @str.841, i64 4 }, %if.then.537 ], [ %callN, %if.else.538 ] ret { ptr, i64 } %bp } @@ -9162,12 +9168,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.844, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.843, i64 14 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.846, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.845, 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.842, i64 4 }, %if.then.540 ], [ %callN, %if.else.541 ] + %bp = phi { ptr, i64 } [ { ptr @str.844, i64 4 }, %if.then.540 ], [ %callN, %if.else.541 ] ret { ptr, i64 } %bp } @@ -9190,12 +9196,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.847, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.846, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.849, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.848, 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.845, i64 4 }, %if.then.543 ], [ %callN, %if.else.544 ] + %bp = phi { ptr, i64 } [ { ptr @str.847, i64 4 }, %if.then.543 ], [ %callN, %if.else.544 ] ret { ptr, i64 } %bp } @@ -9218,12 +9224,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.850, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.849, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.852, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.851, 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.848, i64 4 }, %if.then.546 ], [ %callN, %if.else.547 ] + %bp = phi { ptr, i64 } [ { ptr @str.850, i64 4 }, %if.then.546 ], [ %callN, %if.else.547 ] ret { ptr, i64 } %bp } @@ -9246,12 +9252,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.853, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.852, i64 4 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.855, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.854, 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.851, i64 4 }, %if.then.549 ], [ %callN, %if.else.550 ] + %bp = phi { ptr, i64 } [ { ptr @str.853, i64 4 }, %if.then.549 ], [ %callN, %if.else.550 ] ret { ptr, i64 } %bp } @@ -9274,12 +9280,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.856, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.855, i64 8 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.858, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.857, 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.854, i64 4 }, %if.then.552 ], [ %callN, %if.else.553 ] + %bp = phi { ptr, i64 } [ { ptr @str.856, i64 4 }, %if.then.552 ], [ %callN, %if.else.553 ] ret { ptr, i64 } %bp } @@ -9295,7 +9301,7 @@ entry: br i1 %lnot, label %if.then.561, label %if.merge.562 if.then.561: ; preds = %entry - ret { ptr, i64 } { ptr @str.857, i64 4 } + ret { ptr, i64 } { ptr @str.859, i64 4 } if.merge.562: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -9319,7 +9325,7 @@ entry: br i1 %lnot, label %if.then.563, label %if.merge.564 if.then.563: ; preds = %entry - ret { ptr, i64 } { ptr @str.858, i64 4 } + ret { ptr, i64 } { ptr @str.860, i64 4 } if.merge.564: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -9343,7 +9349,7 @@ entry: br i1 %lnot, label %if.then.565, label %if.merge.566 if.then.565: ; preds = %entry - ret { ptr, i64 } { ptr @str.859, i64 4 } + ret { ptr, i64 } { ptr @str.861, i64 4 } if.merge.566: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -9367,7 +9373,7 @@ entry: br i1 %lnot, label %if.then.567, label %if.merge.568 if.then.567: ; preds = %entry - ret { ptr, i64 } { ptr @str.860, i64 4 } + ret { ptr, i64 } { ptr @str.862, 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 b441dcd..28b7378 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [18 x i8] c"(s32, s32) -> s32\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 [19 x i8] c"*(s32, s32) -> s32\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 [20 x i8] c"**(s32, s32) -> s32\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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 17 }, { ptr, i64 } { ptr @tn.str.241, i64 12 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 18 }, { 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 19 }, { 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.328 = private unnamed_addr constant [14 x i8] c"fp(3,4) = {}\0A\00", align 1 -@str.329 = 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 [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 [1 x i8] zeroinitializer, align 1 +@str.331 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.332 = private unnamed_addr constant [14 x i8] c"fp(3,4) = {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.334 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.335 = private unnamed_addr constant [21 x i8] c"apply(add,5,6) = {}\0A\00", 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 +@str.337 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.338 = private unnamed_addr constant [21 x i8] c"apply(mul,5,6) = {}\0A\00", align 1 +@str.339 = private unnamed_addr constant [16 x i8] c"Source_Location\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 = private constant [5 x i8] c"file\00" -@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 }] +@fld.str.343 = private constant [5 x i8] c"line\00" +@fld.str.344 = private constant [4 x i8] c"col\00" +@fld.str.345 = 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.343, i64 4 }, { ptr, i64 } { ptr @fld.str.344, i64 3 }, { ptr, i64 } { ptr @fld.str.345, i64 4 }] +@str.346 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.347 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.348 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.349 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.350 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.351 = private constant [4 x i8] c"ctx\00" +@fld.str.352 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.353 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.354 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.351, i64 3 }, { ptr, i64 } { ptr @fld.str.352, i64 11 }, { ptr, i64 } { ptr @fld.str.353, i64 13 }] +@str.355 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.356 = private unnamed_addr constant [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.361 = private constant [5 x i8] c"data\00" +@field_names.362 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.360, i64 9 }, { ptr, i64 } { ptr @fld.str.361, i64 4 }] +@str.363 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.364 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.368 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.369 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.370 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.375 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.374, i64 11 }] +@str.376 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.377 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.382 = private constant [4 x i8] c"cap\00" +@field_names.383 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.381, i64 4 }, { 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.390 = private constant [10 x i8] c"end_index\00" +@fld.str.391 = private constant [7 x i8] c"parent\00" +@field_names.392 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.389, i64 5 }, { ptr, i64 } { ptr @fld.str.390, i64 9 }, { ptr, i64 } { ptr @fld.str.391, i64 6 }] +@str.393 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.394 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.399 = private constant [4 x i8] c"len\00" +@fld.str.400 = private constant [4 x i8] c"pos\00" +@field_names.401 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.398, i64 3 }, { ptr, i64 } { ptr @fld.str.399, i64 3 }, { ptr, i64 } { ptr @fld.str.400, i64 3 }] @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.403 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.407 = private constant [7 x i8] c"parent\00" +@fld.str.408 = private constant [12 x i8] c"alloc_count\00" +@fld.str.409 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.410 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.411 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.407, i64 6 }, { ptr, i64 } { ptr @fld.str.408, i64 11 }, { ptr, i64 } { ptr @fld.str.409, i64 13 }, { ptr, i64 } { ptr @fld.str.410, i64 17 }] +@str.412 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.413 = private unnamed_addr constant [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.418 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.417, i64 2 }] +@str.419 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.420 = private unnamed_addr constant [11 x i8] c"TraceFrame\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"file\00" +@fld.str.425 = private constant [5 x i8] c"line\00" +@fld.str.426 = private constant [4 x i8] c"col\00" +@fld.str.427 = private constant [5 x i8] c"func\00" +@fld.str.428 = private constant [10 x i8] c"line_text\00" +@field_names.429 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.424, i64 4 }, { ptr, i64 } { ptr @fld.str.425, i64 4 }, { ptr, i64 } { ptr @fld.str.426, i64 3 }, { ptr, i64 } { ptr @fld.str.427, i64 4 }, { ptr, i64 } { ptr @fld.str.428, i64 9 }] +@str.430 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.431 = private unnamed_addr constant [14 x i8] c"ProcessResult\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 [10 x i8] c"exit_code\00" +@fld.str.436 = private constant [7 x i8] c"stdout\00" +@field_names.437 = private constant [2 x { ptr, i64 }] [{ 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"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.444 = private constant [11 x i8] c"sin_family\00" +@fld.str.445 = private constant [9 x i8] c"sin_port\00" +@fld.str.446 = private constant [9 x i8] c"sin_addr\00" +@fld.str.447 = private constant [9 x i8] c"sin_zero\00" +@field_names.448 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.443, i64 7 }, { ptr, i64 } { ptr @fld.str.444, i64 10 }, { ptr, i64 } { ptr @fld.str.445, i64 8 }, { ptr, i64 } { ptr @fld.str.446, i64 8 }, { ptr, i64 } { ptr @fld.str.447, i64 8 }] +@str.449 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.450 = private unnamed_addr constant [6 x i8] c"Array\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"Object\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 [6 x i8] c"items\00" +@fld.str.464 = private constant [4 x i8] c"len\00" +@fld.str.465 = private constant [4 x i8] c"cap\00" +@field_names.466 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.463, i64 5 }, { 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 [7 x i8] c"Member\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"key\00" +@fld.str.473 = private constant [4 x i8] c"val\00" +@field_names.474 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.472, i64 3 }, { ptr, i64 } { ptr @fld.str.473, i64 3 }] +@str.475 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.476 = private unnamed_addr constant [5 x i8] c"Sink\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"dst\00" +@fld.str.481 = private constant [4 x i8] c"pos\00" +@fld.str.482 = private constant [5 x i8] c"file\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 4 }] +@str.484 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.485 = private unnamed_addr constant [7 x i8] c"Parser\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 +@fld.str.489 = private constant [4 x i8] c"src\00" +@fld.str.490 = private constant [4 x i8] c"pos\00" +@fld.str.491 = private constant [6 x i8] c"alloc\00" +@field_names.492 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.489, i64 3 }, { ptr, i64 } { ptr @fld.str.490, i64 3 }, { ptr, i64 } { ptr @fld.str.491, i64 5 }] +@str.493 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.494 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.495 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.496 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.497 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.498 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.499 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.500 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.505 = private constant [12 x i8] c"takes_value\00" +@fld.str.506 = private constant [9 x i8] c"required\00" +@field_names.507 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.504, i64 4 }, { ptr, i64 } { ptr @fld.str.505, i64 11 }, { ptr, i64 } { ptr @fld.str.506, i64 8 }] +@str.508 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.509 = private unnamed_addr constant [8 x i8] c"Command\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 [6 x i8] c"group\00" +@fld.str.514 = private constant [8 x i8] c"command\00" +@fld.str.515 = private constant [6 x i8] c"flags\00" +@field_names.516 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.513, i64 5 }, { ptr, i64 } { ptr @fld.str.514, i64 7 }, { 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 [10 x i8] c"FlagValue\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 [4 x i8] c"set\00" +@fld.str.523 = private constant [6 x i8] c"value\00" +@field_names.524 = private constant [2 x { ptr, i64 }] [{ 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 [5 x i8] c"Diag\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"index\00" +@fld.str.531 = private constant [6 x i8] c"token\00" +@field_names.532 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.530, i64 5 }, { ptr, i64 } { ptr @fld.str.531, i64 5 }] +@str.533 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.534 = private unnamed_addr constant [7 x i8] c"Parsed\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 [6 x i8] c"group\00" +@fld.str.539 = private constant [8 x i8] c"command\00" +@fld.str.540 = private constant [10 x i8] c"cmd_index\00" +@fld.str.541 = private constant [5 x i8] c"json\00" +@fld.str.542 = private constant [5 x i8] c"rest\00" +@fld.str.543 = private constant [5 x i8] c"spec\00" +@fld.str.544 = private constant [7 x i8] c"values\00" +@field_names.545 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.538, i64 5 }, { ptr, i64 } { ptr @fld.str.539, i64 7 }, { ptr, i64 } { ptr @fld.str.540, i64 9 }, { ptr, i64 } { ptr @fld.str.541, i64 4 }, { ptr, i64 } { ptr @fld.str.542, i64 4 }, { ptr, i64 } { ptr @fld.str.543, i64 4 }, { ptr, i64 } { ptr @fld.str.544, i64 6 }] +@str.546 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.547 = private unnamed_addr constant [7 x i8] c"Sha256\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 [2 x i8] c"h\00" +@fld.str.552 = private constant [4 x i8] c"buf\00" +@fld.str.553 = private constant [8 x i8] c"buf_len\00" +@fld.str.554 = private constant [10 x i8] c"total_len\00" +@field_names.555 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.551, i64 1 }, { ptr, i64 } { ptr @fld.str.552, i64 3 }, { ptr, i64 } { ptr @fld.str.553, i64 7 }, { ptr, i64 } { ptr @fld.str.554, i64 9 }] +@str.556 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.557 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.558 = private constant [5 x i8] c"read\00" +@fld.str.559 = private constant [6 x i8] c"write\00" +@fld.str.560 = private constant [7 x i8] c"append\00" +@fld.str.561 = private constant [11 x i8] c"read_write\00" +@field_names.562 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.558, i64 4 }, { ptr, i64 } { ptr @fld.str.559, i64 5 }, { ptr, i64 } { ptr @fld.str.560, i64 6 }, { ptr, i64 } { ptr @fld.str.561, i64 10 }] +@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 [4 x i8] c"set\00" +@fld.str.567 = private constant [8 x i8] c"current\00" +@fld.str.568 = private constant [4 x i8] c"end\00" +@field_names.569 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.566, i64 3 }, { ptr, i64 } { ptr @fld.str.567, i64 7 }, { ptr, i64 } { ptr @fld.str.568, i64 3 }] +@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"null_\00" +@fld.str.574 = private constant [6 x i8] c"bool_\00" +@fld.str.575 = private constant [5 x i8] c"int_\00" +@fld.str.576 = private constant [4 x i8] c"str\00" +@fld.str.577 = private constant [6 x i8] c"array\00" +@fld.str.578 = private constant [7 x i8] c"object\00" +@field_names.579 = private constant [6 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 4 }, { ptr, i64 } { ptr @fld.str.576, i64 3 }, { ptr, i64 } { ptr @fld.str.577, i64 5 }, { ptr, i64 } { ptr @fld.str.578, i64 6 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.583 = private constant [6 x i8] c"macos\00" +@fld.str.584 = private constant [6 x i8] c"linux\00" +@fld.str.585 = private constant [8 x i8] c"windows\00" +@fld.str.586 = private constant [5 x i8] c"wasm\00" +@fld.str.587 = private constant [4 x i8] c"ios\00" +@fld.str.588 = private constant [8 x i8] c"android\00" +@fld.str.589 = private constant [8 x i8] c"unknown\00" +@field_names.590 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.583, i64 5 }, { ptr, i64 } { ptr @fld.str.584, i64 5 }, { ptr, i64 } { ptr @fld.str.585, i64 7 }, { ptr, i64 } { ptr @fld.str.586, i64 4 }, { ptr, i64 } { ptr @fld.str.587, i64 3 }, { ptr, i64 } { ptr @fld.str.588, i64 7 }, { 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 +@fld.str.594 = private constant [8 x i8] c"aarch64\00" +@fld.str.595 = private constant [7 x i8] c"x86_64\00" +@fld.str.596 = private constant [7 x i8] c"wasm32\00" +@fld.str.597 = private constant [7 x i8] c"wasm64\00" +@fld.str.598 = private constant [8 x i8] c"unknown\00" +@field_names.599 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.594, i64 7 }, { ptr, i64 } { ptr @fld.str.595, i64 6 }, { ptr, i64 } { ptr @fld.str.596, i64 6 }, { ptr, i64 } { ptr @fld.str.597, i64 6 }, { ptr, i64 } { ptr @fld.str.598, i64 7 }] +@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 [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 [5 x i8] c"null\00", align 1 +@str.636 = private unnamed_addr constant [6 x i8] c"*void\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 [12 x i8] c"*CAllocator\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 [5 x i8] c"*GPA\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"*ArenaChunk\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 [7 x i8] c"*Arena\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"[*]u8\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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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 [6 x i8] c"*File\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 [4 x i8] c"*u8\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 [5 x i8] c"*s32\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 [10 x i8] c"*SockAddr\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"*u32\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 [9 x i8] c"[*]Value\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 [7 x i8] c"*Array\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 [10 x i8] c"[*]Member\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 [8 x i8] c"*Object\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 [6 x i8] c"*Sink\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"*Parser\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 [5 x i8] c"*s64\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"*Parsed\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 [6 x i8] c"*Diag\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"*Sha256\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 [13 x i8] c"**CAllocator\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 [7 x i8] c"**void\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"*function\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 [8 x i8] c"*string\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 [8 x i8] c"*[1]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 [7 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 [6 x i8] c"*bool\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"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 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -624,85 +624,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -845,7 +767,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -972,7 +894,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1306,7 +1228,7 @@ entry: br i1 %icmp, label %if.then.369, label %if.merge.370 if.then.369: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.370: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1456,7 +1378,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1483,12 +1405,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1513,25 +1435,25 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 100, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1567,7 +1489,7 @@ match.merge.37: ; preds = %dispatch.merge.472, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1612,12 +1534,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1668,7 +1590,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.264 [ - i64 35, label %dispatch.case.265 + i64 22, label %dispatch.case.265 i64 81, label %dispatch.case.266 i64 87, label %dispatch.case.267 i64 88, label %dispatch.case.268 @@ -1681,7 +1603,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.302 [ - i64 36, label %dispatch.case.303 + i64 23, label %dispatch.case.303 i64 60, label %dispatch.case.304 i64 77, label %dispatch.case.305 i64 85, label %dispatch.case.306 @@ -1694,13 +1616,13 @@ 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 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 - i64 33, label %dispatch.case.342 + i64 25, label %dispatch.case.336 + i64 27, label %dispatch.case.337 + i64 29, label %dispatch.case.338 + i64 31, label %dispatch.case.339 + i64 32, label %dispatch.case.340 + i64 34, label %dispatch.case.341 + i64 36, label %dispatch.case.342 i64 40, label %dispatch.case.343 i64 44, label %dispatch.case.344 i64 47, label %dispatch.case.345 @@ -1794,7 +1716,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.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1816,56 +1738,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2003,7 +1925,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.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.246 dispatch.case.248: ; preds = %match.arm.44 @@ -2044,7 +1966,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.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.263 dispatch.case.265: ; preds = %match.arm.47 @@ -2101,7 +2023,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.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.301 dispatch.case.303: ; preds = %match.arm.48 @@ -2150,7 +2072,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.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.333 dispatch.case.335: ; preds = %match.arm.49 @@ -2376,7 +2298,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.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.472 dispatch.case.474: ; preds = %match.arm.50 @@ -2418,7 +2340,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 @@ -2514,7 +2436,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.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 @@ -2522,7 +2444,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.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 @@ -2532,13 +2454,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.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.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.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 @@ -2546,7 +2468,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.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 @@ -2560,7 +2482,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.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 @@ -2568,7 +2490,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.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 @@ -2579,7 +2501,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 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 @@ -2636,7 +2558,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.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 @@ -2644,7 +2566,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.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 @@ -2655,7 +2577,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 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 @@ -2675,7 +2597,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.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 @@ -2683,7 +2605,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.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 @@ -2694,7 +2616,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 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.36 @@ -2704,67 +2626,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2940,166 +2946,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3297,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.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3384,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.95(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.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3513,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @add(ptr %0, i32 %1, i32 %2) #0 { @@ -3594,7 +3600,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.328, i64 13 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.330, 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 @@ -3610,7 +3616,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.329, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.331, 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) @@ -3638,7 +3644,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.330, i64 13 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.332, i64 13 }) ret { ptr, i64 } %call } @@ -3646,7 +3652,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.331, i64 20 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.333, 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 @@ -3662,7 +3668,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 { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 17) @@ -3690,7 +3696,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.333, i64 20 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.335, i64 20 }) ret { ptr, i64 } %call } @@ -3698,7 +3704,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.334, i64 20 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.336, 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 @@ -3714,7 +3720,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.335, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.337, 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) @@ -3742,7 +3748,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.336, i64 20 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.338, i64 20 }) ret { ptr, i64 } %call } @@ -3753,7 +3759,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.337, i64 15 }, { ptr, i64 } { ptr @str.338, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.339, i64 15 }, { 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 @@ -3772,12 +3778,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.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.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.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.125 @@ -3789,7 +3795,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.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 { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3846,7 +3852,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.345, i64 9 }, { ptr, i64 } { ptr @str.346, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.347, i64 9 }, { ptr, i64 } { ptr @str.348, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3865,24 +3871,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.347, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, 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.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 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 [3 x { ptr, i64 }], ptr @field_names.352, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -3926,20 +3932,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.354, i64 10 }, { ptr, i64 } { ptr @str.355, i64 1 }) + %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.356, i64 7 }, { 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.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, 2 br i1 %icmp, label %while.body.132, label %while.exit.133 while.body.132: ; preds = %while.hdr.131 @@ -3949,24 +3956,102 @@ 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.356, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.358, 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 }) + %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.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.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.359, 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 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 + +fv.default: ; preds = %if.merge.135 + br label %fv.merge + +fv.case: ; preds = %if.merge.135 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.135 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.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.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.366, 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.367, 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.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 %alloca, align 1 @@ -3977,7 +4062,7 @@ if.merge.135: ; preds = %if.then.134, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 + br label %while.hdr.136 } ; Function Attrs: nounwind @@ -3985,43 +4070,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.370, i64 3 }, { 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.136 + br label %while.hdr.141 -while.hdr.136: ; preds = %fv.merge, %entry +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.137, label %while.exit.138 + br i1 %icmp, label %while.body.142, label %while.exit.143 -while.body.137: ; preds = %while.hdr.136 +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.139, label %if.merge.140 + br i1 %icmpN, label %if.then.144, label %if.merge.145 -while.exit.138: ; preds = %while.hdr.136 +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.362, 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.139: ; preds = %while.body.137 +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.363, 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.140 + br label %if.merge.145 -if.merge.140: ; preds = %if.then.139, %while.body.137 +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.365, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.375, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.376, 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 @@ -4038,12 +4123,12 @@ 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 + br label %while.hdr.141 -fv.default: ; preds = %if.merge.140 +fv.default: ; preds = %if.merge.145 br label %fv.merge -fv.case: ; preds = %if.merge.140 +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 @@ -4054,43 +4139,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.377, i64 10 }, { ptr, i64 } { ptr @str.378, 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 + br label %while.hdr.146 -while.hdr.141: ; preds = %fv.merge, %entry +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.142, label %while.exit.143 + br i1 %icmp, label %while.body.147, label %while.exit.148 -while.body.142: ; preds = %while.hdr.141 +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.144, label %if.merge.145 + br i1 %icmpN, label %if.then.149, label %if.merge.150 -while.exit.143: ; preds = %while.hdr.141 +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.379, i64 1 }) ret { ptr, i64 } %callN -if.then.144: ; preds = %while.body.142 +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.380, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 + br label %if.merge.150 -if.merge.145: ; preds = %if.then.144, %while.body.142 +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.373, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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.374, 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 %alloca, align 8 @@ -4108,18 +4193,18 @@ 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.141 + br label %while.hdr.146 -fv.default: ; preds = %if.merge.145 +fv.default: ; preds = %if.merge.150 br label %fv.merge -fv.case: ; preds = %if.merge.145 +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 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.145 +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 @@ -4131,91 +4216,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.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 - 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.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.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.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.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 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.146 - -fv.default: ; preds = %if.merge.150 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.150 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.384, i64 8 }, { ptr, i64 } { ptr @str.385, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 5 }, { 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 @@ -4234,27 +4235,27 @@ 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.386, 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.387, 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.391, 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.392, 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 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4276,29 +4277,30 @@ fv.default: ; preds = %if.merge.155 br label %fv.merge fv.case: ; preds = %if.merge.155 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.155 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.155 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.393, i64 17 }, { ptr, i64 } { ptr @str.394, i64 1 }) + %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.394, i64 8 }, { 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 @@ -4307,7 +4309,7 @@ entry: while.hdr.156: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.157, label %while.exit.158 while.body.157: ; preds = %while.hdr.156 @@ -4317,19 +4319,19 @@ 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.395, 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.396, 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.401, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4337,17 +4339,16 @@ if.merge.160: ; preds = %if.then.159, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4360,35 +4361,29 @@ fv.default: ; preds = %if.merge.160 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.160 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.160 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.403, i64 7 }, { ptr, i64 } { ptr @str.404, i64 1 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.403, i64 17 }, { 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 @@ -4397,7 +4392,7 @@ entry: while.hdr.161: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.162, label %while.exit.163 while.body.162: ; preds = %while.hdr.161 @@ -4419,23 +4414,25 @@ if.then.164: ; preds = %while.body.162 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.409, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4448,16 +4445,25 @@ fv.default: ; preds = %if.merge.165 br label %fv.merge fv.case: ; preds = %if.merge.165 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.165 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.165 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4466,7 +4472,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.411, i64 4 }, { ptr, i64 } { ptr @str.412, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.413, i64 4 }, { 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 @@ -4485,24 +4491,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.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.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.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.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.416, i64 0, i64 %loadN + %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.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 { i32 }, ptr %alloca, align 4 @@ -4539,7 +4545,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.418, i64 10 }, { ptr, i64 } { ptr @str.419, i64 1 }) + %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 @@ -4558,24 +4564,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.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.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.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.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.427, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4641,7 +4647,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.429, i64 13 }, { ptr, i64 } { ptr @str.430, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.431, i64 13 }, { 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 @@ -4660,24 +4666,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.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.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.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.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.435, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4719,7 +4725,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.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 @@ -4738,24 +4744,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.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.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.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.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.446, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.448, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4816,7 +4822,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.448, i64 5 }, { ptr, i64 } { ptr @str.449, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.450, i64 5 }, { ptr, i64 } { ptr @str.451, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4835,24 +4841,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.450, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.452, 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.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 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.455, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.457, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.456, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, 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 @@ -4898,7 +4904,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.457, i64 6 }, { ptr, i64 } { ptr @str.458, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.459, i64 6 }, { ptr, i64 } { ptr @str.460, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4917,24 +4923,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.459, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.461, 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.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 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.464, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 }, ptr %alloca, align 8 @@ -4982,7 +4988,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.466, i64 6 }, { ptr, i64 } { ptr @str.467, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.468, i64 6 }, { 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 @@ -5001,24 +5007,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.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.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.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.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.472, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.474, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5062,7 +5068,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.474, i64 4 }, { ptr, i64 } { ptr @str.475, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.476, i64 4 }, { ptr, i64 } { ptr @str.477, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5081,24 +5087,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.476, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, 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.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 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.481, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.483, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5148,7 +5154,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.483, i64 6 }, { ptr, i64 } { ptr @str.484, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.485, i64 6 }, { ptr, i64 } { ptr @str.486, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5167,24 +5173,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.485, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.487, 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.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 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.490, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.492, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5233,7 +5239,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.492, i64 12 }, { ptr, i64 } { ptr @str.493, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.494, i64 12 }, { ptr, i64 } { ptr @str.495, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5252,24 +5258,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.494, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, 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.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 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.496, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 %alloca, align 1 @@ -5289,7 +5295,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.498, i64 8 }, { ptr, i64 } { ptr @str.499, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.500, i64 8 }, { 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 @@ -5308,24 +5314,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.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.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.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.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.505, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.507, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.506, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, 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 @@ -5377,7 +5383,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.507, i64 7 }, { ptr, i64 } { ptr @str.508, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.509, i64 7 }, { ptr, i64 } { ptr @str.510, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5396,24 +5402,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.509, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, 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.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 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.514, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5465,7 +5471,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.516, i64 9 }, { ptr, i64 } { ptr @str.517, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.518, i64 9 }, { 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 @@ -5484,24 +5490,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.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.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.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.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.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 { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5544,7 +5550,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.524, i64 4 }, { ptr, i64 } { ptr @str.525, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.526, i64 4 }, { 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 @@ -5563,24 +5569,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.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.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.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.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.530, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5626,7 +5632,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.532, i64 6 }, { ptr, i64 } { ptr @str.533, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.534, i64 6 }, { 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 @@ -5645,24 +5651,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.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.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.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.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.543, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 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 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5719,7 +5725,7 @@ fv.case28: ; preds = %if.merge.240 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.240 @@ -5744,7 +5750,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.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 @@ -5763,24 +5769,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.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.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.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.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.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 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5839,9 +5845,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.560, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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.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 @@ -5860,8 +5866,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.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.254 @@ -5880,9 +5886,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.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 - %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, ptr %alloca, align 8 @@ -5901,8 +5907,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.256 @@ -5932,9 +5938,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.577, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.579, 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.570, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.572, 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 @@ -5951,8 +5957,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.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 } { ptr @str.581, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.580, 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 @@ -6030,9 +6036,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.588, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.590, 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.580, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.582, 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 @@ -6051,8 +6057,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.260 @@ -6071,9 +6077,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.597, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.599, 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.591, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.593, 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 @@ -6092,8 +6098,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.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 } { ptr @str.601, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.600, 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 @@ -6110,7 +6116,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.600, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.602, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.271 @@ -6127,12 +6133,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.601, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, 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.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 br label %if.merge.275 @@ -6161,7 +6167,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.603, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.605, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.276 @@ -6178,12 +6184,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.604, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, 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.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 br label %if.merge.280 @@ -6213,7 +6219,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.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.281 @@ -6230,12 +6236,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.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.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.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.285 @@ -6263,7 +6269,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.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.286 @@ -6280,12 +6286,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.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.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.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.290 @@ -6314,7 +6320,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.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.291 @@ -6331,12 +6337,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.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.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.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.295 @@ -6365,7 +6371,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.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.296 @@ -6382,12 +6388,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.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.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.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.300 @@ -6417,7 +6423,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.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.308 @@ -6436,12 +6442,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.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.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.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.312 @@ -6470,7 +6476,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.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.313 @@ -6489,12 +6495,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.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.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.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.317 @@ -6523,7 +6529,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.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.318 @@ -6542,12 +6548,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.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.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.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.322 @@ -6577,7 +6583,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.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.323 @@ -6596,12 +6602,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.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.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.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.327 @@ -6631,7 +6637,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.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.328 @@ -6650,12 +6656,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.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.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.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.332 @@ -6697,12 +6703,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.635, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, i64 5 }, { ptr, i64 } %callN) + %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 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.633, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] + %bp = phi { ptr, i64 } [ { ptr @str.635, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] ret { ptr, i64 } %bp } @@ -6725,12 +6731,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.638, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 11 }, { ptr, i64 } %callN) + %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 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.636, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] + %bp = phi { ptr, i64 } [ { ptr @str.638, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] ret { ptr, i64 } %bp } @@ -6753,12 +6759,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.641, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 4 }, { 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 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.639, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] + %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] ret { ptr, i64 } %bp } @@ -6781,12 +6787,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 } @@ -6809,12 +6815,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 6 }, { 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 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.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 } @@ -6836,12 +6842,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 5 }, { 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 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.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 } @@ -6864,12 +6870,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 9 }, { 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 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.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 } @@ -6892,12 +6898,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 18 }, { 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 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.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 } @@ -6920,12 +6926,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 5 }, { 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 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.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 } @@ -6948,12 +6954,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 3 }, { 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 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.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 } @@ -6976,12 +6982,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 4 }, { 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 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.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 } @@ -7004,12 +7010,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 9 }, { 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 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.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 } @@ -7032,12 +7038,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 } @@ -7059,12 +7065,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 8 }, { 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 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.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 } @@ -7087,12 +7093,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 6 }, { 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 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.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 } @@ -7114,12 +7120,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 9 }, { 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 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.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 } @@ -7142,12 +7148,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 7 }, { 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 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.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 } @@ -7170,12 +7176,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 5 }, { 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 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.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 } @@ -7198,12 +7204,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 } @@ -7226,12 +7232,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 4 }, { 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 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.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 } @@ -7254,12 +7260,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 } @@ -7282,12 +7288,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 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.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 } @@ -7310,12 +7316,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 } @@ -7338,12 +7344,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 12 }, { 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 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.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 } @@ -7366,12 +7372,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 6 }, { 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 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.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 } @@ -7394,12 +7400,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 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.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 } @@ -7422,12 +7428,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 7 }, { 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 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.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 } @@ -7450,12 +7456,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 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.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 } @@ -7478,12 +7484,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 } @@ -7506,12 +7512,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 6 }, { 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 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.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 } @@ -7534,12 +7540,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 5 }, { 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 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.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 } @@ -7555,7 +7561,7 @@ entry: br i1 %lnot, label %if.then.478, label %if.merge.479 if.then.478: ; preds = %entry - ret { ptr, i64 } { ptr @str.726, i64 4 } + ret { ptr, i64 } { ptr @str.728, i64 4 } if.merge.479: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7579,7 +7585,7 @@ entry: br i1 %lnot, label %if.then.480, label %if.merge.481 if.then.480: ; preds = %entry - ret { ptr, i64 } { ptr @str.727, i64 4 } + ret { ptr, i64 } { ptr @str.729, i64 4 } if.merge.481: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7603,7 +7609,7 @@ entry: br i1 %lnot, label %if.then.482, label %if.merge.483 if.then.482: ; preds = %entry - ret { ptr, i64 } { ptr @str.728, i64 4 } + ret { ptr, i64 } { ptr @str.730, i64 4 } if.merge.483: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7627,7 +7633,7 @@ entry: br i1 %lnot, label %if.then.484, label %if.merge.485 if.then.484: ; preds = %entry - ret { ptr, i64 } { ptr @str.729, i64 4 } + ret { ptr, i64 } { ptr @str.731, 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 cbf22e4..022e027 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [9 x i8] c"Lerpable\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 [8 x i8] c"Context\00" +@tn.str.170 = private constant [7 x i8] c"[4]s64\00" +@tn.str.171 = private constant [9 x i8] c"[]string\00" +@tn.str.172 = private constant [11 x i8] c"CAllocator\00" +@tn.str.173 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.174 = private constant [4 x i8] c"GPA\00" +@tn.str.175 = private constant [5 x i8] c"*GPA\00" +@tn.str.176 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.177 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.178 = private constant [6 x i8] c"Arena\00" +@tn.str.179 = private constant [7 x i8] c"*Arena\00" +@tn.str.180 = private constant [6 x i8] c"[*]u8\00" +@tn.str.181 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.182 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.183 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.184 = private constant [19 x i8] c"*TrackingAllocator\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 [13 x i8] c"**CAllocator\00" +@tn.str.242 = private constant [7 x i8] c"**void\00" +@tn.str.243 = private constant [5 x i8] c"*f32\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 [6 x i8] c"**f32\00" +@tn.str.252 = private constant [10 x i8] c"*Lerpable\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 [9 x i8] c"**string\00" +@tn.str.302 = private constant [6 x i8] c"**Any\00" +@tn.str.303 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.304 = private constant [8 x i8] c"**[]Any\00" +@tn.str.305 = private constant [7 x i8] c"**bool\00" +@tn.str.306 = private constant [7 x i8] c"***f32\00" +@tn.str.307 = private constant [11 x i8] c"**Lerpable\00" +@tn.str.308 = private constant [7 x i8] c"*?File\00" +@tn.str.309 = private constant [9 x i8] c"*?string\00" +@tn.str.310 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.311 = 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.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 8 }, { ptr, i64 } { ptr @tn.str.167, i64 15 }, { ptr, i64 } { ptr @tn.str.168, i64 9 }, { ptr, i64 } { ptr @tn.str.169, i64 7 }, { ptr, i64 } { ptr @tn.str.170, i64 6 }, { ptr, i64 } { ptr @tn.str.171, i64 8 }, { ptr, i64 } { ptr @tn.str.172, i64 10 }, { ptr, i64 } { ptr @tn.str.173, i64 11 }, { ptr, i64 } { ptr @tn.str.174, i64 3 }, { ptr, i64 } { ptr @tn.str.175, i64 4 }, { ptr, i64 } { ptr @tn.str.176, i64 10 }, { ptr, i64 } { ptr @tn.str.177, i64 11 }, { ptr, i64 } { ptr @tn.str.178, i64 5 }, { ptr, i64 } { ptr @tn.str.179, i64 6 }, { ptr, i64 } { ptr @tn.str.180, i64 5 }, { ptr, i64 } { ptr @tn.str.181, i64 8 }, { ptr, i64 } { ptr @tn.str.182, i64 9 }, { ptr, i64 } { ptr @tn.str.183, i64 17 }, { ptr, i64 } { ptr @tn.str.184, i64 18 }, { 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 12 }, { ptr, i64 } { ptr @tn.str.242, i64 6 }, { ptr, i64 } { ptr @tn.str.243, i64 4 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.252, i64 9 }, { 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 8 }, { ptr, i64 } { ptr @tn.str.302, i64 5 }, { ptr, i64 } { ptr @tn.str.303, i64 8 }, { ptr, i64 } { ptr @tn.str.304, i64 7 }, { ptr, i64 } { ptr @tn.str.305, i64 6 }, { ptr, i64 } { ptr @tn.str.306, i64 6 }, { ptr, i64 } { ptr @tn.str.307, i64 10 }, { ptr, i64 } { ptr @tn.str.308, i64 6 }, { ptr, i64 } { ptr @tn.str.309, i64 8 }, { ptr, i64 } { ptr @tn.str.310, i64 15 }, { ptr, i64 } { ptr @tn.str.311, i64 8 }] @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 [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 [1 x i8] zeroinitializer, align 1 +@str.316 = 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 [15 x i8] c"result := \22\22; \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 [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.323 = private unnamed_addr constant [6 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 [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.331 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.332 = private unnamed_addr constant [5 x i8] c")); \00", 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 [1 x i8] zeroinitializer, align 1 +@str.334 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.335 = private unnamed_addr constant [23 x i8] c"lerp(0, 10, 0.5) = {}\0A\00", 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 +@str.337 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.338 = private unnamed_addr constant [24 x i8] c"lerp(0, 10, 0.25) = {}\0A\00", align 1 +@str.339 = private unnamed_addr constant [9 x i8] c"Lerpable\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 = private constant [4 x i8] c"ctx\00" -@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 }] +@fld.str.343 = 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.343, i64 4 }] +@str.344 = private unnamed_addr constant [3 x i8] c": \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.349 = private constant [5 x i8] c"file\00" +@fld.str.350 = private constant [5 x i8] c"line\00" +@fld.str.351 = private constant [4 x i8] c"col\00" +@fld.str.352 = private constant [5 x i8] c"func\00" +@field_names.353 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.349, i64 4 }, { ptr, i64 } { ptr @fld.str.350, i64 4 }, { ptr, i64 } { ptr @fld.str.351, i64 3 }, { ptr, i64 } { ptr @fld.str.352, i64 4 }] +@str.354 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.355 = private unnamed_addr constant [10 x i8] c"Allocator\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 [4 x i8] c"ctx\00" +@fld.str.360 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.361 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.362 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.359, i64 3 }, { ptr, i64 } { ptr @fld.str.360, i64 11 }, { ptr, i64 } { ptr @fld.str.361, i64 13 }] +@str.363 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.364 = private unnamed_addr constant [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.369 = private constant [5 x i8] c"data\00" +@field_names.370 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.368, i64 9 }, { ptr, i64 } { ptr @fld.str.369, i64 4 }] +@str.371 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.372 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.376 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.377 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.378 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.383 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.382, i64 11 }] +@str.384 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.385 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.390 = private constant [4 x i8] c"cap\00" +@field_names.391 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.389, i64 4 }, { 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.398 = private constant [10 x i8] c"end_index\00" +@fld.str.399 = private constant [7 x i8] c"parent\00" +@field_names.400 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.397, i64 5 }, { ptr, i64 } { ptr @fld.str.398, i64 9 }, { ptr, i64 } { ptr @fld.str.399, i64 6 }] +@str.401 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.402 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.407 = private constant [4 x i8] c"len\00" +@fld.str.408 = private constant [4 x i8] c"pos\00" +@field_names.409 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.406, i64 3 }, { ptr, i64 } { ptr @fld.str.407, i64 3 }, { 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 [8 x i8] c"Context\00", align 1 +@str.411 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.415 = private constant [7 x i8] c"parent\00" +@fld.str.416 = private constant [12 x i8] c"alloc_count\00" +@fld.str.417 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.418 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.419 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.415, i64 6 }, { ptr, i64 } { ptr @fld.str.416, i64 11 }, { ptr, i64 } { ptr @fld.str.417, i64 13 }, { ptr, i64 } { ptr @fld.str.418, i64 17 }] +@str.420 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.421 = private unnamed_addr constant [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.426 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.425, i64 2 }] +@str.427 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.428 = private unnamed_addr constant [11 x i8] c"TraceFrame\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 [5 x i8] c"file\00" +@fld.str.433 = private constant [5 x i8] c"line\00" +@fld.str.434 = private constant [4 x i8] c"col\00" +@fld.str.435 = private constant [5 x i8] c"func\00" +@fld.str.436 = private constant [10 x i8] c"line_text\00" +@field_names.437 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.432, i64 4 }, { ptr, i64 } { ptr @fld.str.433, i64 4 }, { ptr, i64 } { ptr @fld.str.434, i64 3 }, { ptr, i64 } { ptr @fld.str.435, i64 4 }, { ptr, i64 } { ptr @fld.str.436, i64 9 }] +@str.438 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.439 = private unnamed_addr constant [14 x i8] c"ProcessResult\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"exit_code\00" +@fld.str.444 = private constant [7 x i8] c"stdout\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 6 }] +@str.446 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.447 = private unnamed_addr constant [9 x i8] c"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.452 = private constant [11 x i8] c"sin_family\00" +@fld.str.453 = private constant [9 x i8] c"sin_port\00" +@fld.str.454 = private constant [9 x i8] c"sin_addr\00" +@fld.str.455 = private constant [9 x i8] c"sin_zero\00" +@field_names.456 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.451, i64 7 }, { ptr, i64 } { ptr @fld.str.452, i64 10 }, { ptr, i64 } { ptr @fld.str.453, i64 8 }, { ptr, i64 } { ptr @fld.str.454, i64 8 }, { ptr, i64 } { ptr @fld.str.455, i64 8 }] +@str.457 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.458 = private unnamed_addr constant [6 x i8] c"Array\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"Object\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 [6 x i8] c"items\00" +@fld.str.472 = private constant [4 x i8] c"len\00" +@fld.str.473 = private constant [4 x i8] c"cap\00" +@field_names.474 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.471, i64 5 }, { ptr, i64 } { ptr @fld.str.472, i64 3 }, { ptr, i64 } { ptr @fld.str.473, i64 3 }] +@str.475 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.476 = private unnamed_addr constant [7 x i8] c"Member\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"key\00" +@fld.str.481 = private constant [4 x i8] c"val\00" +@field_names.482 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.480, i64 3 }, { ptr, i64 } { ptr @fld.str.481, i64 3 }] +@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.484 = private unnamed_addr constant [5 x i8] c"Sink\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"dst\00" +@fld.str.489 = private constant [4 x i8] c"pos\00" +@fld.str.490 = private constant [5 x i8] c"file\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 4 }] +@str.492 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.493 = private unnamed_addr constant [7 x i8] c"Parser\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 [4 x i8] c"src\00" +@fld.str.498 = private constant [4 x i8] c"pos\00" +@fld.str.499 = private constant [6 x i8] c"alloc\00" +@field_names.500 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.497, i64 3 }, { ptr, i64 } { ptr @fld.str.498, i64 3 }, { ptr, i64 } { ptr @fld.str.499, i64 5 }] +@str.501 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.502 = private unnamed_addr constant [13 x i8] c"BuildOptions\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 +@field_names.506 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.508 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.513 = private constant [12 x i8] c"takes_value\00" +@fld.str.514 = private constant [9 x i8] c"required\00" +@field_names.515 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.512, i64 4 }, { ptr, i64 } { ptr @fld.str.513, i64 11 }, { ptr, i64 } { ptr @fld.str.514, i64 8 }] +@str.516 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.517 = private unnamed_addr constant [8 x i8] c"Command\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"group\00" +@fld.str.522 = private constant [8 x i8] c"command\00" +@fld.str.523 = private constant [6 x i8] c"flags\00" +@field_names.524 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.521, i64 5 }, { ptr, i64 } { ptr @fld.str.522, i64 7 }, { 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 [10 x i8] c"FlagValue\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"set\00" +@fld.str.531 = private constant [6 x i8] c"value\00" +@field_names.532 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.530, i64 3 }, { ptr, i64 } { ptr @fld.str.531, i64 5 }] +@str.533 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.534 = private unnamed_addr constant [5 x i8] c"Diag\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 [6 x i8] c"index\00" +@fld.str.539 = private constant [6 x i8] c"token\00" +@field_names.540 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.538, i64 5 }, { ptr, i64 } { ptr @fld.str.539, i64 5 }] +@str.541 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.542 = private unnamed_addr constant [7 x i8] c"Parsed\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 [6 x i8] c"group\00" +@fld.str.547 = private constant [8 x i8] c"command\00" +@fld.str.548 = private constant [10 x i8] c"cmd_index\00" +@fld.str.549 = private constant [5 x i8] c"json\00" +@fld.str.550 = private constant [5 x i8] c"rest\00" +@fld.str.551 = private constant [5 x i8] c"spec\00" +@fld.str.552 = private constant [7 x i8] c"values\00" +@field_names.553 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.546, i64 5 }, { ptr, i64 } { ptr @fld.str.547, i64 7 }, { ptr, i64 } { ptr @fld.str.548, i64 9 }, { ptr, i64 } { ptr @fld.str.549, i64 4 }, { ptr, i64 } { ptr @fld.str.550, i64 4 }, { ptr, i64 } { ptr @fld.str.551, i64 4 }, { ptr, i64 } { ptr @fld.str.552, i64 6 }] +@str.554 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.555 = private unnamed_addr constant [7 x i8] c"Sha256\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 +@str.558 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.559 = private constant [2 x i8] c"h\00" +@fld.str.560 = private constant [4 x i8] c"buf\00" +@fld.str.561 = private constant [8 x i8] c"buf_len\00" +@fld.str.562 = private constant [10 x i8] c"total_len\00" +@field_names.563 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.559, i64 1 }, { ptr, i64 } { ptr @fld.str.560, i64 3 }, { ptr, i64 } { ptr @fld.str.561, i64 7 }, { ptr, i64 } { ptr @fld.str.562, i64 9 }] +@str.564 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.565 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.566 = private constant [5 x i8] c"read\00" +@fld.str.567 = private constant [6 x i8] c"write\00" +@fld.str.568 = private constant [7 x i8] c"append\00" +@fld.str.569 = private constant [11 x i8] c"read_write\00" +@field_names.570 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.566, i64 4 }, { ptr, i64 } { ptr @fld.str.567, i64 5 }, { ptr, i64 } { ptr @fld.str.568, i64 6 }, { ptr, i64 } { ptr @fld.str.569, i64 10 }] +@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 [4 x i8] c"set\00" +@fld.str.575 = private constant [8 x i8] c"current\00" +@fld.str.576 = private constant [4 x i8] c"end\00" +@field_names.577 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.574, i64 3 }, { ptr, i64 } { ptr @fld.str.575, i64 7 }, { ptr, i64 } { ptr @fld.str.576, i64 3 }] +@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"null_\00" +@fld.str.582 = private constant [6 x i8] c"bool_\00" +@fld.str.583 = private constant [5 x i8] c"int_\00" +@fld.str.584 = private constant [4 x i8] c"str\00" +@fld.str.585 = private constant [6 x i8] c"array\00" +@fld.str.586 = private constant [7 x i8] c"object\00" +@field_names.587 = private constant [6 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 4 }, { ptr, i64 } { ptr @fld.str.584, i64 3 }, { ptr, i64 } { ptr @fld.str.585, i64 5 }, { ptr, i64 } { ptr @fld.str.586, i64 6 }] +@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 [6 x i8] c"macos\00" +@fld.str.592 = private constant [6 x i8] c"linux\00" +@fld.str.593 = private constant [8 x i8] c"windows\00" +@fld.str.594 = private constant [5 x i8] c"wasm\00" +@fld.str.595 = private constant [4 x i8] c"ios\00" +@fld.str.596 = private constant [8 x i8] c"android\00" +@fld.str.597 = private constant [8 x i8] c"unknown\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 5 }, { ptr, i64 } { ptr @fld.str.593, i64 7 }, { ptr, i64 } { ptr @fld.str.594, i64 4 }, { ptr, i64 } { ptr @fld.str.595, i64 3 }, { ptr, i64 } { ptr @fld.str.596, i64 7 }, { 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 +@fld.str.602 = private constant [8 x i8] c"aarch64\00" +@fld.str.603 = private constant [7 x i8] c"x86_64\00" +@fld.str.604 = private constant [7 x i8] c"wasm32\00" +@fld.str.605 = private constant [7 x i8] c"wasm64\00" +@fld.str.606 = private constant [8 x i8] c"unknown\00" +@field_names.607 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.602, i64 7 }, { ptr, i64 } { ptr @fld.str.603, i64 6 }, { ptr, i64 } { ptr @fld.str.604, i64 6 }, { ptr, i64 } { ptr @fld.str.605, i64 6 }, { ptr, i64 } { ptr @fld.str.606, i64 7 }] +@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 [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"*f32\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"*string\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"*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"*[1]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 [7 x i8] c"*[]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 [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 [6 x i8] c"**f32\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"*Lerpable\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 define internal float @f32.lerp(ptr %0, float %1, float %2, float %3) #0 { @@ -704,85 +704,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -925,7 +847,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1052,7 +974,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1386,7 +1308,7 @@ entry: br i1 %icmp, label %if.then.377, label %if.merge.378 if.then.377: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.378: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1536,7 +1458,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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,12 +1486,12 @@ entry: i64 20, label %match.arm.43 i64 21, 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 25, label %match.arm.43 + i64 27, label %match.arm.43 + i64 29, label %match.arm.43 i64 31, label %match.arm.43 - i64 33, label %match.arm.43 - i64 35, label %match.arm.43 + i64 34, label %match.arm.43 + i64 36, label %match.arm.43 i64 40, label %match.arm.43 i64 44, label %match.arm.43 i64 46, label %match.arm.43 @@ -1594,25 +1516,25 @@ entry: i64 52, label %match.arm.45 i64 65, label %match.arm.45 i64 76, label %match.arm.45 - i64 36, label %match.arm.47 + i64 23, label %match.arm.47 i64 82, label %match.arm.47 i64 88, label %match.arm.47 i64 89, label %match.arm.47 i64 93, label %match.arm.47 i64 100, label %match.arm.47 - i64 37, label %match.arm.48 + i64 24, label %match.arm.48 i64 61, label %match.arm.48 i64 78, label %match.arm.48 i64 86, label %match.arm.48 i64 98, label %match.arm.48 i64 18, 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 26, label %match.arm.49 + i64 28, label %match.arm.49 i64 30, label %match.arm.49 i64 32, label %match.arm.49 - i64 34, label %match.arm.49 + i64 33, label %match.arm.49 + i64 35, label %match.arm.49 + i64 37, label %match.arm.49 i64 41, label %match.arm.49 i64 45, label %match.arm.49 i64 48, label %match.arm.49 @@ -1650,7 +1572,7 @@ match.merge.37: ; preds = %dispatch.merge.486, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1696,12 +1618,12 @@ match.arm.43: ; preds = %entry, %entry, %ent i64 20, label %dispatch.case.97 i64 21, label %dispatch.case.98 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 25, label %dispatch.case.100 + i64 27, label %dispatch.case.101 + i64 29, label %dispatch.case.102 i64 31, label %dispatch.case.103 - i64 33, label %dispatch.case.104 - i64 35, label %dispatch.case.105 + i64 34, label %dispatch.case.104 + i64 36, label %dispatch.case.105 i64 40, label %dispatch.case.106 i64 44, label %dispatch.case.107 i64 46, label %dispatch.case.108 @@ -1752,7 +1674,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.270 [ - i64 36, label %dispatch.case.271 + i64 23, label %dispatch.case.271 i64 82, label %dispatch.case.272 i64 88, label %dispatch.case.273 i64 89, label %dispatch.case.274 @@ -1765,7 +1687,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.308 [ - i64 37, label %dispatch.case.309 + i64 24, label %dispatch.case.309 i64 61, label %dispatch.case.310 i64 78, label %dispatch.case.311 i64 86, label %dispatch.case.312 @@ -1778,13 +1700,13 @@ 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 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 - i64 34, label %dispatch.case.348 + i64 26, label %dispatch.case.342 + i64 28, label %dispatch.case.343 + i64 30, label %dispatch.case.344 + i64 32, label %dispatch.case.345 + i64 33, label %dispatch.case.346 + i64 35, label %dispatch.case.347 + i64 37, label %dispatch.case.348 i64 41, label %dispatch.case.349 i64 45, label %dispatch.case.350 i64 48, label %dispatch.case.351 @@ -1880,7 +1802,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.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1910,56 +1832,56 @@ dispatch.case.98: ; preds = %match.arm.43 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 %ua.ptr73, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load74) + %ua.load74 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr73, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %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 { i64 }, ptr %ua.ptr77, align 8 - %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load78) + %ua.load78 = load {}, ptr %ua.ptr77, align 1 + %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %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, i64 }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load82) + %ua.load82 = load { i64 }, ptr %ua.ptr81, align 8 + %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load82) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) + %ua.load86 = load { ptr, i64 }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) + %ua.load94 = load { ptr, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.105: ; preds = %match.arm.43 %ua.raw96 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr97 = inttoptr i64 %ua.raw96 to ptr - %ua.load98 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr97, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load98) + %ua.load98 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr97, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load98) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2097,7 +2019,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.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.252 dispatch.case.254: ; preds = %match.arm.44 @@ -2138,7 +2060,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.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.269 dispatch.case.271: ; preds = %match.arm.47 @@ -2195,7 +2117,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.313, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.307 dispatch.case.309: ; preds = %match.arm.48 @@ -2244,7 +2166,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.314, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.316, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.339 dispatch.case.341: ; preds = %match.arm.49 @@ -2484,7 +2406,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.315, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.317, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.486 dispatch.case.488: ; preds = %match.arm.50 @@ -2526,7 +2448,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.316, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.318, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2622,7 +2544,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.317, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.319, 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 @@ -2630,7 +2552,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.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 @@ -2640,13 +2562,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.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 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.320, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, 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 @@ -2654,7 +2576,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.321, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.323, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2668,7 +2590,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.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 @@ -2676,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.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 @@ -2687,7 +2609,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 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 @@ -2744,7 +2666,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.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 @@ -2752,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.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 i64, ptr %allocaN, align 8 @@ -2763,7 +2685,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 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 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2783,7 +2705,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.328, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, 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 @@ -2791,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.329, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, 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 @@ -2802,7 +2724,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 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2812,67 +2734,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3048,166 +3054,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3405,64 +3411,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3492,97 +3498,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3621,7 +3627,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal ptr @__thunk_CAllocator_Allocator_alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { @@ -3641,7 +3647,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.331, i64 22 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.333, 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 @@ -3658,7 +3664,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 { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 19) @@ -3687,7 +3693,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 22 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.335, i64 22 }) ret { ptr, i64 } %call } @@ -3706,7 +3712,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.334, i64 23 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.336, 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 @@ -3723,7 +3729,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.335, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.337, 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) @@ -3752,7 +3758,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.336, i64 23 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.338, i64 23 }) ret { ptr, i64 } %call } @@ -3761,7 +3767,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.337, i64 8 }, { ptr, i64 } { ptr @str.338, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.339, i64 8 }, { 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 @@ -3780,12 +3786,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.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.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.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.126 @@ -3797,7 +3803,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.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, ptr }, ptr %alloca, align 8 @@ -3840,7 +3846,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 @@ -3859,24 +3865,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.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.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.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.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.351, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3933,7 +3939,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.353, i64 9 }, { ptr, i64 } { ptr @str.354, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.355, i64 9 }, { 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 @@ -3952,24 +3958,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.355, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, 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 }) + %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.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 [3 x { ptr, i64 }], ptr @field_names.360, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -4013,20 +4019,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.362, i64 10 }, { ptr, i64 } { ptr @str.363, i64 1 }) + %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.364, i64 7 }, { 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 = %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, 2 br i1 %icmp, label %while.body.138, label %while.exit.139 while.body.138: ; preds = %while.hdr.137 @@ -4036,24 +4043,102 @@ 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.364, i64 1 }) + %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.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 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.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.367, i64 2 }) + %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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.137 + +fv.default: ; preds = %if.merge.141 + br label %fv.merge + +fv.case: ; preds = %if.merge.141 + %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + 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 21, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.141 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.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.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.374, 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.375, 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.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 %alloca, align 1 @@ -4064,7 +4149,7 @@ if.merge.141: ; preds = %if.then.140, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.137 + br label %while.hdr.142 } ; Function Attrs: nounwind @@ -4072,43 +4157,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 3 }, { 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.142 + br label %while.hdr.147 -while.hdr.142: ; preds = %fv.merge, %entry +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.143, label %while.exit.144 + br i1 %icmp, label %while.body.148, label %while.exit.149 -while.body.143: ; preds = %while.hdr.142 +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.145, label %if.merge.146 + br i1 %icmpN, label %if.then.150, label %if.merge.151 -while.exit.144: ; preds = %while.hdr.142 +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.370, 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.145: ; preds = %while.body.143 +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.371, 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.146 + br label %if.merge.151 -if.merge.146: ; preds = %if.then.145, %while.body.143 +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.373, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.374, 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 { i64 }, ptr %alloca, align 8 @@ -4125,12 +4210,12 @@ 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 + br label %while.hdr.147 -fv.default: ; preds = %if.merge.146 +fv.default: ; preds = %if.merge.151 br label %fv.merge -fv.case: ; preds = %if.merge.146 +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 @@ -4141,43 +4226,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 10 }, { 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 + br label %while.hdr.152 -while.hdr.147: ; preds = %fv.merge, %entry +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.148, label %while.exit.149 + br i1 %icmp, label %while.body.153, label %while.exit.154 -while.body.148: ; preds = %while.hdr.147 +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.150, label %if.merge.151 + br i1 %icmpN, label %if.then.155, label %if.merge.156 -while.exit.149: ; preds = %while.hdr.147 +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.377, 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.150: ; preds = %while.body.148 +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.378, 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.151 + br label %if.merge.156 -if.merge.151: ; preds = %if.then.150, %while.body.148 +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.381, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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.382, 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 }, ptr %alloca, align 8 @@ -4195,18 +4280,18 @@ 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.147 + br label %while.hdr.152 -fv.default: ; preds = %if.merge.151 +fv.default: ; preds = %if.merge.156 br label %fv.merge -fv.case: ; preds = %if.merge.151 +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 27, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 30, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.151 +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 @@ -4218,91 +4303,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.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 - 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.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.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.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 { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.152 - -fv.default: ; preds = %if.merge.156 - br label %fv.merge - -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 27, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.156 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 21, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 8 }, { ptr, i64 } { ptr @str.393, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.393, i64 5 }, { 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 @@ -4321,27 +4322,27 @@ 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.394, 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.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.395, 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.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.399, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.400, 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, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4363,29 +4364,30 @@ fv.default: ; preds = %if.merge.161 br label %fv.merge fv.case: ; preds = %if.merge.161 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 30, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.161 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.161 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 21, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.401, i64 17 }, { ptr, i64 } { ptr @str.402, i64 1 }) + %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.402, i64 8 }, { 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 @@ -4394,7 +4396,7 @@ entry: while.hdr.162: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.163, label %while.exit.164 while.body.163: ; preds = %while.hdr.162 @@ -4404,19 +4406,19 @@ 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.403, 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.404, 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 [4 x { ptr, i64 }], ptr @field_names.409, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4424,17 +4426,16 @@ if.merge.166: ; preds = %if.then.165, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4447,35 +4448,29 @@ fv.default: ; preds = %if.merge.166 br label %fv.merge 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 21, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 33, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.166 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.166 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.166 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.411, i64 7 }, { ptr, i64 } { ptr @str.412, i64 1 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.411, i64 17 }, { 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 @@ -4484,7 +4479,7 @@ entry: while.hdr.167: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.168, label %while.exit.169 while.body.168: ; preds = %while.hdr.167 @@ -4506,23 +4501,25 @@ if.then.170: ; preds = %while.body.168 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.417, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4535,16 +4532,25 @@ fv.default: ; preds = %if.merge.171 br label %fv.merge fv.case: ; preds = %if.merge.171 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 21, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.171 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.171 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.171 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4553,7 +4559,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.419, i64 4 }, { ptr, i64 } { ptr @str.420, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.421, i64 4 }, { 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 @@ -4572,24 +4578,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.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.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.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.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.424, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i32 }, ptr %alloca, align 4 @@ -4626,7 +4632,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.426, i64 10 }, { ptr, i64 } { ptr @str.427, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.428, i64 10 }, { 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 @@ -4645,24 +4651,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 [5 x { ptr, i64 }], ptr @field_names.435, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4728,7 +4734,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.437, i64 13 }, { ptr, i64 } { ptr @str.438, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.439, i64 13 }, { 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 @@ -4747,24 +4753,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.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.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.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.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.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 { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4806,7 +4812,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.445, i64 8 }, { ptr, i64 } { ptr @str.446, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.447, i64 8 }, { 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 @@ -4825,24 +4831,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 [5 x { ptr, i64 }], ptr @field_names.454, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4903,7 +4909,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.456, i64 5 }, { ptr, i64 } { ptr @str.457, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 5 }, { 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 @@ -4922,24 +4928,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.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.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.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.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.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 @@ -4985,7 +4991,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.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 @@ -5004,24 +5010,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.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.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.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.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.472, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.474, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 @@ -5069,7 +5075,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.474, i64 6 }, { ptr, i64 } { ptr @str.475, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.476, i64 6 }, { ptr, i64 } { ptr @str.477, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5088,24 +5094,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.476, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, 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.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 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.480, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, [24 x i8] } }, ptr %alloca, align 8 @@ -5149,7 +5155,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.482, i64 4 }, { ptr, i64 } { ptr @str.483, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 4 }, { 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 @@ -5168,24 +5174,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.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.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.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.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.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 %alloca, align 8 @@ -5235,7 +5241,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.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 @@ -5254,24 +5260,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.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.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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 @@ -5320,7 +5326,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.500, i64 12 }, { ptr, i64 } { ptr @str.501, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.502, i64 12 }, { 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 @@ -5339,24 +5345,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.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.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.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.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.504, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 %alloca, align 1 @@ -5376,7 +5382,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.506, i64 8 }, { ptr, i64 } { ptr @str.507, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 8 }, { 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 @@ -5395,24 +5401,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.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.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.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.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.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 }, i1, i1 }, ptr %alloca, align 8 @@ -5464,7 +5470,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.515, i64 7 }, { ptr, i64 } { ptr @str.516, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.517, i64 7 }, { 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 @@ -5483,24 +5489,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.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.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.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.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.522, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5552,7 +5558,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.524, i64 9 }, { ptr, i64 } { ptr @str.525, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.526, i64 9 }, { 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 @@ -5571,24 +5577,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.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.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.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.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.530, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5631,7 +5637,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.532, i64 4 }, { ptr, i64 } { ptr @str.533, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.534, i64 4 }, { 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 @@ -5650,24 +5656,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.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.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.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.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.538, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.540, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5713,7 +5719,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.540, i64 6 }, { ptr, i64 } { ptr @str.541, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.542, i64 6 }, { ptr, i64 } { ptr @str.543, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5732,24 +5738,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.542, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, 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.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 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.551, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 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 { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5806,7 +5812,7 @@ fv.case28: ; preds = %if.merge.246 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 37, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 24, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.246 @@ -5831,7 +5837,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.553, i64 6 }, { ptr, i64 } { ptr @str.554, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.555, i64 6 }, { ptr, i64 } { ptr @str.556, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5850,24 +5856,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.555, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.557, 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.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 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.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 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5926,9 +5932,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.568, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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.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, ptr %alloca, align 8 @@ -5947,8 +5953,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.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.260 @@ -5967,9 +5973,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.575, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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, ptr %alloca, align 8 @@ -5988,8 +5994,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.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.262 @@ -6019,9 +6025,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.585, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.587, 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, [24 x i8] }, ptr %alloca, align 8 @@ -6038,8 +6044,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.264 @@ -6117,9 +6123,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.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 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, 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 @@ -6138,8 +6144,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.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.266 @@ -6158,9 +6164,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.605, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.607, 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.599, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.601, 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 @@ -6179,8 +6185,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.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 } { ptr @str.609, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.608, 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 @@ -6197,7 +6203,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.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.277 @@ -6214,12 +6220,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.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.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.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.281 @@ -6248,7 +6254,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.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.282 @@ -6265,12 +6271,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.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.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.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.286 @@ -6300,7 +6306,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.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.287 @@ -6317,12 +6323,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.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.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.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.291 @@ -6350,7 +6356,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.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.292 @@ -6367,12 +6373,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.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.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.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.296 @@ -6401,7 +6407,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.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.297 @@ -6418,12 +6424,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.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.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.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.301 @@ -6452,7 +6458,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.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.302 @@ -6469,12 +6475,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.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.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.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.306 @@ -6504,7 +6510,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.314 @@ -6523,12 +6529,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.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.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.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.318 @@ -6557,7 +6563,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.319 @@ -6576,12 +6582,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.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.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.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.323 @@ -6610,7 +6616,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.324 @@ -6629,12 +6635,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.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.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.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.328 @@ -6664,7 +6670,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.329 @@ -6683,12 +6689,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.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.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.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.333 @@ -6718,7 +6724,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.334 @@ -6737,12 +6743,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.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.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.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.338 @@ -6784,12 +6790,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.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.376 if.merge.376: ; preds = %if.else.375, %if.then.374 - %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.374 ], [ %callN, %if.else.375 ] + %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.374 ], [ %callN, %if.else.375 ] ret { ptr, i64 } %bp } @@ -6812,12 +6818,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.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.392 if.merge.392: ; preds = %if.else.391, %if.then.390 - %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] + %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.390 ], [ %callN, %if.else.391 ] ret { ptr, i64 } %bp } @@ -6840,12 +6846,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.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.395 if.merge.395: ; preds = %if.else.394, %if.then.393 - %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.393 ], [ %callN, %if.else.394 ] + %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.393 ], [ %callN, %if.else.394 ] ret { ptr, i64 } %bp } @@ -6868,12 +6874,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.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.398 if.merge.398: ; preds = %if.else.397, %if.then.396 - %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] + %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] ret { ptr, i64 } %bp } @@ -6896,12 +6902,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.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.401 if.merge.401: ; preds = %if.else.400, %if.then.399 - %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.399 ], [ %callN, %if.else.400 ] + %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.399 ], [ %callN, %if.else.400 ] ret { ptr, i64 } %bp } @@ -6923,12 +6929,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.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.404 if.merge.404: ; preds = %if.else.403, %if.then.402 - %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] + %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] ret { ptr, i64 } %bp } @@ -6951,12 +6957,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.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.407 if.merge.407: ; preds = %if.else.406, %if.then.405 - %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] + %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] ret { ptr, i64 } %bp } @@ -6979,12 +6985,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.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.410 if.merge.410: ; preds = %if.else.409, %if.then.408 - %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] + %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] ret { ptr, i64 } %bp } @@ -7007,12 +7013,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.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.413 if.merge.413: ; preds = %if.else.412, %if.then.411 - %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] + %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] ret { ptr, i64 } %bp } @@ -7035,12 +7041,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.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.416 if.merge.416: ; preds = %if.else.415, %if.then.414 - %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] + %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] ret { ptr, i64 } %bp } @@ -7063,12 +7069,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.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.419 if.merge.419: ; preds = %if.else.418, %if.then.417 - %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] + %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] ret { ptr, i64 } %bp } @@ -7091,12 +7097,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.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.422 if.merge.422: ; preds = %if.else.421, %if.then.420 - %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -7119,12 +7125,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.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.425 if.merge.425: ; preds = %if.else.424, %if.then.423 - %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -7146,12 +7152,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.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.428 if.merge.428: ; preds = %if.else.427, %if.then.426 - %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -7174,12 +7180,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.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.431 if.merge.431: ; preds = %if.else.430, %if.then.429 - %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -7201,12 +7207,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.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.434 if.merge.434: ; preds = %if.else.433, %if.then.432 - %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -7229,12 +7235,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.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.437 if.merge.437: ; preds = %if.else.436, %if.then.435 - %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -7257,12 +7263,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.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.440 if.merge.440: ; preds = %if.else.439, %if.then.438 - %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -7285,12 +7291,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.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.443 if.merge.443: ; preds = %if.else.442, %if.then.441 - %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -7313,12 +7319,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.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.446 if.merge.446: ; preds = %if.else.445, %if.then.444 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -7341,12 +7347,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.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.449 if.merge.449: ; preds = %if.else.448, %if.then.447 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -7369,12 +7375,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.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.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -7397,12 +7403,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.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.455 if.merge.455: ; preds = %if.else.454, %if.then.453 - %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -7425,12 +7431,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.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.458 if.merge.458: ; preds = %if.else.457, %if.then.456 - %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -7453,12 +7459,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.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.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -7481,12 +7487,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.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.464 if.merge.464: ; preds = %if.else.463, %if.then.462 - %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -7509,12 +7515,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.721, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 7 }, { 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 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.719, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -7537,12 +7543,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.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.470 if.merge.470: ; preds = %if.else.469, %if.then.468 - %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -7565,12 +7571,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.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.473 if.merge.473: ; preds = %if.else.472, %if.then.471 - %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -7593,12 +7599,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.730, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 6 }, { 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 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.728, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -7621,12 +7627,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.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.479 if.merge.479: ; preds = %if.else.478, %if.then.477 - %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.733, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -7649,12 +7655,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.736, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 5 }, { 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 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.734, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.736, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -7677,12 +7683,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.739, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 9 }, { 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 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.737, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.739, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -7698,7 +7704,7 @@ entry: br i1 %lnot, label %if.then.492, label %if.merge.493 if.then.492: ; preds = %entry - ret { ptr, i64 } { ptr @str.740, i64 4 } + ret { ptr, i64 } { ptr @str.742, i64 4 } if.merge.493: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7722,7 +7728,7 @@ entry: br i1 %lnot, label %if.then.494, label %if.merge.495 if.then.494: ; preds = %entry - ret { ptr, i64 } { ptr @str.741, i64 4 } + ret { ptr, i64 } { ptr @str.743, i64 4 } if.merge.495: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7746,7 +7752,7 @@ entry: br i1 %lnot, label %if.then.496, label %if.merge.497 if.then.496: ; preds = %entry - ret { ptr, i64 } { ptr @str.742, i64 4 } + ret { ptr, i64 } { ptr @str.744, i64 4 } if.merge.497: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7770,7 +7776,7 @@ entry: br i1 %lnot, label %if.then.498, label %if.merge.499 if.then.498: ; preds = %entry - ret { ptr, i64 } { ptr @str.743, i64 4 } + ret { ptr, i64 } { ptr @str.745, 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 f80d197..64c12b2 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [8 x i8] c"IntCell\00" +@tn.str.241 = private constant [8 x i8] c"StrCell\00" +@tn.str.242 = private constant [9 x i8] c"*IntCell\00" +@tn.str.243 = private constant [9 x i8] c"*StrCell\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"VL__s64\00" +@tn.str.247 = private constant [18 x i8] c"__VL__s64__Vtable\00" +@tn.str.248 = private constant [9 x i8] c"*VL__s64\00" +@tn.str.249 = private constant [10 x i8] c"**IntCell\00" +@tn.str.250 = private constant [19 x i8] c"*__VL__s64__Vtable\00" +@tn.str.251 = private constant [8 x i8] c"*string\00" +@tn.str.252 = private constant [6 x i8] c"[]Any\00" +@tn.str.253 = private constant [5 x i8] c"*Any\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 [7 x i8] c"*[]Any\00" +@tn.str.257 = private constant [6 x i8] c"*bool\00" +@tn.str.258 = private constant [11 x i8] c"VL__string\00" +@tn.str.259 = private constant [21 x i8] c"__VL__string__Vtable\00" +@tn.str.260 = private constant [12 x i8] c"*VL__string\00" +@tn.str.261 = private constant [10 x i8] c"**StrCell\00" +@tn.str.262 = private constant [22 x i8] c"*__VL__string__Vtable\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 [10 x i8] c"*OpenMode\00" +@tn.str.276 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.277 = private constant [7 x i8] c"*Value\00" +@tn.str.278 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.279 = private constant [14 x i8] c"*Architecture\00" +@tn.str.280 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.281 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.282 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.283 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.284 = private constant [10 x i8] c"*[]string\00" +@tn.str.285 = private constant [6 x i8] c"*[]u8\00" +@tn.str.286 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.287 = private constant [11 x i8] c"*[]Command\00" +@tn.str.288 = private constant [6 x i8] c"**GPA\00" +@tn.str.289 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.290 = private constant [8 x i8] c"**Arena\00" +@tn.str.291 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.292 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.293 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.294 = private constant [7 x i8] c"**File\00" +@tn.str.295 = private constant [5 x i8] c"**u8\00" +@tn.str.296 = private constant [6 x i8] c"**s32\00" +@tn.str.297 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.298 = private constant [6 x i8] c"**u32\00" +@tn.str.299 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.300 = private constant [8 x i8] c"**Array\00" +@tn.str.301 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.302 = private constant [9 x i8] c"**Object\00" +@tn.str.303 = private constant [7 x i8] c"**Sink\00" +@tn.str.304 = private constant [9 x i8] c"**Parser\00" +@tn.str.305 = private constant [6 x i8] c"**s64\00" +@tn.str.306 = private constant [9 x i8] c"**Parsed\00" +@tn.str.307 = private constant [7 x i8] c"**Diag\00" +@tn.str.308 = private constant [9 x i8] c"**Sha256\00" +@tn.str.309 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.310 = private constant [8 x i8] c"***void\00" +@tn.str.311 = private constant [10 x i8] c"**VL__s64\00" +@tn.str.312 = private constant [11 x i8] c"***IntCell\00" +@tn.str.313 = private constant [20 x i8] c"**__VL__s64__Vtable\00" +@tn.str.314 = private constant [9 x i8] c"**string\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 [7 x i8] c"**bool\00" +@tn.str.319 = private constant [13 x i8] c"**VL__string\00" +@tn.str.320 = private constant [11 x i8] c"***StrCell\00" +@tn.str.321 = private constant [23 x i8] c"**__VL__string__Vtable\00" +@tn.str.322 = private constant [7 x i8] c"*?File\00" +@tn.str.323 = private constant [9 x i8] c"*?string\00" +@tn.str.324 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.325 = 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.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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 7 }, { ptr, i64 } { ptr @tn.str.241, i64 7 }, { ptr, i64 } { ptr @tn.str.242, i64 8 }, { ptr, i64 } { ptr @tn.str.243, i64 8 }, { 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 17 }, { ptr, i64 } { ptr @tn.str.248, i64 8 }, { ptr, i64 } { ptr @tn.str.249, i64 9 }, { ptr, i64 } { ptr @tn.str.250, i64 18 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 5 }, { 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 6 }, { ptr, i64 } { ptr @tn.str.257, i64 5 }, { ptr, i64 } { ptr @tn.str.258, i64 10 }, { ptr, i64 } { ptr @tn.str.259, i64 20 }, { ptr, i64 } { ptr @tn.str.260, i64 11 }, { ptr, i64 } { ptr @tn.str.261, i64 9 }, { ptr, i64 } { ptr @tn.str.262, i64 21 }, { 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 9 }, { ptr, i64 } { ptr @tn.str.276, i64 9 }, { ptr, i64 } { ptr @tn.str.277, i64 6 }, { ptr, i64 } { ptr @tn.str.278, i64 16 }, { ptr, i64 } { ptr @tn.str.279, i64 13 }, { ptr, i64 } { ptr @tn.str.280, i64 14 }, { ptr, i64 } { ptr @tn.str.281, i64 7 }, { ptr, i64 } { ptr @tn.str.282, i64 7 }, { ptr, i64 } { ptr @tn.str.283, i64 8 }, { ptr, i64 } { ptr @tn.str.284, i64 9 }, { ptr, i64 } { ptr @tn.str.285, i64 5 }, { ptr, i64 } { ptr @tn.str.286, i64 11 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 5 }, { ptr, i64 } { ptr @tn.str.289, i64 12 }, { ptr, i64 } { ptr @tn.str.290, i64 7 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 10 }, { ptr, i64 } { ptr @tn.str.293, i64 19 }, { ptr, i64 } { ptr @tn.str.294, i64 6 }, { ptr, i64 } { ptr @tn.str.295, i64 4 }, { ptr, i64 } { ptr @tn.str.296, i64 5 }, { ptr, i64 } { ptr @tn.str.297, i64 10 }, { ptr, i64 } { ptr @tn.str.298, i64 5 }, { ptr, i64 } { ptr @tn.str.299, i64 9 }, { ptr, i64 } { ptr @tn.str.300, i64 7 }, { ptr, i64 } { ptr @tn.str.301, i64 10 }, { 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 5 }, { 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 13 }, { ptr, i64 } { ptr @tn.str.310, i64 7 }, { ptr, i64 } { ptr @tn.str.311, i64 9 }, { ptr, i64 } { ptr @tn.str.312, i64 10 }, { ptr, i64 } { ptr @tn.str.313, i64 19 }, { ptr, i64 } { ptr @tn.str.314, i64 8 }, { 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 6 }, { ptr, i64 } { ptr @tn.str.319, i64 12 }, { ptr, i64 } { ptr @tn.str.320, i64 10 }, { ptr, i64 } { ptr @tn.str.321, i64 22 }, { ptr, i64 } { ptr @tn.str.322, i64 6 }, { ptr, i64 } { ptr @tn.str.323, i64 8 }, { ptr, i64 } { ptr @tn.str.324, i64 15 }, { ptr, i64 } { ptr @tn.str.325, i64 8 }] @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 [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 [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 [15 x i8] c"result := \22\22; \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 [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.337 = private unnamed_addr constant [6 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 [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 [3 x i8] c"hi\00", 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 [1 x i8] zeroinitializer, align 1 +@str.349 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.350 = private unnamed_addr constant [10 x i8] c"a.get={}\0A\00", 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 +@str.352 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.353 = private unnamed_addr constant [10 x i8] c"b.get={}\0A\00", align 1 +@str.354 = private unnamed_addr constant [16 x i8] c"Source_Location\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 = private constant [5 x i8] c"file\00" -@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 }] +@fld.str.358 = private constant [5 x i8] c"line\00" +@fld.str.359 = private constant [4 x i8] c"col\00" +@fld.str.360 = 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.358, i64 4 }, { ptr, i64 } { ptr @fld.str.359, i64 3 }, { ptr, i64 } { ptr @fld.str.360, i64 4 }] +@str.361 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.362 = private unnamed_addr constant [10 x i8] c"Allocator\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 [4 x i8] c"ctx\00" +@fld.str.367 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.368 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.369 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.366, i64 3 }, { ptr, i64 } { ptr @fld.str.367, i64 11 }, { ptr, i64 } { ptr @fld.str.368, i64 13 }] +@str.370 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.371 = private unnamed_addr constant [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.376 = private constant [5 x i8] c"data\00" +@field_names.377 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.375, i64 9 }, { ptr, i64 } { ptr @fld.str.376, 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.405 = private constant [10 x i8] c"end_index\00" +@fld.str.406 = private constant [7 x i8] c"parent\00" +@field_names.407 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.404, i64 5 }, { ptr, i64 } { ptr @fld.str.405, i64 9 }, { ptr, i64 } { ptr @fld.str.406, i64 6 }] +@str.408 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.409 = private unnamed_addr constant [9 x i8] c"BufAlloc\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"buf\00" +@fld.str.414 = private constant [4 x i8] c"len\00" +@fld.str.415 = private constant [4 x i8] c"pos\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 3 }, { ptr, i64 } { ptr @fld.str.415, i64 3 }] @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.418 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.422 = private constant [7 x i8] c"parent\00" +@fld.str.423 = private constant [12 x i8] c"alloc_count\00" +@fld.str.424 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.425 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.426 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.422, i64 6 }, { ptr, i64 } { ptr @fld.str.423, i64 11 }, { ptr, i64 } { ptr @fld.str.424, i64 13 }, { ptr, i64 } { ptr @fld.str.425, i64 17 }] +@str.427 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.428 = private unnamed_addr constant [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.433 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.432, i64 2 }] +@str.434 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.435 = private unnamed_addr constant [11 x i8] c"TraceFrame\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 [5 x i8] c"file\00" +@fld.str.440 = private constant [5 x i8] c"line\00" +@fld.str.441 = private constant [4 x i8] c"col\00" +@fld.str.442 = private constant [5 x i8] c"func\00" +@fld.str.443 = private constant [10 x i8] c"line_text\00" +@field_names.444 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.439, i64 4 }, { ptr, i64 } { ptr @fld.str.440, i64 4 }, { ptr, i64 } { ptr @fld.str.441, i64 3 }, { ptr, i64 } { ptr @fld.str.442, i64 4 }, { ptr, i64 } { ptr @fld.str.443, i64 9 }] +@str.445 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.446 = private unnamed_addr constant [14 x i8] c"ProcessResult\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"exit_code\00" +@fld.str.451 = private constant [7 x i8] c"stdout\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 6 }] +@str.453 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.454 = private unnamed_addr constant [9 x i8] c"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.459 = private constant [11 x i8] c"sin_family\00" +@fld.str.460 = private constant [9 x i8] c"sin_port\00" +@fld.str.461 = private constant [9 x i8] c"sin_addr\00" +@fld.str.462 = private constant [9 x i8] c"sin_zero\00" +@field_names.463 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.458, i64 7 }, { ptr, i64 } { ptr @fld.str.459, i64 10 }, { ptr, i64 } { ptr @fld.str.460, i64 8 }, { ptr, i64 } { ptr @fld.str.461, i64 8 }, { ptr, i64 } { ptr @fld.str.462, i64 8 }] +@str.464 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.465 = private unnamed_addr constant [6 x i8] c"Array\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"Object\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 [6 x i8] c"items\00" +@fld.str.479 = private constant [4 x i8] c"len\00" +@fld.str.480 = private constant [4 x i8] c"cap\00" +@field_names.481 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.478, i64 5 }, { ptr, i64 } { ptr @fld.str.479, i64 3 }, { ptr, i64 } { ptr @fld.str.480, i64 3 }] +@str.482 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.483 = private unnamed_addr constant [7 x i8] c"Member\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"key\00" +@fld.str.488 = private constant [4 x i8] c"val\00" +@field_names.489 = private constant [2 x { ptr, i64 }] [{ 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 [5 x i8] c"Sink\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"dst\00" +@fld.str.496 = private constant [4 x i8] c"pos\00" +@fld.str.497 = private constant [5 x i8] c"file\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 4 }] +@str.499 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.500 = private unnamed_addr constant [7 x i8] c"Parser\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"src\00" +@fld.str.505 = private constant [4 x i8] c"pos\00" +@fld.str.506 = private constant [6 x i8] c"alloc\00" +@field_names.507 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.504, i64 3 }, { ptr, i64 } { ptr @fld.str.505, i64 3 }, { 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 [13 x i8] c"BuildOptions\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 +@field_names.513 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.514 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.515 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.520 = private constant [12 x i8] c"takes_value\00" +@fld.str.521 = private constant [9 x i8] c"required\00" +@field_names.522 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.519, i64 4 }, { ptr, i64 } { ptr @fld.str.520, i64 11 }, { ptr, i64 } { ptr @fld.str.521, i64 8 }] +@str.523 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.524 = private unnamed_addr constant [8 x i8] c"Command\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 [6 x i8] c"flags\00" +@field_names.531 = private constant [3 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 5 }] +@str.532 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.533 = private unnamed_addr constant [10 x i8] c"FlagValue\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 [4 x i8] c"set\00" +@fld.str.538 = private constant [6 x i8] c"value\00" +@field_names.539 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.537, i64 3 }, { ptr, i64 } { ptr @fld.str.538, i64 5 }] +@str.540 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.541 = private unnamed_addr constant [5 x i8] c"Diag\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"index\00" +@fld.str.546 = private constant [6 x i8] c"token\00" +@field_names.547 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.545, i64 5 }, { ptr, i64 } { ptr @fld.str.546, i64 5 }] +@str.548 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.549 = private unnamed_addr constant [7 x i8] c"Parsed\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 [6 x i8] c"group\00" +@fld.str.554 = private constant [8 x i8] c"command\00" +@fld.str.555 = private constant [10 x i8] c"cmd_index\00" +@fld.str.556 = private constant [5 x i8] c"json\00" +@fld.str.557 = private constant [5 x i8] c"rest\00" +@fld.str.558 = private constant [5 x i8] c"spec\00" +@fld.str.559 = private constant [7 x i8] c"values\00" +@field_names.560 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.553, i64 5 }, { ptr, i64 } { ptr @fld.str.554, i64 7 }, { ptr, i64 } { ptr @fld.str.555, i64 9 }, { ptr, i64 } { ptr @fld.str.556, i64 4 }, { ptr, i64 } { ptr @fld.str.557, i64 4 }, { ptr, i64 } { ptr @fld.str.558, i64 4 }, { ptr, i64 } { ptr @fld.str.559, i64 6 }] +@str.561 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.562 = private unnamed_addr constant [7 x i8] c"Sha256\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 [2 x i8] c"h\00" +@fld.str.567 = private constant [4 x i8] c"buf\00" +@fld.str.568 = private constant [8 x i8] c"buf_len\00" +@fld.str.569 = private constant [10 x i8] c"total_len\00" +@field_names.570 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.566, i64 1 }, { ptr, i64 } { ptr @fld.str.567, i64 3 }, { ptr, i64 } { ptr @fld.str.568, i64 7 }, { ptr, i64 } { ptr @fld.str.569, i64 9 }] +@str.571 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.572 = private unnamed_addr constant [8 x i8] c"IntCell\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 +@str.575 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.576 = private constant [2 x i8] c"v\00" +@field_names.577 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.576, i64 1 }] +@str.578 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.579 = private unnamed_addr constant [8 x i8] c"StrCell\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"s\00" +@field_names.584 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.583, i64 1 }] +@str.585 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.586 = private unnamed_addr constant [8 x i8] c"VL__s64\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 +@str.589 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.590 = private constant [4 x i8] c"ctx\00" +@fld.str.591 = private constant [9 x i8] c"__vtable\00" +@field_names.592 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.590, i64 3 }, { ptr, i64 } { ptr @fld.str.591, i64 8 }] +@str.593 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.594 = private unnamed_addr constant [18 x i8] c"__VL__s64__Vtable\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 +@fld.str.598 = private constant [4 x i8] c"get\00" +@field_names.599 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.598, i64 3 }] +@str.600 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.601 = private unnamed_addr constant [11 x i8] c"VL__string\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 +@fld.str.605 = private constant [4 x i8] c"ctx\00" +@fld.str.606 = private constant [9 x i8] c"__vtable\00" +@field_names.607 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.605, i64 3 }, { ptr, i64 } { ptr @fld.str.606, i64 8 }] +@str.608 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.609 = private unnamed_addr constant [21 x i8] c"__VL__string__Vtable\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 [4 x i8] c"get\00" +@field_names.614 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.613, i64 3 }] +@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 +@fld.str.617 = private constant [5 x i8] c"read\00" +@fld.str.618 = private constant [6 x i8] c"write\00" +@fld.str.619 = private constant [7 x i8] c"append\00" +@fld.str.620 = private constant [11 x i8] c"read_write\00" +@field_names.621 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.617, i64 4 }, { ptr, i64 } { ptr @fld.str.618, i64 5 }, { ptr, i64 } { ptr @fld.str.619, i64 6 }, { ptr, i64 } { ptr @fld.str.620, i64 10 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.625 = private constant [4 x i8] c"set\00" +@fld.str.626 = private constant [8 x i8] c"current\00" +@fld.str.627 = private constant [4 x i8] c"end\00" +@field_names.628 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.625, i64 3 }, { ptr, i64 } { ptr @fld.str.626, i64 7 }, { ptr, i64 } { ptr @fld.str.627, i64 3 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.632 = private constant [6 x i8] c"null_\00" +@fld.str.633 = private constant [6 x i8] c"bool_\00" +@fld.str.634 = private constant [5 x i8] c"int_\00" +@fld.str.635 = private constant [4 x i8] c"str\00" +@fld.str.636 = private constant [6 x i8] c"array\00" +@fld.str.637 = private constant [7 x i8] c"object\00" +@field_names.638 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.632, i64 5 }, { ptr, i64 } { ptr @fld.str.633, i64 5 }, { ptr, i64 } { ptr @fld.str.634, i64 4 }, { ptr, i64 } { ptr @fld.str.635, i64 3 }, { ptr, i64 } { ptr @fld.str.636, i64 5 }, { ptr, i64 } { ptr @fld.str.637, i64 6 }] +@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 +@fld.str.642 = private constant [6 x i8] c"macos\00" +@fld.str.643 = private constant [6 x i8] c"linux\00" +@fld.str.644 = private constant [8 x i8] c"windows\00" +@fld.str.645 = private constant [5 x i8] c"wasm\00" +@fld.str.646 = private constant [4 x i8] c"ios\00" +@fld.str.647 = private constant [8 x i8] c"android\00" +@fld.str.648 = private constant [8 x i8] c"unknown\00" +@field_names.649 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.642, i64 5 }, { ptr, i64 } { ptr @fld.str.643, i64 5 }, { ptr, i64 } { ptr @fld.str.644, i64 7 }, { ptr, i64 } { ptr @fld.str.645, i64 4 }, { ptr, i64 } { ptr @fld.str.646, i64 3 }, { ptr, i64 } { ptr @fld.str.647, i64 7 }, { ptr, i64 } { ptr @fld.str.648, i64 7 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.653 = private constant [8 x i8] c"aarch64\00" +@fld.str.654 = private constant [7 x i8] c"x86_64\00" +@fld.str.655 = private constant [7 x i8] c"wasm32\00" +@fld.str.656 = private constant [7 x i8] c"wasm64\00" +@fld.str.657 = private constant [8 x i8] c"unknown\00" +@field_names.658 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.653, i64 7 }, { ptr, i64 } { ptr @fld.str.654, i64 6 }, { ptr, i64 } { ptr @fld.str.655, i64 6 }, { ptr, i64 } { ptr @fld.str.656, i64 6 }, { ptr, i64 } { ptr @fld.str.657, i64 7 }] +@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 [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 [9 x i8] c"*IntCell\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 [9 x i8] c"*StrCell\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 [13 x i8] c"**CAllocator\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 [7 x i8] c"**void\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 [9 x i8] c"*VL__s64\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 [10 x i8] c"**IntCell\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 [19 x i8] c"*__VL__s64__Vtable\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 [8 x i8] c"*string\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"*Any\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"*[1]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 [7 x i8] c"*[]Any\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 [6 x i8] c"*bool\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 [12 x i8] c"*VL__string\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 [10 x i8] c"**StrCell\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 [22 x i8] c"*__VL__string__Vtable\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 [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 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -706,85 +706,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -927,7 +849,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1054,7 +976,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1388,7 +1310,7 @@ entry: br i1 %icmp, label %if.then.412, label %if.merge.413 if.then.412: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.413: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1538,7 +1460,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1565,12 +1487,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1601,25 +1523,25 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 107, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 105, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1662,7 +1584,7 @@ match.merge.37: ; preds = %dispatch.merge.536, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1707,12 +1629,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1769,7 +1691,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.300 [ - i64 35, label %dispatch.case.301 + i64 22, label %dispatch.case.301 i64 81, label %dispatch.case.302 i64 87, label %dispatch.case.303 i64 88, label %dispatch.case.304 @@ -1782,7 +1704,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.338 [ - i64 36, label %dispatch.case.339 + i64 23, label %dispatch.case.339 i64 60, label %dispatch.case.340 i64 77, label %dispatch.case.341 i64 85, label %dispatch.case.342 @@ -1795,13 +1717,13 @@ 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 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 - i64 33, label %dispatch.case.378 + i64 25, label %dispatch.case.372 + i64 27, label %dispatch.case.373 + i64 29, label %dispatch.case.374 + i64 31, label %dispatch.case.375 + i64 32, label %dispatch.case.376 + i64 34, label %dispatch.case.377 + i64 36, label %dispatch.case.378 i64 40, label %dispatch.case.379 i64 44, label %dispatch.case.380 i64 47, label %dispatch.case.381 @@ -1902,7 +1824,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.324, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.326, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1924,56 +1846,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2159,7 +2081,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.325, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.327, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.282 dispatch.case.284: ; preds = %match.arm.44 @@ -2200,7 +2122,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.326, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.328, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.299 dispatch.case.301: ; preds = %match.arm.47 @@ -2257,7 +2179,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.327, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.329, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.337 dispatch.case.339: ; preds = %match.arm.48 @@ -2306,7 +2228,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.328, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.330, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.369 dispatch.case.371: ; preds = %match.arm.49 @@ -2581,7 +2503,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.329, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.331, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.536 dispatch.case.538: ; preds = %match.arm.50 @@ -2623,7 +2545,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.330, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.332, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2719,7 +2641,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.331, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, 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 @@ -2727,7 +2649,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.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 @@ -2737,13 +2659,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.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 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.334, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, 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 @@ -2751,7 +2673,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.335, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2765,7 +2687,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.336, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, 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 @@ -2773,7 +2695,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.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 i64, ptr %allocaN, align 8 @@ -2784,7 +2706,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.338, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2841,7 +2763,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.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 @@ -2849,7 +2771,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.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 @@ -2860,7 +2782,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.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 @@ -2880,7 +2802,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.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 @@ -2888,7 +2810,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.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 }, ptr %alloca, align 8 @@ -2899,7 +2821,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.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 br label %if.merge.36 @@ -2909,67 +2831,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3145,166 +3151,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3502,64 +3508,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3589,97 +3595,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3718,7 +3724,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i64 @IntCell.get(ptr %0, ptr %1) #0 { @@ -3766,7 +3772,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.345, i64 2 } }, ptr %allocaN, align 8 + store { { ptr, i64 } } { { ptr, i64 } { ptr @str.347, 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 @@ -3811,7 +3817,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.346, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.348, 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 @@ -3826,7 +3832,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 6) @@ -3853,7 +3859,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.348, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.350, i64 9 }) ret { ptr, i64 } %call } @@ -3868,7 +3874,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.349, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.351, 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 @@ -3886,7 +3892,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.350, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.352, 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) @@ -3916,7 +3922,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.351, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.353, i64 9 }) ret { ptr, i64 } %call } @@ -3927,7 +3933,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.352, i64 15 }, { ptr, i64 } { ptr @str.353, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.354, i64 15 }, { 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 @@ -3946,12 +3952,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.354, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.356, 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.355, i64 2 }) + %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.131 @@ -3963,7 +3969,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.359, 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, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4020,7 +4026,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.360, i64 9 }, { ptr, i64 } { ptr @str.361, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.362, i64 9 }, { 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 @@ -4039,24 +4045,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.362, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, 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.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 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 [3 x { ptr, i64 }], ptr @field_names.367, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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, ptr, ptr }, ptr %alloca, align 8 @@ -4100,20 +4106,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.369, i64 10 }, { ptr, i64 } { ptr @str.370, i64 1 }) + %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.371, i64 7 }, { 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.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, 2 br i1 %icmp, label %while.body.138, label %while.exit.139 while.body.138: ; preds = %while.hdr.137 @@ -4123,24 +4130,102 @@ 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.371, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, 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 }) + %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.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.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.374, 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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.137 + +fv.default: ; preds = %if.merge.141 + br label %fv.merge + +fv.case: ; preds = %if.merge.141 + %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + store { ptr, ptr, ptr } %fv.field, ptr %ba.tmp, align 8 + %ba.p2i = ptrtoint ptr %ba.tmp to i64 + %fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.141 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.379, i64 10 }, { 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.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.381, 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 }) + 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.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, 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 @@ -4151,7 +4236,7 @@ if.merge.141: ; preds = %if.then.140, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.137 + br label %while.hdr.142 } ; Function Attrs: nounwind @@ -4159,43 +4244,43 @@ 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 }) + %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.142 + br label %while.hdr.147 -while.hdr.142: ; preds = %fv.merge, %entry +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.143, label %while.exit.144 + br i1 %icmp, label %while.body.148, label %while.exit.149 -while.body.143: ; preds = %while.hdr.142 +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.145, label %if.merge.146 + br i1 %icmpN, label %if.then.150, label %if.merge.151 -while.exit.144: ; preds = %while.hdr.142 +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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.387, i64 1 }) ret { ptr, i64 } %callN -if.then.145: ; preds = %while.body.143 +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 }) + %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.146 + br label %if.merge.151 -if.merge.146: ; preds = %if.then.145, %while.body.143 +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.380, i64 0, i64 %loadN + %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.381, 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 { i64 }, ptr %alloca, align 8 @@ -4212,12 +4297,12 @@ 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 + br label %while.hdr.147 -fv.default: ; preds = %if.merge.146 +fv.default: ; preds = %if.merge.151 br label %fv.merge -fv.case: ; preds = %if.merge.146 +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 @@ -4228,43 +4313,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %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.147 + br label %while.hdr.152 -while.hdr.147: ; preds = %fv.merge, %entry +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.148, label %while.exit.149 + br i1 %icmp, label %while.body.153, label %while.exit.154 -while.body.148: ; preds = %while.hdr.147 +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.150, label %if.merge.151 + br i1 %icmpN, label %if.then.155, label %if.merge.156 -while.exit.149: ; preds = %while.hdr.147 +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.384, 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.150: ; preds = %while.body.148 +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.385, 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.151 + br label %if.merge.156 -if.merge.151: ; preds = %if.then.150, %while.body.148 +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.388, i64 0, i64 %loadN + %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.389, 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 %alloca, align 8 @@ -4282,18 +4367,18 @@ 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.147 + br label %while.hdr.152 -fv.default: ; preds = %if.merge.151 +fv.default: ; preds = %if.merge.156 br label %fv.merge -fv.case: ; preds = %if.merge.151 +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 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.151 +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 @@ -4305,91 +4390,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.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 - 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.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.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.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.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 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.152 - -fv.default: ; preds = %if.merge.156 - br label %fv.merge - -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 - br label %fv.merge - -fv.case17: ; preds = %if.merge.156 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.399, i64 8 }, { ptr, i64 } { ptr @str.400, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.400, i64 5 }, { 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 @@ -4408,27 +4409,27 @@ 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.401, 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.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.402, 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.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.406, 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.407, 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 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4450,29 +4451,30 @@ fv.default: ; preds = %if.merge.161 br label %fv.merge fv.case: ; preds = %if.merge.161 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.161 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.161 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.408, i64 17 }, { ptr, i64 } { ptr @str.409, i64 1 }) + %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.409, i64 8 }, { 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 @@ -4481,7 +4483,7 @@ entry: while.hdr.162: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.163, label %while.exit.164 while.body.163: ; preds = %while.hdr.162 @@ -4491,19 +4493,19 @@ 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.410, 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.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.411, 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.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.416, i64 0, i64 %loadN + %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 @@ -4511,17 +4513,16 @@ if.merge.166: ; preds = %if.then.165, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4534,35 +4535,29 @@ fv.default: ; preds = %if.merge.166 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.166 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.166 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.166 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.418, i64 7 }, { ptr, i64 } { ptr @str.419, i64 1 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.418, i64 17 }, { 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 @@ -4571,7 +4566,7 @@ entry: while.hdr.167: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.168, label %while.exit.169 while.body.168: ; preds = %while.hdr.167 @@ -4593,23 +4588,25 @@ if.then.170: ; preds = %while.body.168 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.424, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4622,16 +4619,25 @@ fv.default: ; preds = %if.merge.171 br label %fv.merge fv.case: ; preds = %if.merge.171 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.171 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.171 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.171 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4640,7 +4646,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.426, i64 4 }, { ptr, i64 } { ptr @str.427, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.428, i64 4 }, { 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 @@ -4659,24 +4665,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.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.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.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.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.431, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i32 }, ptr %alloca, align 4 @@ -4713,7 +4719,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.433, i64 10 }, { ptr, i64 } { ptr @str.434, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.435, i64 10 }, { 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 @@ -4732,24 +4738,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.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.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.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.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.442, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4815,7 +4821,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.444, i64 13 }, { ptr, i64 } { ptr @str.445, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.446, i64 13 }, { 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 @@ -4834,24 +4840,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.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.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.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.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.450, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, i64 } }, ptr %alloca, align 8 @@ -4893,7 +4899,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.452, i64 8 }, { ptr, i64 } { ptr @str.453, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.454, i64 8 }, { 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 @@ -4912,24 +4918,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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4990,7 +4996,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.463, i64 5 }, { ptr, i64 } { ptr @str.464, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.465, i64 5 }, { 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 @@ -5009,24 +5015,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 [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 @@ -5072,7 +5078,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.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 @@ -5091,24 +5097,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.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.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.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.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.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 %alloca, align 8 @@ -5156,7 +5162,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.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 @@ -5175,24 +5181,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.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.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.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.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.487, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, [24 x i8] } }, ptr %alloca, align 8 @@ -5236,7 +5242,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.489, i64 4 }, { ptr, i64 } { ptr @str.490, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.491, i64 4 }, { 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 @@ -5255,24 +5261,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.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.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.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.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.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 %alloca, align 8 @@ -5322,7 +5328,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.498, i64 6 }, { ptr, i64 } { ptr @str.499, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.500, i64 6 }, { 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 @@ -5341,24 +5347,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.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.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.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.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.505, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.507, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.506, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, 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 @@ -5407,7 +5413,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.507, i64 12 }, { ptr, i64 } { ptr @str.508, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.509, i64 12 }, { ptr, i64 } { ptr @str.510, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5426,24 +5432,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.509, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.511, 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.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 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.511, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 %alloca, align 1 @@ -5463,7 +5469,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.513, i64 8 }, { ptr, i64 } { ptr @str.514, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.515, i64 8 }, { 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 @@ -5482,24 +5488,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.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.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.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.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.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 }, i1, i1 }, ptr %alloca, align 8 @@ -5551,7 +5557,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.522, i64 7 }, { ptr, i64 } { ptr @str.523, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.524, i64 7 }, { 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 @@ -5570,24 +5576,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.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.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.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.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.529, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5639,7 +5645,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.531, i64 9 }, { ptr, i64 } { ptr @str.532, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.533, i64 9 }, { 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 @@ -5658,24 +5664,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.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.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.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.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.537, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.539, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5718,7 +5724,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.539, i64 4 }, { ptr, i64 } { ptr @str.540, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.541, i64 4 }, { ptr, i64 } { ptr @str.542, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5737,24 +5743,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.541, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, 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.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 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.545, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5800,7 +5806,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.547, i64 6 }, { ptr, i64 } { ptr @str.548, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.549, i64 6 }, { ptr, i64 } { ptr @str.550, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5819,24 +5825,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.549, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.551, 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.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 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.558, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 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 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5893,7 +5899,7 @@ fv.case28: ; preds = %if.merge.246 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.246 @@ -5918,7 +5924,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.560, i64 6 }, { ptr, i64 } { ptr @str.561, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 6 }, { 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 @@ -5937,24 +5943,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.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.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.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.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.568, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.570, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6009,7 +6015,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.570, i64 7 }, { ptr, i64 } { ptr @str.571, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.572, i64 7 }, { ptr, i64 } { ptr @str.573, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6028,24 +6034,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.572, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.574, 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.573, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.575, 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.575, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i64 }, ptr %alloca, align 8 @@ -6079,7 +6085,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.577, i64 7 }, { ptr, i64 } { ptr @str.578, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 7 }, { 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 @@ -6098,24 +6104,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.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.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.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.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.582, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.584, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, 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 @@ -6150,7 +6156,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.584, i64 7 }, { ptr, i64 } { ptr @str.585, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, i64 7 }, { ptr, i64 } { ptr @str.587, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6169,24 +6175,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.586, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.588, 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.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 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.590, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.592, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -6227,7 +6233,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.592, i64 17 }, { ptr, i64 } { ptr @str.593, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.594, i64 17 }, { ptr, i64 } { ptr @str.595, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6246,24 +6252,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.594, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.596, 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.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.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.597, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.599, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr }, ptr %alloca, align 8 @@ -6297,7 +6303,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.599, i64 10 }, { ptr, i64 } { ptr @str.600, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.601, i64 10 }, { ptr, i64 } { ptr @str.602, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6316,24 +6322,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.601, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, 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.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 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.605, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.607, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -6374,7 +6380,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.607, i64 20 }, { ptr, i64 } { ptr @str.608, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.609, i64 20 }, { ptr, i64 } { ptr @str.610, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6393,24 +6399,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.609, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, 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.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.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.612, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 }, ptr %alloca, align 8 @@ -6448,9 +6454,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.619, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.621, 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.614, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.616, 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 @@ -6469,8 +6475,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.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 } { ptr @str.623, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.622, 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 @@ -6489,9 +6495,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.626, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.628, 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.622, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.624, 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 @@ -6510,8 +6516,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.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 } { ptr @str.630, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.629, 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 @@ -6541,9 +6547,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.636, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.638, 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.629, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.631, 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 @@ -6560,8 +6566,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.294 @@ -6639,9 +6645,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.647, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.649, 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.639, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.641, 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 @@ -6660,8 +6666,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.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 } { ptr @str.651, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, 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 @@ -6680,9 +6686,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.656, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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.650, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, 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 @@ -6701,8 +6707,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.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.298 @@ -6719,7 +6725,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.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.307 @@ -6736,12 +6742,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.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.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.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.311 @@ -6770,7 +6776,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.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.312 @@ -6787,12 +6793,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.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.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.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.316 @@ -6822,7 +6828,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.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.317 @@ -6839,12 +6845,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.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.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.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.321 @@ -6872,7 +6878,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.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.322 @@ -6889,12 +6895,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.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.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.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.326 @@ -6923,7 +6929,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.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.327 @@ -6940,12 +6946,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.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.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.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.331 @@ -6974,7 +6980,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.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.332 @@ -6991,12 +6997,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.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.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.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.336 @@ -7026,7 +7032,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.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.344 @@ -7045,12 +7051,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.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.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.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.348 @@ -7079,7 +7085,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.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.349 @@ -7098,12 +7104,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.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.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.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.353 @@ -7132,7 +7138,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.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.354 @@ -7151,12 +7157,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.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.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.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.358 @@ -7186,7 +7192,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.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.359 @@ -7205,12 +7211,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.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.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.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.363 @@ -7240,7 +7246,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.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.364 @@ -7259,12 +7265,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.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.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.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.368 @@ -7306,12 +7312,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.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.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -7334,12 +7340,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.697, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.696, i64 11 }, { 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 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.695, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] + %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] ret { ptr, i64 } %bp } @@ -7362,12 +7368,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.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.430 if.merge.430: ; preds = %if.else.429, %if.then.428 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] ret { ptr, i64 } %bp } @@ -7390,12 +7396,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.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.433 if.merge.433: ; preds = %if.else.432, %if.then.431 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] ret { ptr, i64 } %bp } @@ -7418,12 +7424,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.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.436 if.merge.436: ; preds = %if.else.435, %if.then.434 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] ret { ptr, i64 } %bp } @@ -7445,12 +7451,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.709, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.708, i64 5 }, { 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 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.707, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] ret { ptr, i64 } %bp } @@ -7473,12 +7479,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.712, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.711, i64 9 }, { 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 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.710, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] ret { ptr, i64 } %bp } @@ -7501,12 +7507,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.715, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.714, i64 18 }, { 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 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.713, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] ret { ptr, i64 } %bp } @@ -7529,12 +7535,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.718, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 5 }, { 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 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.716, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] ret { ptr, i64 } %bp } @@ -7557,12 +7563,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.721, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 3 }, { 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 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.719, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] ret { ptr, i64 } %bp } @@ -7585,12 +7591,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.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.454 if.merge.454: ; preds = %if.else.453, %if.then.452 - %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] ret { ptr, i64 } %bp } @@ -7613,12 +7619,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.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.457 if.merge.457: ; preds = %if.else.456, %if.then.455 - %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] + %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] ret { ptr, i64 } %bp } @@ -7641,12 +7647,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.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.460 if.merge.460: ; preds = %if.else.459, %if.then.458 - %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] + %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] ret { ptr, i64 } %bp } @@ -7668,12 +7674,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.733, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.732, i64 8 }, { 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 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.731, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] + %bp = phi { ptr, i64 } [ { ptr @str.733, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] ret { ptr, i64 } %bp } @@ -7696,12 +7702,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.736, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 6 }, { 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 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.734, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] + %bp = phi { ptr, i64 } [ { ptr @str.736, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] ret { ptr, i64 } %bp } @@ -7723,12 +7729,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.739, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 9 }, { 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 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.737, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] + %bp = phi { ptr, i64 } [ { ptr @str.739, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] ret { ptr, i64 } %bp } @@ -7751,12 +7757,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.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.472 if.merge.472: ; preds = %if.else.471, %if.then.470 - %bp = phi { ptr, i64 } [ { ptr @str.740, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] + %bp = phi { ptr, i64 } [ { ptr @str.742, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] ret { ptr, i64 } %bp } @@ -7779,12 +7785,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.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.475 if.merge.475: ; preds = %if.else.474, %if.then.473 - %bp = phi { ptr, i64 } [ { ptr @str.743, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] + %bp = phi { ptr, i64 } [ { ptr @str.745, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] ret { ptr, i64 } %bp } @@ -7807,12 +7813,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.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.478 if.merge.478: ; preds = %if.else.477, %if.then.476 - %bp = phi { ptr, i64 } [ { ptr @str.746, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] + %bp = phi { ptr, i64 } [ { ptr @str.748, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] ret { ptr, i64 } %bp } @@ -7835,12 +7841,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.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.481 if.merge.481: ; preds = %if.else.480, %if.then.479 - %bp = phi { ptr, i64 } [ { ptr @str.749, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] + %bp = phi { ptr, i64 } [ { ptr @str.751, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] ret { ptr, i64 } %bp } @@ -7863,12 +7869,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.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.484 if.merge.484: ; preds = %if.else.483, %if.then.482 - %bp = phi { ptr, i64 } [ { ptr @str.752, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] + %bp = phi { ptr, i64 } [ { ptr @str.754, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] ret { ptr, i64 } %bp } @@ -7891,12 +7897,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.757, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 5 }, { 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 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.755, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] + %bp = phi { ptr, i64 } [ { ptr @str.757, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] ret { ptr, i64 } %bp } @@ -7919,12 +7925,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.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.490 if.merge.490: ; preds = %if.else.489, %if.then.488 - %bp = phi { ptr, i64 } [ { ptr @str.758, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] + %bp = phi { ptr, i64 } [ { ptr @str.760, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] ret { ptr, i64 } %bp } @@ -7947,12 +7953,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.763, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 8 }, { 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 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.761, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] + %bp = phi { ptr, i64 } [ { ptr @str.763, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] ret { ptr, i64 } %bp } @@ -7975,12 +7981,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.766, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 8 }, { 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 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.764, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] + %bp = phi { ptr, i64 } [ { ptr @str.766, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] ret { ptr, i64 } %bp } @@ -8003,12 +8009,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.769, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 12 }, { 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 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.767, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] + %bp = phi { ptr, i64 } [ { ptr @str.769, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] ret { ptr, i64 } %bp } @@ -8031,12 +8037,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.772, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 6 }, { 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 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.770, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] + %bp = phi { ptr, i64 } [ { ptr @str.772, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] ret { ptr, i64 } %bp } @@ -8059,12 +8065,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.775, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 8 }, { 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 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.773, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] + %bp = phi { ptr, i64 } [ { ptr @str.775, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] ret { ptr, i64 } %bp } @@ -8087,12 +8093,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.778, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 9 }, { 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 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.776, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] + %bp = phi { ptr, i64 } [ { ptr @str.778, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] ret { ptr, i64 } %bp } @@ -8115,12 +8121,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.781, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 18 }, { 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 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.779, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] + %bp = phi { ptr, i64 } [ { ptr @str.781, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] ret { ptr, i64 } %bp } @@ -8143,12 +8149,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.784, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 7 }, { 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 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.782, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] + %bp = phi { ptr, i64 } [ { ptr @str.784, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] ret { ptr, i64 } %bp } @@ -8171,12 +8177,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.787, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 4 }, { 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 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.785, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] + %bp = phi { ptr, i64 } [ { ptr @str.787, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] ret { ptr, i64 } %bp } @@ -8199,12 +8205,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.790, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 7 }, { 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 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.788, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] + %bp = phi { ptr, i64 } [ { ptr @str.790, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] ret { ptr, i64 } %bp } @@ -8227,12 +8233,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.793, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 6 }, { 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 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.791, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] + %bp = phi { ptr, i64 } [ { ptr @str.793, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] ret { ptr, i64 } %bp } @@ -8255,12 +8261,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.796, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 5 }, { 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 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.794, i64 4 }, %if.then.524 ], [ %callN, %if.else.525 ] + %bp = phi { ptr, i64 } [ { ptr @str.796, i64 4 }, %if.then.524 ], [ %callN, %if.else.525 ] ret { ptr, i64 } %bp } @@ -8283,12 +8289,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.799, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 11 }, { 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 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.797, i64 4 }, %if.then.527 ], [ %callN, %if.else.528 ] + %bp = phi { ptr, i64 } [ { ptr @str.799, i64 4 }, %if.then.527 ], [ %callN, %if.else.528 ] ret { ptr, i64 } %bp } @@ -8311,12 +8317,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.802, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 9 }, { 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 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.800, i64 4 }, %if.then.530 ], [ %callN, %if.else.531 ] + %bp = phi { ptr, i64 } [ { ptr @str.802, i64 4 }, %if.then.530 ], [ %callN, %if.else.531 ] ret { ptr, i64 } %bp } @@ -8339,12 +8345,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.805, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 21 }, { 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 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.803, i64 4 }, %if.then.533 ], [ %callN, %if.else.534 ] + %bp = phi { ptr, i64 } [ { ptr @str.805, i64 4 }, %if.then.533 ], [ %callN, %if.else.534 ] ret { ptr, i64 } %bp } @@ -8360,7 +8366,7 @@ entry: br i1 %lnot, label %if.then.542, label %if.merge.543 if.then.542: ; preds = %entry - ret { ptr, i64 } { ptr @str.806, i64 4 } + ret { ptr, i64 } { ptr @str.808, i64 4 } if.merge.543: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8384,7 +8390,7 @@ entry: br i1 %lnot, label %if.then.544, label %if.merge.545 if.then.544: ; preds = %entry - ret { ptr, i64 } { ptr @str.807, i64 4 } + ret { ptr, i64 } { ptr @str.809, i64 4 } if.merge.545: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8408,7 +8414,7 @@ entry: br i1 %lnot, label %if.then.546, label %if.merge.547 if.then.546: ; preds = %entry - ret { ptr, i64 } { ptr @str.808, i64 4 } + ret { ptr, i64 } { ptr @str.810, i64 4 } if.merge.547: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8432,7 +8438,7 @@ entry: br i1 %lnot, label %if.then.548, label %if.merge.549 if.then.548: ; preds = %entry - ret { ptr, i64 } { ptr @str.809, i64 4 } + ret { ptr, i64 } { ptr @str.811, 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 c47329a..b9671b5 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [8 x i8] c"IntCell\00" +@tn.str.241 = private constant [9 x i8] c"*IntCell\00" +@tn.str.242 = private constant [2 x i8] c"R\00" +@tn.str.243 = private constant [9 x i8] c"Combined\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 [3 x i8] c"VL\00" +@tn.str.247 = private constant [5 x i8] c"[]VL\00" +@tn.str.248 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.249 = private constant [7 x i8] c"**void\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 [10 x i8] c"(VL__s64)\00" +@tn.str.256 = private constant [19 x i8] c"Combined__s64__s64\00" +@tn.str.257 = private constant [20 x i8] c"*Combined__s64__s64\00" +@tn.str.258 = private constant [10 x i8] c"**IntCell\00" +@tn.str.259 = private constant [19 x i8] c"*__VL__s64__Vtable\00" +@tn.str.260 = private constant [11 x i8] c"*(VL__s64)\00" +@tn.str.261 = private constant [21 x i8] c"**Combined__s64__s64\00" +@tn.str.262 = private constant [9 x i8] c"*VL__s64\00" +@tn.str.263 = private constant [8 x i8] c"*string\00" +@tn.str.264 = private constant [6 x i8] c"*bool\00" +@tn.str.265 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.266 = private constant [5 x i8] c"*f64\00" +@tn.str.267 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.268 = private constant [11 x i8] c"*Allocator\00" +@tn.str.269 = private constant [9 x i8] c"*Context\00" +@tn.str.270 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.271 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.272 = private constant [8 x i8] c"*Member\00" +@tn.str.273 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.274 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.275 = private constant [9 x i8] c"*Command\00" +@tn.str.276 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.277 = private constant [3 x i8] c"*R\00" +@tn.str.278 = private constant [10 x i8] c"*Combined\00" +@tn.str.279 = private constant [4 x i8] c"*VL\00" +@tn.str.280 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.281 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.282 = private constant [7 x i8] c"*Value\00" +@tn.str.283 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.284 = private constant [14 x i8] c"*Architecture\00" +@tn.str.285 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.286 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.287 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.288 = private constant [9 x i8] c"*[64]s64\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"*[]VL\00" +@tn.str.294 = private constant [6 x i8] c"**GPA\00" +@tn.str.295 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.296 = private constant [8 x i8] c"**Arena\00" +@tn.str.297 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.298 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.299 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.300 = private constant [7 x i8] c"**File\00" +@tn.str.301 = private constant [5 x i8] c"**u8\00" +@tn.str.302 = private constant [6 x i8] c"**s32\00" +@tn.str.303 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.304 = private constant [6 x i8] c"**u32\00" +@tn.str.305 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.306 = private constant [8 x i8] c"**Array\00" +@tn.str.307 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.308 = private constant [9 x i8] c"**Object\00" +@tn.str.309 = private constant [7 x i8] c"**Sink\00" +@tn.str.310 = private constant [9 x i8] c"**Parser\00" +@tn.str.311 = private constant [6 x i8] c"**s64\00" +@tn.str.312 = private constant [9 x i8] c"**Parsed\00" +@tn.str.313 = private constant [7 x i8] c"**Diag\00" +@tn.str.314 = private constant [9 x i8] c"**Sha256\00" +@tn.str.315 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.316 = private constant [8 x i8] c"***void\00" +@tn.str.317 = private constant [6 x i8] c"**Any\00" +@tn.str.318 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.319 = private constant [8 x i8] c"**[]Any\00" +@tn.str.320 = private constant [11 x i8] c"***IntCell\00" +@tn.str.321 = private constant [20 x i8] c"**__VL__s64__Vtable\00" +@tn.str.322 = private constant [12 x i8] c"**(VL__s64)\00" +@tn.str.323 = private constant [22 x i8] c"***Combined__s64__s64\00" +@tn.str.324 = private constant [10 x i8] c"**VL__s64\00" +@tn.str.325 = private constant [9 x i8] c"**string\00" +@tn.str.326 = private constant [7 x i8] c"**bool\00" +@tn.str.327 = private constant [7 x i8] c"*?File\00" +@tn.str.328 = private constant [9 x i8] c"*?string\00" +@tn.str.329 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.330 = 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.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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 7 }, { ptr, i64 } { ptr @tn.str.241, i64 8 }, { ptr, i64 } { ptr @tn.str.242, i64 1 }, { ptr, i64 } { ptr @tn.str.243, i64 8 }, { ptr, i64 } { ptr @tn.str.244, i64 7 }, { ptr, i64 } { ptr @tn.str.245, i64 17 }, { ptr, i64 } { ptr @tn.str.246, i64 2 }, { ptr, i64 } { ptr @tn.str.247, i64 4 }, { ptr, i64 } { ptr @tn.str.248, i64 12 }, { ptr, i64 } { ptr @tn.str.249, i64 6 }, { 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 9 }, { ptr, i64 } { ptr @tn.str.256, i64 18 }, { ptr, i64 } { ptr @tn.str.257, i64 19 }, { ptr, i64 } { ptr @tn.str.258, i64 9 }, { ptr, i64 } { ptr @tn.str.259, i64 18 }, { ptr, i64 } { ptr @tn.str.260, i64 10 }, { ptr, i64 } { ptr @tn.str.261, i64 20 }, { ptr, i64 } { ptr @tn.str.262, i64 8 }, { ptr, i64 } { ptr @tn.str.263, i64 7 }, { ptr, i64 } { ptr @tn.str.264, i64 5 }, { ptr, i64 } { ptr @tn.str.265, i64 7 }, { ptr, i64 } { ptr @tn.str.266, i64 4 }, { ptr, i64 } { ptr @tn.str.267, i64 16 }, { ptr, i64 } { ptr @tn.str.268, i64 10 }, { ptr, i64 } { ptr @tn.str.269, i64 8 }, { ptr, i64 } { ptr @tn.str.270, i64 11 }, { ptr, i64 } { ptr @tn.str.271, i64 14 }, { ptr, i64 } { ptr @tn.str.272, i64 7 }, { ptr, i64 } { ptr @tn.str.273, i64 13 }, { ptr, i64 } { ptr @tn.str.274, i64 9 }, { ptr, i64 } { ptr @tn.str.275, i64 8 }, { ptr, i64 } { ptr @tn.str.276, i64 10 }, { ptr, i64 } { ptr @tn.str.277, i64 2 }, { ptr, i64 } { ptr @tn.str.278, i64 9 }, { ptr, i64 } { ptr @tn.str.279, i64 3 }, { ptr, i64 } { ptr @tn.str.280, i64 9 }, { ptr, i64 } { ptr @tn.str.281, i64 9 }, { ptr, i64 } { ptr @tn.str.282, i64 6 }, { ptr, i64 } { ptr @tn.str.283, i64 16 }, { ptr, i64 } { ptr @tn.str.284, i64 13 }, { ptr, i64 } { ptr @tn.str.285, i64 14 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 7 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.295, i64 12 }, { ptr, i64 } { ptr @tn.str.296, i64 7 }, { ptr, i64 } { ptr @tn.str.297, i64 6 }, { ptr, i64 } { ptr @tn.str.298, i64 10 }, { ptr, i64 } { ptr @tn.str.299, i64 19 }, { ptr, i64 } { ptr @tn.str.300, i64 6 }, { ptr, i64 } { ptr @tn.str.301, i64 4 }, { ptr, i64 } { ptr @tn.str.302, i64 5 }, { ptr, i64 } { ptr @tn.str.303, i64 10 }, { ptr, i64 } { ptr @tn.str.304, i64 5 }, { ptr, i64 } { ptr @tn.str.305, i64 9 }, { ptr, i64 } { ptr @tn.str.306, i64 7 }, { ptr, i64 } { ptr @tn.str.307, i64 10 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.312, i64 8 }, { ptr, i64 } { ptr @tn.str.313, i64 6 }, { ptr, i64 } { ptr @tn.str.314, i64 8 }, { ptr, i64 } { ptr @tn.str.315, i64 13 }, { ptr, i64 } { ptr @tn.str.316, i64 7 }, { ptr, i64 } { ptr @tn.str.317, i64 5 }, { ptr, i64 } { ptr @tn.str.318, i64 8 }, { ptr, i64 } { ptr @tn.str.319, i64 7 }, { ptr, i64 } { ptr @tn.str.320, i64 10 }, { ptr, i64 } { ptr @tn.str.321, i64 19 }, { ptr, i64 } { ptr @tn.str.322, i64 11 }, { ptr, i64 } { ptr @tn.str.323, i64 21 }, { ptr, i64 } { ptr @tn.str.324, i64 9 }, { ptr, i64 } { ptr @tn.str.325, i64 8 }, { ptr, i64 } { ptr @tn.str.326, i64 6 }, { ptr, i64 } { ptr @tn.str.327, i64 6 }, { ptr, i64 } { ptr @tn.str.328, i64 8 }, { ptr, i64 } { ptr @tn.str.329, i64 15 }, { ptr, i64 } { ptr @tn.str.330, i64 8 }] @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 [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 [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 [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 +@str.353 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.354 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 +@str.355 = private unnamed_addr constant [16 x i8] c"Source_Location\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 = private constant [5 x i8] c"file\00" -@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 }] +@fld.str.359 = private constant [5 x i8] c"line\00" +@fld.str.360 = private constant [4 x i8] c"col\00" +@fld.str.361 = 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.359, i64 4 }, { ptr, i64 } { ptr @fld.str.360, i64 3 }, { ptr, i64 } { ptr @fld.str.361, i64 4 }] +@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 [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.377 = private constant [5 x i8] c"data\00" +@field_names.378 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.376, i64 9 }, { ptr, i64 } { ptr @fld.str.377, i64 4 }] +@str.379 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.380 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.384 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.385 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.386 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.391 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.390, i64 11 }] +@str.392 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.393 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.398 = private constant [4 x i8] c"cap\00" +@field_names.399 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.397, i64 4 }, { 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.406 = private constant [10 x i8] c"end_index\00" +@fld.str.407 = private constant [7 x i8] c"parent\00" +@field_names.408 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.405, i64 5 }, { ptr, i64 } { ptr @fld.str.406, i64 9 }, { ptr, i64 } { ptr @fld.str.407, i64 6 }] +@str.409 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.410 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.415 = private constant [4 x i8] c"len\00" +@fld.str.416 = private constant [4 x i8] c"pos\00" +@field_names.417 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.414, i64 3 }, { ptr, i64 } { ptr @fld.str.415, i64 3 }, { 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 [8 x i8] c"Context\00", align 1 +@str.419 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.423 = private constant [7 x i8] c"parent\00" +@fld.str.424 = private constant [12 x i8] c"alloc_count\00" +@fld.str.425 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.426 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.427 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.423, i64 6 }, { ptr, i64 } { ptr @fld.str.424, i64 11 }, { ptr, i64 } { ptr @fld.str.425, i64 13 }, { ptr, i64 } { ptr @fld.str.426, i64 17 }] +@str.428 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.429 = private unnamed_addr constant [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.434 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.433, i64 2 }] +@str.435 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.436 = private unnamed_addr constant [11 x i8] c"TraceFrame\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 [5 x i8] c"file\00" +@fld.str.441 = private constant [5 x i8] c"line\00" +@fld.str.442 = private constant [4 x i8] c"col\00" +@fld.str.443 = private constant [5 x i8] c"func\00" +@fld.str.444 = private constant [10 x i8] c"line_text\00" +@field_names.445 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.440, i64 4 }, { ptr, i64 } { ptr @fld.str.441, i64 4 }, { ptr, i64 } { ptr @fld.str.442, i64 3 }, { ptr, i64 } { ptr @fld.str.443, i64 4 }, { ptr, i64 } { ptr @fld.str.444, i64 9 }] +@str.446 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.447 = private unnamed_addr constant [14 x i8] c"ProcessResult\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 [10 x i8] c"exit_code\00" +@fld.str.452 = private constant [7 x i8] c"stdout\00" +@field_names.453 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.451, i64 9 }, { ptr, i64 } { ptr @fld.str.452, i64 6 }] +@str.454 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.455 = private unnamed_addr constant [9 x i8] c"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.460 = private constant [11 x i8] c"sin_family\00" +@fld.str.461 = private constant [9 x i8] c"sin_port\00" +@fld.str.462 = private constant [9 x i8] c"sin_addr\00" +@fld.str.463 = private constant [9 x i8] c"sin_zero\00" +@field_names.464 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.459, i64 7 }, { ptr, i64 } { ptr @fld.str.460, i64 10 }, { ptr, i64 } { ptr @fld.str.461, i64 8 }, { ptr, i64 } { ptr @fld.str.462, i64 8 }, { ptr, i64 } { ptr @fld.str.463, i64 8 }] +@str.465 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.466 = private unnamed_addr constant [6 x i8] c"Array\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 [6 x i8] c"items\00" +@fld.str.471 = private constant [4 x i8] c"len\00" +@fld.str.472 = private constant [4 x i8] c"cap\00" +@field_names.473 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.470, i64 5 }, { 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 [7 x i8] c"Object\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 [6 x i8] c"items\00" +@fld.str.480 = private constant [4 x i8] c"len\00" +@fld.str.481 = private constant [4 x i8] c"cap\00" +@field_names.482 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.479, i64 5 }, { ptr, i64 } { ptr @fld.str.480, i64 3 }, { ptr, i64 } { ptr @fld.str.481, i64 3 }] +@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.484 = private unnamed_addr constant [7 x i8] c"Member\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"key\00" +@fld.str.489 = private constant [4 x i8] c"val\00" +@field_names.490 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.488, i64 3 }, { ptr, i64 } { ptr @fld.str.489, i64 3 }] +@str.491 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.492 = private unnamed_addr constant [5 x i8] c"Sink\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 [4 x i8] c"dst\00" +@fld.str.497 = private constant [4 x i8] c"pos\00" +@fld.str.498 = private constant [5 x i8] c"file\00" +@field_names.499 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.496, i64 3 }, { ptr, i64 } { ptr @fld.str.497, i64 3 }, { ptr, i64 } { ptr @fld.str.498, i64 4 }] +@str.500 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.501 = private unnamed_addr constant [7 x i8] c"Parser\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 [4 x i8] c"src\00" +@fld.str.506 = private constant [4 x i8] c"pos\00" +@fld.str.507 = private constant [6 x i8] c"alloc\00" +@field_names.508 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.505, i64 3 }, { ptr, i64 } { ptr @fld.str.506, i64 3 }, { 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 [13 x i8] c"BuildOptions\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 +@field_names.514 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.515 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.516 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.521 = private constant [12 x i8] c"takes_value\00" +@fld.str.522 = private constant [9 x i8] c"required\00" +@field_names.523 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.520, i64 4 }, { ptr, i64 } { ptr @fld.str.521, i64 11 }, { ptr, i64 } { ptr @fld.str.522, i64 8 }] +@str.524 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.525 = private unnamed_addr constant [8 x i8] c"Command\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 [6 x i8] c"flags\00" +@field_names.532 = private constant [3 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 5 }] +@str.533 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.534 = private unnamed_addr constant [10 x i8] c"FlagValue\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"set\00" +@fld.str.539 = private constant [6 x i8] c"value\00" +@field_names.540 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.538, i64 3 }, { ptr, i64 } { ptr @fld.str.539, i64 5 }] +@str.541 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.542 = private unnamed_addr constant [5 x i8] c"Diag\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 [6 x i8] c"index\00" +@fld.str.547 = private constant [6 x i8] c"token\00" +@field_names.548 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.546, i64 5 }, { 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 [7 x i8] c"Parsed\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 [10 x i8] c"cmd_index\00" +@fld.str.557 = private constant [5 x i8] c"json\00" +@fld.str.558 = private constant [5 x i8] c"rest\00" +@fld.str.559 = private constant [5 x i8] c"spec\00" +@fld.str.560 = private constant [7 x i8] c"values\00" +@field_names.561 = private constant [7 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 9 }, { ptr, i64 } { ptr @fld.str.557, i64 4 }, { ptr, i64 } { ptr @fld.str.558, i64 4 }, { ptr, i64 } { ptr @fld.str.559, i64 4 }, { ptr, i64 } { ptr @fld.str.560, i64 6 }] +@str.562 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.563 = private unnamed_addr constant [7 x i8] c"Sha256\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 +@str.566 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.567 = private constant [2 x i8] c"h\00" +@fld.str.568 = private constant [4 x i8] c"buf\00" +@fld.str.569 = private constant [8 x i8] c"buf_len\00" +@fld.str.570 = private constant [10 x i8] c"total_len\00" +@field_names.571 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.567, i64 1 }, { ptr, i64 } { ptr @fld.str.568, i64 3 }, { ptr, i64 } { ptr @fld.str.569, i64 7 }, { ptr, i64 } { ptr @fld.str.570, i64 9 }] +@str.572 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.573 = private unnamed_addr constant [8 x i8] c"IntCell\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 +@str.576 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.577 = private constant [2 x i8] c"v\00" +@field_names.578 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.577, i64 1 }] +@str.579 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.580 = private unnamed_addr constant [2 x i8] c"R\00", align 1 +@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 [3 x i8] c", \00", align 1 +@field_names.584 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.585 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.586 = private unnamed_addr constant [9 x i8] c"Combined\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 +@str.589 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.590 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.591 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.592 = private unnamed_addr constant [8 x i8] c"VL__s64\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"ctx\00" +@fld.str.597 = private constant [9 x i8] c"__vtable\00" +@field_names.598 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.596, i64 3 }, { ptr, i64 } { ptr @fld.str.597, i64 8 }] +@str.599 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.600 = private unnamed_addr constant [18 x i8] c"__VL__s64__Vtable\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 [4 x i8] c"get\00" +@field_names.605 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.604, i64 3 }] +@str.606 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.607 = private unnamed_addr constant [3 x i8] c"VL\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 +@field_names.611 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.612 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.613 = private unnamed_addr constant [19 x i8] c"Combined__s64__s64\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 [8 x i8] c"sources\00" +@fld.str.618 = private constant [6 x i8] c"value\00" +@field_names.619 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.617, i64 7 }, { ptr, i64 } { ptr @fld.str.618, i64 5 }] +@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 +@fld.str.622 = private constant [5 x i8] c"read\00" +@fld.str.623 = private constant [6 x i8] c"write\00" +@fld.str.624 = private constant [7 x i8] c"append\00" +@fld.str.625 = private constant [11 x i8] c"read_write\00" +@field_names.626 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.622, i64 4 }, { ptr, i64 } { ptr @fld.str.623, i64 5 }, { ptr, i64 } { ptr @fld.str.624, i64 6 }, { ptr, i64 } { ptr @fld.str.625, i64 10 }] +@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 [4 x i8] c"set\00" +@fld.str.631 = private constant [8 x i8] c"current\00" +@fld.str.632 = private constant [4 x i8] c"end\00" +@field_names.633 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.630, i64 3 }, { ptr, i64 } { ptr @fld.str.631, i64 7 }, { ptr, i64 } { ptr @fld.str.632, i64 3 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.637 = private constant [6 x i8] c"null_\00" +@fld.str.638 = private constant [6 x i8] c"bool_\00" +@fld.str.639 = private constant [5 x i8] c"int_\00" +@fld.str.640 = private constant [4 x i8] c"str\00" +@fld.str.641 = private constant [6 x i8] c"array\00" +@fld.str.642 = private constant [7 x i8] c"object\00" +@field_names.643 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.637, i64 5 }, { ptr, i64 } { ptr @fld.str.638, i64 5 }, { ptr, i64 } { ptr @fld.str.639, i64 4 }, { ptr, i64 } { ptr @fld.str.640, i64 3 }, { ptr, i64 } { ptr @fld.str.641, i64 5 }, { ptr, i64 } { ptr @fld.str.642, i64 6 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.647 = private constant [6 x i8] c"macos\00" +@fld.str.648 = private constant [6 x i8] c"linux\00" +@fld.str.649 = private constant [8 x i8] c"windows\00" +@fld.str.650 = private constant [5 x i8] c"wasm\00" +@fld.str.651 = private constant [4 x i8] c"ios\00" +@fld.str.652 = private constant [8 x i8] c"android\00" +@fld.str.653 = private constant [8 x i8] c"unknown\00" +@field_names.654 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.647, i64 5 }, { ptr, i64 } { ptr @fld.str.648, i64 5 }, { ptr, i64 } { ptr @fld.str.649, i64 7 }, { ptr, i64 } { ptr @fld.str.650, i64 4 }, { ptr, i64 } { ptr @fld.str.651, i64 3 }, { ptr, i64 } { ptr @fld.str.652, i64 7 }, { 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 +@fld.str.658 = private constant [8 x i8] c"aarch64\00" +@fld.str.659 = private constant [7 x i8] c"x86_64\00" +@fld.str.660 = private constant [7 x i8] c"wasm32\00" +@fld.str.661 = private constant [7 x i8] c"wasm64\00" +@fld.str.662 = private constant [8 x i8] c"unknown\00" +@field_names.663 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.658, i64 7 }, { ptr, i64 } { ptr @fld.str.659, i64 6 }, { ptr, i64 } { ptr @fld.str.660, i64 6 }, { ptr, i64 } { ptr @fld.str.661, i64 6 }, { 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 +@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 [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 [5 x i8] c"null\00", align 1 +@str.703 = private unnamed_addr constant [6 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 [12 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 [5 x i8] c"*GPA\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 [12 x i8] c"*ArenaChunk\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"*Arena\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"[*]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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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"*File\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 [4 x i8] c"*u8\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"*s32\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"*SockAddr\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"*u32\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 [9 x i8] c"[*]Value\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 [7 x i8] c"*Array\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 [10 x i8] c"[*]Member\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"*Object\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"*Sink\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"*Parser\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 [5 x i8] c"*s64\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"*Parsed\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 [6 x i8] c"*Diag\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 [8 x i8] c"*Sha256\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"*IntCell\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 [13 x i8] c"**CAllocator\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 [7 x i8] c"**void\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 [20 x i8] c"*Combined__s64__s64\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 [10 x i8] c"**IntCell\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 [19 x i8] c"*__VL__s64__Vtable\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 [7 x i8] c"*tuple\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 [21 x i8] c"**Combined__s64__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 [9 x i8] c"*VL__s64\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"*string\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 [6 x i8] c"*bool\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 +@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 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -711,85 +711,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -932,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.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1059,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1393,7 +1315,7 @@ entry: br i1 %icmp, label %if.then.423, label %if.merge.424 if.then.423: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.424: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1543,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1570,12 +1492,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1607,26 +1529,26 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 105, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 100, label %match.arm.48 i64 103, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1668,7 +1590,7 @@ match.merge.37: ; preds = %dispatch.merge.544, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1713,12 +1635,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1776,7 +1698,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.306 [ - i64 35, label %dispatch.case.307 + i64 22, label %dispatch.case.307 i64 81, label %dispatch.case.308 i64 87, label %dispatch.case.309 i64 88, label %dispatch.case.310 @@ -1789,7 +1711,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.344 [ - i64 36, label %dispatch.case.345 + i64 23, label %dispatch.case.345 i64 60, label %dispatch.case.346 i64 77, label %dispatch.case.347 i64 85, label %dispatch.case.348 @@ -1803,13 +1725,13 @@ 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 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 - i64 33, label %dispatch.case.390 + i64 25, label %dispatch.case.384 + i64 27, label %dispatch.case.385 + i64 29, label %dispatch.case.386 + i64 31, label %dispatch.case.387 + i64 32, label %dispatch.case.388 + i64 34, label %dispatch.case.389 + i64 36, label %dispatch.case.390 i64 40, label %dispatch.case.391 i64 44, label %dispatch.case.392 i64 47, label %dispatch.case.393 @@ -1909,7 +1831,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.329, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.331, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1931,56 +1853,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2174,7 +2096,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.330, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.332, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.288 dispatch.case.290: ; preds = %match.arm.44 @@ -2215,7 +2137,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.331, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.333, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.305 dispatch.case.307: ; preds = %match.arm.47 @@ -2272,7 +2194,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.332, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.334, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.343 dispatch.case.345: ; preds = %match.arm.48 @@ -2329,7 +2251,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.333, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.335, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.381 dispatch.case.383: ; preds = %match.arm.49 @@ -2597,7 +2519,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.334, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.336, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.544 dispatch.case.546: ; preds = %match.arm.50 @@ -2639,7 +2561,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.335, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.337, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2735,7 +2657,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.336, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, 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 @@ -2743,7 +2665,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.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 i64, ptr %allocaN, align 8 @@ -2753,13 +2675,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.338, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, 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.339, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.341, 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 @@ -2767,7 +2689,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.340, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.342, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2781,7 +2703,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.341, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, 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 @@ -2789,7 +2711,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.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 i64, ptr %allocaN, align 8 @@ -2800,7 +2722,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.343, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.345, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2857,7 +2779,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.344, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.346, 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 @@ -2865,7 +2787,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.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 i64, ptr %allocaN, align 8 @@ -2876,7 +2798,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.346, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.348, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2896,7 +2818,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.347, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, 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 @@ -2904,7 +2826,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.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 }, ptr %alloca, align 8 @@ -2915,7 +2837,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.349, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.351, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2925,67 +2847,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3161,166 +3167,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3518,64 +3524,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3605,97 +3611,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3734,7 +3740,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i64 @IntCell.get(ptr %0, ptr %1) #0 { @@ -3844,7 +3850,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.350, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.352, 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 @@ -3859,7 +3865,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 i64, ptr %allocaN, align 8 %ba.val9 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %loadN, 1 @@ -3881,7 +3887,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.352, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.354, i64 3 }) ret { ptr, i64 } %call } @@ -3892,7 +3898,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.353, i64 15 }, { ptr, i64 } { ptr @str.354, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.355, i64 15 }, { 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 @@ -3911,12 +3917,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.355, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, 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.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 br label %if.merge.132 @@ -3928,7 +3934,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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3985,7 +3991,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.361, i64 9 }, { ptr, i64 } { ptr @str.362, i64 1 }) + %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 @@ -4004,24 +4010,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.363, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, 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.364, i64 2 }) + %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.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 [3 x { ptr, i64 }], ptr @field_names.368, i64 0, i64 %loadN + %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.369, i64 2 }) + %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, ptr, ptr }, ptr %alloca, align 8 @@ -4065,20 +4071,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.370, i64 10 }, { ptr, i64 } { ptr @str.371, i64 1 }) + %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.372, i64 7 }, { 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.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, 2 br i1 %icmp, label %while.body.139, label %while.exit.140 while.body.139: ; preds = %while.hdr.138 @@ -4088,24 +4095,102 @@ 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.372, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, 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 }) + %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.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.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.375, 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 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.138 + +fv.default: ; preds = %if.merge.142 + br label %fv.merge + +fv.case: ; preds = %if.merge.142 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.142 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.380, i64 10 }, { 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.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.382, 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.383, 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.384, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, 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 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -4116,7 +4201,7 @@ if.merge.142: ; preds = %if.then.141, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.138 + br label %while.hdr.143 } ; Function Attrs: nounwind @@ -4124,43 +4209,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.386, i64 3 }, { ptr, i64 } { ptr @str.387, 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 + br label %while.hdr.148 -while.hdr.143: ; preds = %fv.merge, %entry +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.144, label %while.exit.145 + br i1 %icmp, label %while.body.149, label %while.exit.150 -while.body.144: ; preds = %while.hdr.143 +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.146, label %if.merge.147 + br i1 %icmpN, label %if.then.151, label %if.merge.152 -while.exit.145: ; preds = %while.hdr.143 +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.378, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, i64 1 }) ret { ptr, i64 } %callN -if.then.146: ; preds = %while.body.144 +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.379, 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 - br label %if.merge.147 + br label %if.merge.152 -if.merge.147: ; preds = %if.then.146, %while.body.144 +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.381, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.382, 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 { i64 }, ptr %alloca, align 8 @@ -4177,12 +4262,12 @@ 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.143 + br label %while.hdr.148 -fv.default: ; preds = %if.merge.147 +fv.default: ; preds = %if.merge.152 br label %fv.merge -fv.case: ; preds = %if.merge.147 +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 @@ -4193,43 +4278,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.393, i64 10 }, { 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 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.148 + br label %while.hdr.153 -while.hdr.148: ; preds = %fv.merge, %entry +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.149, label %while.exit.150 + br i1 %icmp, label %while.body.154, label %while.exit.155 -while.body.149: ; preds = %while.hdr.148 +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.151, label %if.merge.152 + br i1 %icmpN, label %if.then.156, label %if.merge.157 -while.exit.150: ; preds = %while.hdr.148 +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.385, 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.151: ; preds = %while.body.149 +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.386, 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.152 + br label %if.merge.157 -if.merge.152: ; preds = %if.then.151, %while.body.149 +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.389, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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.390, 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 }, ptr %alloca, align 8 @@ -4247,18 +4332,18 @@ 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.148 + br label %while.hdr.153 -fv.default: ; preds = %if.merge.152 +fv.default: ; preds = %if.merge.157 br label %fv.merge -fv.case: ; preds = %if.merge.152 +fv.case: ; preds = %if.merge.157 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.152 +fv.case17: ; preds = %if.merge.157 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -4270,91 +4355,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.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 - 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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.153 - -fv.default: ; preds = %if.merge.157 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.157 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.400, i64 8 }, { ptr, i64 } { ptr @str.401, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.401, i64 5 }, { 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 @@ -4373,27 +4374,27 @@ 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.402, 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.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.403, 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.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.407, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.408, 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, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4415,29 +4416,30 @@ fv.default: ; preds = %if.merge.162 br label %fv.merge fv.case: ; preds = %if.merge.162 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.162 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.162 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.409, i64 17 }, { ptr, i64 } { ptr @str.410, i64 1 }) + %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.410, i64 8 }, { 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 @@ -4446,7 +4448,7 @@ entry: while.hdr.163: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.164, label %while.exit.165 while.body.164: ; preds = %while.hdr.163 @@ -4456,19 +4458,19 @@ 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.411, 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.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.412, 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.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.417, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4476,17 +4478,16 @@ if.merge.167: ; preds = %if.then.166, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4499,35 +4500,29 @@ fv.default: ; preds = %if.merge.167 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.167 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.167 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.167 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.419, i64 7 }, { ptr, i64 } { ptr @str.420, i64 1 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.419, i64 17 }, { 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 @@ -4536,7 +4531,7 @@ entry: while.hdr.168: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.169, label %while.exit.170 while.body.169: ; preds = %while.hdr.168 @@ -4558,23 +4553,25 @@ if.then.171: ; preds = %while.body.169 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.425, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4587,16 +4584,25 @@ fv.default: ; preds = %if.merge.172 br label %fv.merge fv.case: ; preds = %if.merge.172 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.172 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.172 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.172 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4605,7 +4611,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.427, i64 4 }, { ptr, i64 } { ptr @str.428, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.429, i64 4 }, { 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 @@ -4624,24 +4630,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.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.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.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.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.432, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 %alloca, align 4 @@ -4678,7 +4684,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.434, i64 10 }, { ptr, i64 } { ptr @str.435, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.436, i64 10 }, { 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 @@ -4697,24 +4703,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.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.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.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.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.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 { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4780,7 +4786,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.445, i64 13 }, { ptr, i64 } { ptr @str.446, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.447, i64 13 }, { 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 @@ -4799,24 +4805,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.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.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.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.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.451, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.453, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4858,7 +4864,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.453, i64 8 }, { ptr, i64 } { ptr @str.454, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.455, i64 8 }, { ptr, i64 } { ptr @str.456, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4877,24 +4883,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.455, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.457, 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.456, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.458, 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.462, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4955,7 +4961,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.464, i64 5 }, { ptr, i64 } { ptr @str.465, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.466, i64 5 }, { 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 @@ -4974,24 +4980,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.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.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.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.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.471, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 }, ptr %alloca, align 8 @@ -5037,7 +5043,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.473, i64 6 }, { ptr, i64 } { ptr @str.474, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.475, i64 6 }, { 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 @@ -5056,24 +5062,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.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.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.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.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.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 %alloca, align 8 @@ -5121,7 +5127,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.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 @@ -5140,24 +5146,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.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.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.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.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.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 { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5201,7 +5207,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.490, i64 4 }, { ptr, i64 } { ptr @str.491, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.492, i64 4 }, { 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 @@ -5220,24 +5226,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.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.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.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.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.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 }, i64, ptr }, ptr %alloca, align 8 @@ -5287,7 +5293,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.499, i64 6 }, { ptr, i64 } { ptr @str.500, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.501, i64 6 }, { 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 @@ -5306,24 +5312,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.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.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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 @@ -5372,7 +5378,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.508, i64 12 }, { ptr, i64 } { ptr @str.509, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.510, i64 12 }, { 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 @@ -5391,24 +5397,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.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.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.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.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.512, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 %alloca, align 1 @@ -5428,7 +5434,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.514, i64 8 }, { ptr, i64 } { ptr @str.515, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.516, i64 8 }, { 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 @@ -5447,24 +5453,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.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.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.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.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.521, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5516,7 +5522,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.523, i64 7 }, { ptr, i64 } { ptr @str.524, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.525, i64 7 }, { 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 @@ -5535,24 +5541,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.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.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.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.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.530, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5604,7 +5610,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.532, i64 9 }, { ptr, i64 } { ptr @str.533, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.534, i64 9 }, { 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 @@ -5623,24 +5629,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.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.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.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.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.538, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.540, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5683,7 +5689,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.540, i64 4 }, { ptr, i64 } { ptr @str.541, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.542, i64 4 }, { ptr, i64 } { ptr @str.543, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5702,24 +5708,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.542, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, 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.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 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.546, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5765,7 +5771,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.548, i64 6 }, { ptr, i64 } { ptr @str.549, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.550, i64 6 }, { ptr, i64 } { ptr @str.551, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5784,24 +5790,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.550, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.552, 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.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 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.559, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 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 { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5858,7 +5864,7 @@ fv.case28: ; preds = %if.merge.247 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.247 @@ -5883,7 +5889,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.561, i64 6 }, { ptr, i64 } { ptr @str.562, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.563, i64 6 }, { ptr, i64 } { ptr @str.564, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5902,24 +5908,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.563, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.565, 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.564, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.566, 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.569, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.571, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5974,7 +5980,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.571, i64 7 }, { ptr, i64 } { ptr @str.572, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.573, i64 7 }, { ptr, i64 } { ptr @str.574, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5993,24 +5999,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.573, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.575, 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.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 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.576, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.578, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.579, 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 @@ -6043,7 +6049,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.578, i64 1 }, { ptr, i64 } { ptr @str.579, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.580, i64 1 }, { ptr, i64 } { ptr @str.581, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6062,24 +6068,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.580, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.582, 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.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 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.582, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.584, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6098,7 +6104,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.584, i64 8 }, { ptr, i64 } { ptr @str.585, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, i64 8 }, { ptr, i64 } { ptr @str.587, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6117,24 +6123,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.586, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.588, 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.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 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.588, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 %alloca, align 1 @@ -6153,7 +6159,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.590, i64 7 }, { ptr, i64 } { ptr @str.591, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.592, i64 7 }, { 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 @@ -6172,24 +6178,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.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.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.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.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.596, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, ptr }, ptr %alloca, align 8 @@ -6230,7 +6236,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.598, i64 17 }, { ptr, i64 } { ptr @str.599, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.600, i64 17 }, { 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 @@ -6249,24 +6255,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.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.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.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.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.603, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 %alloca, align 8 @@ -6300,7 +6306,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.605, i64 2 }, { ptr, i64 } { ptr @str.606, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.607, i64 2 }, { 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 @@ -6319,24 +6325,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.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.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.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.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.609, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.611, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6356,7 +6362,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.611, i64 18 }, { ptr, i64 } { ptr @str.612, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.613, i64 18 }, { ptr, i64 } { ptr @str.614, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6375,24 +6381,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.613, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.615, 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.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.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.617, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.619, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { { ptr, ptr } }, i64 }, ptr %alloca, align 8 @@ -6437,9 +6443,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.624, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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.619, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.621, 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 @@ -6458,8 +6464,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.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.296 @@ -6478,9 +6484,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.631, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.633, 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, ptr %alloca, align 8 @@ -6499,8 +6505,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.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 } { ptr @str.635, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, 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 @@ -6530,9 +6536,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.641, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.643, 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.634, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, 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 @@ -6549,8 +6555,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.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 } { ptr @str.645, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.644, 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 @@ -6628,9 +6634,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.652, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 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.644, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, 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 @@ -6649,8 +6655,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.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.302 @@ -6669,9 +6675,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.661, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.663, 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 @@ -6690,8 +6696,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.304 @@ -6708,7 +6714,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.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.313 @@ -6725,12 +6731,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.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.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.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.317 @@ -6759,7 +6765,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.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.318 @@ -6776,12 +6782,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.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.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.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.322 @@ -6811,7 +6817,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.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.323 @@ -6828,12 +6834,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.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.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.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.327 @@ -6861,7 +6867,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.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.328 @@ -6878,12 +6884,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.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.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.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.332 @@ -6912,7 +6918,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.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.333 @@ -6929,12 +6935,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.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.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.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.337 @@ -6963,7 +6969,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.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.338 @@ -6980,12 +6986,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.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.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.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.342 @@ -7015,7 +7021,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.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.351 @@ -7034,12 +7040,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.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.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.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.355 @@ -7068,7 +7074,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.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.356 @@ -7087,12 +7093,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.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.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.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.360 @@ -7121,7 +7127,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.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.361 @@ -7140,12 +7146,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.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.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.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.365 @@ -7175,7 +7181,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.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.366 @@ -7194,12 +7200,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.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.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.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.370 @@ -7229,7 +7235,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.694, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.696, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.371 @@ -7248,12 +7254,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.695, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, 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.696, i64 2 }) + %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.375 @@ -7283,7 +7289,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.697, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.699, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.376 @@ -7302,12 +7308,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.698, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.700, 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.699, 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 br label %if.merge.380 @@ -7349,12 +7355,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.702, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 5 }, { 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 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.700, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -7377,12 +7383,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.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.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7405,12 +7411,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.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.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7433,12 +7439,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.711, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 11 }, { 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 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.709, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7461,12 +7467,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.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.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7488,12 +7494,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.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.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7516,12 +7522,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.720, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.719, i64 9 }, { 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 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.718, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7544,12 +7550,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.723, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 18 }, { 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 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.721, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7572,12 +7578,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.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.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7600,12 +7606,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.729, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 3 }, { 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 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.727, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7628,12 +7634,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.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.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.732, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7656,12 +7662,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.735, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 9 }, { 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 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.733, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.735, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7684,12 +7690,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.738, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 4 }, { 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 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.736, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.738, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7711,12 +7717,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.741, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 8 }, { 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 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.739, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.741, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7739,12 +7745,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.744, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.743, i64 6 }, { 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 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.742, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.744, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7766,12 +7772,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.747, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.746, i64 9 }, { 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 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.745, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] + %bp = phi { ptr, i64 } [ { ptr @str.747, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] ret { ptr, i64 } %bp } @@ -7794,12 +7800,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.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.483 if.merge.483: ; preds = %if.else.482, %if.then.481 - %bp = phi { ptr, i64 } [ { ptr @str.748, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] + %bp = phi { ptr, i64 } [ { ptr @str.750, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] ret { ptr, i64 } %bp } @@ -7822,12 +7828,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.753, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 5 }, { 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 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.751, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] + %bp = phi { ptr, i64 } [ { ptr @str.753, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] ret { ptr, i64 } %bp } @@ -7850,12 +7856,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.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.489 if.merge.489: ; preds = %if.else.488, %if.then.487 - %bp = phi { ptr, i64 } [ { ptr @str.754, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] + %bp = phi { ptr, i64 } [ { ptr @str.756, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] ret { ptr, i64 } %bp } @@ -7878,12 +7884,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.759, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.758, i64 4 }, { 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 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.757, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] + %bp = phi { ptr, i64 } [ { ptr @str.759, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] ret { ptr, i64 } %bp } @@ -7906,12 +7912,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.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.495 if.merge.495: ; preds = %if.else.494, %if.then.493 - %bp = phi { ptr, i64 } [ { ptr @str.760, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] + %bp = phi { ptr, i64 } [ { ptr @str.762, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] ret { ptr, i64 } %bp } @@ -7934,12 +7940,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.765, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 5 }, { 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 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.763, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] + %bp = phi { ptr, i64 } [ { ptr @str.765, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] ret { ptr, i64 } %bp } @@ -7962,12 +7968,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.768, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 7 }, { 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 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.766, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] + %bp = phi { ptr, i64 } [ { ptr @str.768, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] ret { ptr, i64 } %bp } @@ -7990,12 +7996,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.771, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.770, i64 8 }, { 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 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.769, i64 4 }, %if.then.502 ], [ %callN, %if.else.503 ] + %bp = phi { ptr, i64 } [ { ptr @str.771, i64 4 }, %if.then.502 ], [ %callN, %if.else.503 ] ret { ptr, i64 } %bp } @@ -8018,12 +8024,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.774, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.773, i64 12 }, { 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 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.772, i64 4 }, %if.then.505 ], [ %callN, %if.else.506 ] + %bp = phi { ptr, i64 } [ { ptr @str.774, i64 4 }, %if.then.505 ], [ %callN, %if.else.506 ] ret { ptr, i64 } %bp } @@ -8046,12 +8052,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.777, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 6 }, { 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 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.775, i64 4 }, %if.then.508 ], [ %callN, %if.else.509 ] + %bp = phi { ptr, i64 } [ { ptr @str.777, i64 4 }, %if.then.508 ], [ %callN, %if.else.509 ] ret { ptr, i64 } %bp } @@ -8074,12 +8080,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.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.513 if.merge.513: ; preds = %if.else.512, %if.then.511 - %bp = phi { ptr, i64 } [ { ptr @str.778, i64 4 }, %if.then.511 ], [ %callN, %if.else.512 ] + %bp = phi { ptr, i64 } [ { ptr @str.780, i64 4 }, %if.then.511 ], [ %callN, %if.else.512 ] ret { ptr, i64 } %bp } @@ -8102,12 +8108,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.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.516 if.merge.516: ; preds = %if.else.515, %if.then.514 - %bp = phi { ptr, i64 } [ { ptr @str.781, i64 4 }, %if.then.514 ], [ %callN, %if.else.515 ] + %bp = phi { ptr, i64 } [ { ptr @str.783, i64 4 }, %if.then.514 ], [ %callN, %if.else.515 ] ret { ptr, i64 } %bp } @@ -8130,12 +8136,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.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.519 if.merge.519: ; preds = %if.else.518, %if.then.517 - %bp = phi { ptr, i64 } [ { ptr @str.784, i64 4 }, %if.then.517 ], [ %callN, %if.else.518 ] + %bp = phi { ptr, i64 } [ { ptr @str.786, i64 4 }, %if.then.517 ], [ %callN, %if.else.518 ] ret { ptr, i64 } %bp } @@ -8158,12 +8164,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.789, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.788, i64 19 }, { 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 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.787, i64 4 }, %if.then.520 ], [ %callN, %if.else.521 ] + %bp = phi { ptr, i64 } [ { ptr @str.789, i64 4 }, %if.then.520 ], [ %callN, %if.else.521 ] ret { ptr, i64 } %bp } @@ -8186,12 +8192,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.792, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.791, i64 9 }, { 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 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.790, i64 4 }, %if.then.523 ], [ %callN, %if.else.524 ] + %bp = phi { ptr, i64 } [ { ptr @str.792, i64 4 }, %if.then.523 ], [ %callN, %if.else.524 ] ret { ptr, i64 } %bp } @@ -8214,12 +8220,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.795, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.794, i64 18 }, { ptr, i64 } %callN) + %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 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.793, i64 4 }, %if.then.526 ], [ %callN, %if.else.527 ] + %bp = phi { ptr, i64 } [ { ptr @str.795, i64 4 }, %if.then.526 ], [ %callN, %if.else.527 ] ret { ptr, i64 } %bp } @@ -8242,12 +8248,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.798, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.797, i64 6 }, { ptr, i64 } %callN) + %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 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.796, i64 4 }, %if.then.529 ], [ %callN, %if.else.530 ] + %bp = phi { ptr, i64 } [ { ptr @str.798, i64 4 }, %if.then.529 ], [ %callN, %if.else.530 ] ret { ptr, i64 } %bp } @@ -8270,12 +8276,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.801, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.800, i64 20 }, { ptr, i64 } %callN) + %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 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.799, i64 4 }, %if.then.532 ], [ %callN, %if.else.533 ] + %bp = phi { ptr, i64 } [ { ptr @str.801, i64 4 }, %if.then.532 ], [ %callN, %if.else.533 ] ret { ptr, i64 } %bp } @@ -8298,12 +8304,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.804, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.803, i64 8 }, { ptr, i64 } %callN) + %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 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.802, i64 4 }, %if.then.535 ], [ %callN, %if.else.536 ] + %bp = phi { ptr, i64 } [ { ptr @str.804, i64 4 }, %if.then.535 ], [ %callN, %if.else.536 ] ret { ptr, i64 } %bp } @@ -8326,12 +8332,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.807, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.806, i64 7 }, { ptr, i64 } %callN) + %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) br label %if.merge.540 if.merge.540: ; preds = %if.else.539, %if.then.538 - %bp = phi { ptr, i64 } [ { ptr @str.805, i64 4 }, %if.then.538 ], [ %callN, %if.else.539 ] + %bp = phi { ptr, i64 } [ { ptr @str.807, i64 4 }, %if.then.538 ], [ %callN, %if.else.539 ] ret { ptr, i64 } %bp } @@ -8354,12 +8360,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.810, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.809, i64 5 }, { ptr, i64 } %callN) + %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 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.808, i64 4 }, %if.then.541 ], [ %callN, %if.else.542 ] + %bp = phi { ptr, i64 } [ { ptr @str.810, i64 4 }, %if.then.541 ], [ %callN, %if.else.542 ] ret { ptr, i64 } %bp } @@ -8375,7 +8381,7 @@ entry: br i1 %lnot, label %if.then.550, label %if.merge.551 if.then.550: ; preds = %entry - ret { ptr, i64 } { ptr @str.811, i64 4 } + ret { ptr, i64 } { ptr @str.813, i64 4 } if.merge.551: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8399,7 +8405,7 @@ entry: br i1 %lnot, label %if.then.552, label %if.merge.553 if.then.552: ; preds = %entry - ret { ptr, i64 } { ptr @str.812, i64 4 } + ret { ptr, i64 } { ptr @str.814, i64 4 } if.merge.553: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8423,7 +8429,7 @@ entry: br i1 %lnot, label %if.then.554, label %if.merge.555 if.then.554: ; preds = %entry - ret { ptr, i64 } { ptr @str.813, i64 4 } + ret { ptr, i64 } { ptr @str.815, i64 4 } if.merge.555: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8447,7 +8453,7 @@ entry: br i1 %lnot, label %if.then.556, label %if.merge.557 if.then.556: ; preds = %entry - ret { ptr, i64 } { ptr @str.814, i64 4 } + ret { ptr, i64 } { ptr @str.816, 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 7d649be..c8f86ee 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.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 +@str.475 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.476 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.477 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.478 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.479 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.480 = 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.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 }] +@tag.str.481 = private constant [9 x i8] c"Overflow\00" +@tag.str.482 = private constant [3 x i8] c"Io\00" +@tag.str.483 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.484 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.485 = private constant [10 x i8] c"BadEscape\00" +@tag.str.486 = private constant [10 x i8] c"BadNumber\00" +@tag.str.487 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.488 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.489 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.490 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.491 = private constant [13 x i8] c"MissingValue\00" +@tag.str.492 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.493 = 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.481, i64 8 }, { ptr, i64 } { ptr @tag.str.482, i64 2 }, { ptr, i64 } { ptr @tag.str.483, i64 15 }, { ptr, i64 } { ptr @tag.str.484, i64 13 }, { ptr, i64 } { ptr @tag.str.485, i64 9 }, { ptr, i64 } { ptr @tag.str.486, i64 9 }, { ptr, i64 } { ptr @tag.str.487, i64 15 }, { ptr, i64 } { ptr @tag.str.488, i64 14 }, { ptr, i64 } { ptr @tag.str.489, i64 14 }, { ptr, i64 } { ptr @tag.str.490, i64 11 }, { ptr, i64 } { ptr @tag.str.491, i64 12 }, { ptr, i64 } { ptr @tag.str.492, i64 15 }, { ptr, i64 } { ptr @tag.str.493, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@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 [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 +@tn.str.494 = private constant [5 x i8] c"bool\00" +@tn.str.495 = private constant [3 x i8] c"s8\00" +@tn.str.496 = private constant [4 x i8] c"s16\00" +@tn.str.497 = private constant [4 x i8] c"s32\00" +@tn.str.498 = private constant [4 x i8] c"s64\00" +@tn.str.499 = private constant [3 x i8] c"u8\00" +@tn.str.500 = private constant [4 x i8] c"u16\00" +@tn.str.501 = private constant [4 x i8] c"u32\00" +@tn.str.502 = private constant [4 x i8] c"u64\00" +@tn.str.503 = private constant [4 x i8] c"f32\00" +@tn.str.504 = private constant [4 x i8] c"f64\00" +@tn.str.505 = private constant [7 x i8] c"string\00" +@tn.str.506 = private constant [4 x i8] c"Any\00" +@tn.str.507 = private constant [9 x i8] c"noreturn\00" +@tn.str.508 = private constant [6 x i8] c"isize\00" +@tn.str.509 = private constant [6 x i8] c"usize\00" +@tn.str.510 = private constant [5 x i8] c"void\00" +@tn.str.511 = private constant [6 x i8] c"*void\00" +@tn.str.512 = private constant [16 x i8] c"Source_Location\00" +@tn.str.513 = private constant [10 x i8] c"Allocator\00" +@tn.str.514 = private constant [8 x i8] c"Context\00" +@tn.str.515 = private constant [7 x i8] c"[4]s64\00" +@tn.str.516 = private constant [9 x i8] c"[]string\00" +@tn.str.517 = private constant [11 x i8] c"CAllocator\00" +@tn.str.518 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.519 = private constant [4 x i8] c"GPA\00" +@tn.str.520 = private constant [5 x i8] c"*GPA\00" +@tn.str.521 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.522 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.523 = private constant [6 x i8] c"Arena\00" +@tn.str.524 = private constant [7 x i8] c"*Arena\00" +@tn.str.525 = private constant [6 x i8] c"[*]u8\00" +@tn.str.526 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.527 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.528 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.529 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.530 = private constant [9 x i8] c"OpenMode\00" +@tn.str.531 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.532 = private constant [5 x i8] c"File\00" +@tn.str.533 = private constant [6 x i8] c"*File\00" +@tn.str.534 = private constant [6 x i8] c"?File\00" +@tn.str.535 = private constant [8 x i8] c"?string\00" +@tn.str.536 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.537 = private constant [4 x i8] c"*u8\00" +@tn.str.538 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.539 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.540 = private constant [5 x i8] c"*s32\00" +@tn.str.541 = private constant [9 x i8] c"SockAddr\00" +@tn.str.542 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.543 = private constant [5 x i8] c"*u32\00" +@tn.str.544 = private constant [10 x i8] c"JsonError\00" +@tn.str.545 = private constant [6 x i8] c"Array\00" +@tn.str.546 = private constant [7 x i8] c"Object\00" +@tn.str.547 = private constant [6 x i8] c"Value\00" +@tn.str.548 = private constant [7 x i8] c"Member\00" +@tn.str.549 = private constant [9 x i8] c"[*]Value\00" +@tn.str.550 = private constant [7 x i8] c"*Array\00" +@tn.str.551 = private constant [10 x i8] c"[*]Member\00" +@tn.str.552 = private constant [8 x i8] c"*Object\00" +@tn.str.553 = private constant [5 x i8] c"[]u8\00" +@tn.str.554 = private constant [5 x i8] c"Sink\00" +@tn.str.555 = private constant [6 x i8] c"*Sink\00" +@tn.str.556 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.557 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.558 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.559 = private constant [7 x i8] c"Parser\00" +@tn.str.560 = private constant [8 x i8] c"*Parser\00" +@tn.str.561 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.562 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.563 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.564 = private constant [13 x i8] c"Architecture\00" +@tn.str.565 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.566 = private constant [11 x i8] c"() -> bool\00" +@tn.str.567 = private constant [5 x i8] c"*s64\00" +@tn.str.568 = private constant [9 x i8] c"CliError\00" +@tn.str.569 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.570 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.571 = private constant [8 x i8] c"Command\00" +@tn.str.572 = private constant [10 x i8] c"FlagValue\00" +@tn.str.573 = private constant [5 x i8] c"Diag\00" +@tn.str.574 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.575 = private constant [7 x i8] c"Parsed\00" +@tn.str.576 = private constant [8 x i8] c"*Parsed\00" +@tn.str.577 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.578 = private constant [10 x i8] c"[]Command\00" +@tn.str.579 = private constant [6 x i8] c"*Diag\00" +@tn.str.580 = private constant [7 x i8] c"[8]s64\00" +@tn.str.581 = private constant [7 x i8] c"[64]u8\00" +@tn.str.582 = private constant [7 x i8] c"Sha256\00" +@tn.str.583 = private constant [8 x i8] c"*Sha256\00" +@tn.str.584 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.585 = private constant [8 x i8] c"[64]s64\00" +@tn.str.586 = private constant [8 x i8] c"[16]f32\00" +@tn.str.587 = private constant [5 x i8] c"Mat4\00" +@tn.str.588 = private constant [5 x i8] c"Vec2\00" +@tn.str.589 = private constant [6 x i8] c"Point\00" +@tn.str.590 = private constant [8 x i8] c"Counter\00" +@tn.str.591 = private constant [18 x i8] c"__Counter__Vtable\00" +@tn.str.592 = private constant [9 x i8] c"Summable\00" +@tn.str.593 = private constant [19 x i8] c"__Summable__Vtable\00" +@tn.str.594 = private constant [14 x i8] c"SimpleCounter\00" +@tn.str.595 = private constant [15 x i8] c"*SimpleCounter\00" +@tn.str.596 = private constant [7 x i8] c"*Point\00" +@tn.str.597 = private constant [6 x i8] c"Adder\00" +@tn.str.598 = private constant [12 x i8] c"Accumulator\00" +@tn.str.599 = private constant [13 x i8] c"*Accumulator\00" +@tn.str.600 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.601 = private constant [7 x i8] c"**void\00" +@tn.str.602 = private constant [8 x i8] c"*string\00" +@tn.str.603 = private constant [6 x i8] c"[]Any\00" +@tn.str.604 = private constant [5 x i8] c"*Any\00" +@tn.str.605 = private constant [7 x i8] c"*[]Any\00" +@tn.str.606 = private constant [6 x i8] c"*bool\00" +@tn.str.607 = private constant [9 x i8] c"*Counter\00" +@tn.str.608 = private constant [16 x i8] c"**SimpleCounter\00" +@tn.str.609 = private constant [19 x i8] c"*__Counter__Vtable\00" +@tn.str.610 = private constant [7 x i8] c"[1]Any\00" +@tn.str.611 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.612 = private constant [7 x i8] c"*Adder\00" +@tn.str.613 = private constant [14 x i8] c"**Accumulator\00" +@tn.str.614 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.615 = private constant [5 x i8] c"*f64\00" +@tn.str.616 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.617 = private constant [11 x i8] c"*Allocator\00" +@tn.str.618 = private constant [9 x i8] c"*Context\00" +@tn.str.619 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.620 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.621 = private constant [8 x i8] c"*Member\00" +@tn.str.622 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.623 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.624 = private constant [9 x i8] c"*Command\00" +@tn.str.625 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.626 = private constant [6 x i8] c"*Mat4\00" +@tn.str.627 = private constant [6 x i8] c"*Vec2\00" +@tn.str.628 = private constant [10 x i8] c"*Summable\00" +@tn.str.629 = private constant [20 x i8] c"*__Summable__Vtable\00" +@tn.str.630 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.631 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.632 = private constant [7 x i8] c"*Value\00" +@tn.str.633 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.634 = private constant [14 x i8] c"*Architecture\00" +@tn.str.635 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.636 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.637 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.638 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.639 = private constant [9 x i8] c"*[16]f32\00" +@tn.str.640 = private constant [10 x i8] c"*[]string\00" +@tn.str.641 = private constant [6 x i8] c"*[]u8\00" +@tn.str.642 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.643 = private constant [11 x i8] c"*[]Command\00" +@tn.str.644 = private constant [6 x i8] c"**GPA\00" +@tn.str.645 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.646 = private constant [8 x i8] c"**Arena\00" +@tn.str.647 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.648 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.649 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.650 = private constant [7 x i8] c"**File\00" +@tn.str.651 = private constant [5 x i8] c"**u8\00" +@tn.str.652 = private constant [6 x i8] c"**s32\00" +@tn.str.653 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.654 = private constant [6 x i8] c"**u32\00" +@tn.str.655 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.656 = private constant [8 x i8] c"**Array\00" +@tn.str.657 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.658 = private constant [9 x i8] c"**Object\00" +@tn.str.659 = private constant [7 x i8] c"**Sink\00" +@tn.str.660 = private constant [9 x i8] c"**Parser\00" +@tn.str.661 = private constant [6 x i8] c"**s64\00" +@tn.str.662 = private constant [9 x i8] c"**Parsed\00" +@tn.str.663 = private constant [7 x i8] c"**Diag\00" +@tn.str.664 = private constant [9 x i8] c"**Sha256\00" +@tn.str.665 = private constant [8 x i8] c"**Point\00" +@tn.str.666 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.667 = private constant [8 x i8] c"***void\00" +@tn.str.668 = private constant [9 x i8] c"**string\00" +@tn.str.669 = private constant [6 x i8] c"**Any\00" +@tn.str.670 = private constant [8 x i8] c"**[]Any\00" +@tn.str.671 = private constant [7 x i8] c"**bool\00" +@tn.str.672 = private constant [10 x i8] c"**Counter\00" +@tn.str.673 = private constant [17 x i8] c"***SimpleCounter\00" +@tn.str.674 = private constant [20 x i8] c"**__Counter__Vtable\00" +@tn.str.675 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.676 = private constant [8 x i8] c"**Adder\00" +@tn.str.677 = private constant [15 x i8] c"***Accumulator\00" +@tn.str.678 = private constant [7 x i8] c"*?File\00" +@tn.str.679 = private constant [9 x i8] c"*?string\00" +@tn.str.680 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.681 = 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.494, i64 4 }, { 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 2 }, { ptr, i64 } { ptr @tn.str.500, i64 3 }, { ptr, i64 } { ptr @tn.str.501, i64 3 }, { ptr, i64 } { ptr @tn.str.502, i64 3 }, { ptr, i64 } { ptr @tn.str.503, i64 3 }, { ptr, i64 } { ptr @tn.str.504, i64 3 }, { ptr, i64 } { ptr @tn.str.505, i64 6 }, { ptr, i64 } { ptr @tn.str.506, i64 3 }, { ptr, i64 } { ptr @tn.str.507, i64 8 }, { ptr, i64 } { ptr @tn.str.508, i64 5 }, { ptr, i64 } { ptr @tn.str.509, i64 5 }, { ptr, i64 } { ptr @tn.str.510, i64 4 }, { ptr, i64 } { ptr @tn.str.511, i64 5 }, { ptr, i64 } { ptr @tn.str.512, i64 15 }, { ptr, i64 } { ptr @tn.str.513, i64 9 }, { ptr, i64 } { ptr @tn.str.514, i64 7 }, { ptr, i64 } { ptr @tn.str.515, i64 6 }, { ptr, i64 } { ptr @tn.str.516, i64 8 }, { ptr, i64 } { ptr @tn.str.517, i64 10 }, { ptr, i64 } { ptr @tn.str.518, i64 11 }, { ptr, i64 } { ptr @tn.str.519, i64 3 }, { ptr, i64 } { ptr @tn.str.520, i64 4 }, { ptr, i64 } { ptr @tn.str.521, i64 10 }, { ptr, i64 } { ptr @tn.str.522, i64 11 }, { ptr, i64 } { ptr @tn.str.523, i64 5 }, { ptr, i64 } { ptr @tn.str.524, i64 6 }, { ptr, i64 } { ptr @tn.str.525, i64 5 }, { ptr, i64 } { ptr @tn.str.526, i64 8 }, { ptr, i64 } { ptr @tn.str.527, i64 9 }, { ptr, i64 } { ptr @tn.str.528, i64 17 }, { ptr, i64 } { ptr @tn.str.529, i64 18 }, { ptr, i64 } { ptr @tn.str.530, i64 8 }, { ptr, i64 } { ptr @tn.str.531, i64 8 }, { ptr, i64 } { ptr @tn.str.532, i64 4 }, { ptr, i64 } { ptr @tn.str.533, i64 5 }, { ptr, i64 } { ptr @tn.str.534, i64 5 }, { ptr, i64 } { ptr @tn.str.535, i64 7 }, { ptr, i64 } { ptr @tn.str.536, i64 10 }, { ptr, i64 } { ptr @tn.str.537, i64 3 }, { ptr, i64 } { ptr @tn.str.538, i64 13 }, { ptr, i64 } { ptr @tn.str.539, i64 14 }, { ptr, i64 } { ptr @tn.str.540, i64 4 }, { ptr, i64 } { ptr @tn.str.541, i64 8 }, { ptr, i64 } { ptr @tn.str.542, i64 9 }, { ptr, i64 } { ptr @tn.str.543, i64 4 }, { ptr, i64 } { ptr @tn.str.544, i64 9 }, { ptr, i64 } { ptr @tn.str.545, i64 5 }, { ptr, i64 } { ptr @tn.str.546, i64 6 }, { ptr, i64 } { ptr @tn.str.547, i64 5 }, { ptr, i64 } { ptr @tn.str.548, i64 6 }, { ptr, i64 } { ptr @tn.str.549, i64 8 }, { ptr, i64 } { ptr @tn.str.550, i64 6 }, { ptr, i64 } { ptr @tn.str.551, i64 9 }, { ptr, i64 } { ptr @tn.str.552, i64 7 }, { ptr, i64 } { ptr @tn.str.553, i64 4 }, { ptr, i64 } { ptr @tn.str.554, i64 4 }, { ptr, i64 } { ptr @tn.str.555, i64 5 }, { ptr, i64 } { ptr @tn.str.556, i64 16 }, { ptr, i64 } { ptr @tn.str.557, i64 14 }, { ptr, i64 } { ptr @tn.str.558, i64 21 }, { ptr, i64 } { ptr @tn.str.559, i64 6 }, { ptr, i64 } { ptr @tn.str.560, i64 7 }, { ptr, i64 } { ptr @tn.str.561, i64 24 }, { ptr, i64 } { ptr @tn.str.562, i64 23 }, { ptr, i64 } { ptr @tn.str.563, i64 15 }, { ptr, i64 } { ptr @tn.str.564, i64 12 }, { ptr, i64 } { ptr @tn.str.565, i64 12 }, { ptr, i64 } { ptr @tn.str.566, i64 10 }, { ptr, i64 } { ptr @tn.str.567, i64 4 }, { ptr, i64 } { ptr @tn.str.568, i64 8 }, { ptr, i64 } { ptr @tn.str.569, i64 8 }, { ptr, i64 } { ptr @tn.str.570, i64 10 }, { ptr, i64 } { ptr @tn.str.571, i64 7 }, { ptr, i64 } { ptr @tn.str.572, i64 9 }, { ptr, i64 } { ptr @tn.str.573, i64 4 }, { ptr, i64 } { ptr @tn.str.574, i64 13 }, { ptr, i64 } { ptr @tn.str.575, i64 6 }, { ptr, i64 } { ptr @tn.str.576, i64 7 }, { ptr, i64 } { ptr @tn.str.577, i64 18 }, { ptr, i64 } { ptr @tn.str.578, i64 9 }, { ptr, i64 } { ptr @tn.str.579, i64 5 }, { ptr, i64 } { ptr @tn.str.580, i64 6 }, { ptr, i64 } { ptr @tn.str.581, i64 6 }, { ptr, i64 } { ptr @tn.str.582, i64 6 }, { ptr, i64 } { ptr @tn.str.583, i64 7 }, { ptr, i64 } { ptr @tn.str.584, i64 7 }, { ptr, i64 } { ptr @tn.str.585, i64 7 }, { ptr, i64 } { ptr @tn.str.586, i64 7 }, { ptr, i64 } { ptr @tn.str.587, i64 4 }, { ptr, i64 } { ptr @tn.str.588, i64 4 }, { ptr, i64 } { ptr @tn.str.589, i64 5 }, { ptr, i64 } { ptr @tn.str.590, i64 7 }, { ptr, i64 } { ptr @tn.str.591, i64 17 }, { ptr, i64 } { ptr @tn.str.592, i64 8 }, { ptr, i64 } { ptr @tn.str.593, i64 18 }, { ptr, i64 } { ptr @tn.str.594, i64 13 }, { ptr, i64 } { ptr @tn.str.595, i64 14 }, { ptr, i64 } { ptr @tn.str.596, i64 6 }, { ptr, i64 } { ptr @tn.str.597, i64 5 }, { ptr, i64 } { ptr @tn.str.598, i64 11 }, { ptr, i64 } { ptr @tn.str.599, i64 12 }, { ptr, i64 } { ptr @tn.str.600, i64 12 }, { ptr, i64 } { ptr @tn.str.601, i64 6 }, { ptr, i64 } { ptr @tn.str.602, i64 7 }, { ptr, i64 } { ptr @tn.str.603, i64 5 }, { ptr, i64 } { ptr @tn.str.604, i64 4 }, { ptr, i64 } { ptr @tn.str.605, i64 6 }, { ptr, i64 } { ptr @tn.str.606, i64 5 }, { ptr, i64 } { ptr @tn.str.607, i64 8 }, { ptr, i64 } { ptr @tn.str.608, i64 15 }, { ptr, i64 } { ptr @tn.str.609, i64 18 }, { ptr, i64 } { ptr @tn.str.610, i64 6 }, { ptr, i64 } { ptr @tn.str.611, i64 7 }, { ptr, i64 } { ptr @tn.str.612, i64 6 }, { ptr, i64 } { ptr @tn.str.613, i64 13 }, { ptr, i64 } { ptr @tn.str.614, i64 7 }, { ptr, i64 } { ptr @tn.str.615, i64 4 }, { ptr, i64 } { ptr @tn.str.616, i64 16 }, { ptr, i64 } { ptr @tn.str.617, i64 10 }, { ptr, i64 } { ptr @tn.str.618, i64 8 }, { ptr, i64 } { ptr @tn.str.619, i64 11 }, { ptr, i64 } { ptr @tn.str.620, i64 14 }, { ptr, i64 } { ptr @tn.str.621, i64 7 }, { ptr, i64 } { ptr @tn.str.622, i64 13 }, { ptr, i64 } { ptr @tn.str.623, i64 9 }, { ptr, i64 } { ptr @tn.str.624, i64 8 }, { ptr, i64 } { ptr @tn.str.625, i64 10 }, { ptr, i64 } { ptr @tn.str.626, i64 5 }, { ptr, i64 } { ptr @tn.str.627, i64 5 }, { ptr, i64 } { ptr @tn.str.628, i64 9 }, { ptr, i64 } { ptr @tn.str.629, i64 19 }, { ptr, i64 } { ptr @tn.str.630, i64 9 }, { ptr, i64 } { ptr @tn.str.631, i64 9 }, { ptr, i64 } { ptr @tn.str.632, i64 6 }, { ptr, i64 } { ptr @tn.str.633, i64 16 }, { ptr, i64 } { ptr @tn.str.634, i64 13 }, { ptr, i64 } { ptr @tn.str.635, i64 14 }, { ptr, i64 } { ptr @tn.str.636, i64 7 }, { ptr, i64 } { ptr @tn.str.637, i64 7 }, { ptr, i64 } { ptr @tn.str.638, i64 8 }, { ptr, i64 } { ptr @tn.str.639, i64 8 }, { ptr, i64 } { ptr @tn.str.640, i64 9 }, { ptr, i64 } { ptr @tn.str.641, i64 5 }, { ptr, i64 } { ptr @tn.str.642, i64 11 }, { ptr, i64 } { ptr @tn.str.643, i64 10 }, { ptr, i64 } { ptr @tn.str.644, i64 5 }, { ptr, i64 } { ptr @tn.str.645, i64 12 }, { ptr, i64 } { ptr @tn.str.646, i64 7 }, { ptr, i64 } { ptr @tn.str.647, i64 6 }, { ptr, i64 } { ptr @tn.str.648, i64 10 }, { ptr, i64 } { ptr @tn.str.649, i64 19 }, { ptr, i64 } { ptr @tn.str.650, i64 6 }, { ptr, i64 } { ptr @tn.str.651, i64 4 }, { ptr, i64 } { ptr @tn.str.652, i64 5 }, { ptr, i64 } { ptr @tn.str.653, i64 10 }, { ptr, i64 } { ptr @tn.str.654, i64 5 }, { ptr, i64 } { ptr @tn.str.655, i64 9 }, { ptr, i64 } { ptr @tn.str.656, i64 7 }, { ptr, i64 } { ptr @tn.str.657, i64 10 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.662, i64 8 }, { ptr, i64 } { ptr @tn.str.663, i64 6 }, { ptr, i64 } { ptr @tn.str.664, i64 8 }, { ptr, i64 } { ptr @tn.str.665, i64 7 }, { ptr, i64 } { ptr @tn.str.666, i64 13 }, { ptr, i64 } { ptr @tn.str.667, i64 7 }, { ptr, i64 } { ptr @tn.str.668, i64 8 }, { ptr, i64 } { ptr @tn.str.669, i64 5 }, { ptr, i64 } { ptr @tn.str.670, i64 7 }, { ptr, i64 } { ptr @tn.str.671, i64 6 }, { ptr, i64 } { ptr @tn.str.672, i64 9 }, { ptr, i64 } { ptr @tn.str.673, i64 16 }, { ptr, i64 } { ptr @tn.str.674, i64 19 }, { ptr, i64 } { ptr @tn.str.675, i64 8 }, { ptr, i64 } { ptr @tn.str.676, i64 7 }, { ptr, i64 } { ptr @tn.str.677, i64 14 }, { ptr, i64 } { ptr @tn.str.678, i64 6 }, { ptr, i64 } { ptr @tn.str.679, i64 8 }, { ptr, i64 } { ptr @tn.str.680, i64 15 }, { ptr, i64 } { ptr @tn.str.681, i64 8 }] @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 [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 +@str.684 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.685 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.686 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.687 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.688 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.689 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.690 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.691 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.692 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.693 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.694 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \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")); \00", align 1 +@str.697 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.698 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.699 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.700 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.701 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.702 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.703 = private unnamed_addr constant [27 x i8] c"=== Auto Type Erasure ===\0A\00", align 1 +@str.704 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.705 = private unnamed_addr constant [27 x i8] c"=== Auto Type Erasure ===\0A\00", align 1 +@str.706 = private unnamed_addr constant [9 x i8] c"AE1: {}\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"AE1: {}\0A\00", align 1 +@str.709 = private unnamed_addr constant [9 x i8] c"AE2: {}\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"AE2: {}\0A\00", align 1 +@str.712 = private unnamed_addr constant [9 x i8] c"AE3: {}\0A\00", align 1 +@str.713 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.714 = private unnamed_addr constant [9 x i8] c"AE3: {}\0A\00", align 1 +@str.715 = private unnamed_addr constant [9 x i8] c"AE4: {}\0A\00", align 1 +@str.716 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.717 = private unnamed_addr constant [9 x i8] c"AE4: {}\0A\00", align 1 +@str.718 = private unnamed_addr constant [9 x i8] c"AE5: {}\0A\00", align 1 +@str.719 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.720 = private unnamed_addr constant [9 x i8] c"AE5: {}\0A\00", align 1 +@str.721 = private unnamed_addr constant [16 x i8] c"Source_Location\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 @fld.str = private constant [5 x i8] c"file\00" -@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 [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 +@fld.str.725 = private constant [5 x i8] c"line\00" +@fld.str.726 = private constant [4 x i8] c"col\00" +@fld.str.727 = 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.725, i64 4 }, { ptr, i64 } { ptr @fld.str.726, i64 3 }, { ptr, i64 } { ptr @fld.str.727, i64 4 }] +@str.728 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.729 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.730 = private unnamed_addr constant [2 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 [3 x i8] c", \00", align 1 +@fld.str.733 = private constant [4 x i8] c"ctx\00" +@fld.str.734 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.735 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.736 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.733, i64 3 }, { ptr, i64 } { ptr @fld.str.734, i64 11 }, { ptr, i64 } { ptr @fld.str.735, i64 13 }] +@str.737 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.738 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.739 = private unnamed_addr constant [2 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 [3 x i8] c", \00", align 1 +@fld.str.742 = private constant [10 x i8] c"allocator\00" +@fld.str.743 = private constant [5 x i8] c"data\00" +@field_names.744 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.742, i64 9 }, { ptr, i64 } { ptr @fld.str.743, i64 4 }] +@str.745 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.746 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.747 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.748 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.749 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.750 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.751 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.752 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.757 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.756, i64 11 }] +@str.758 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.759 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.764 = private constant [4 x i8] c"cap\00" +@field_names.765 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.763, i64 4 }, { ptr, i64 } { ptr @fld.str.764, i64 3 }] +@str.766 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.767 = private unnamed_addr constant [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.772 = private constant [10 x i8] c"end_index\00" +@fld.str.773 = private constant [7 x i8] c"parent\00" +@field_names.774 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.771, i64 5 }, { ptr, i64 } { ptr @fld.str.772, i64 9 }, { ptr, i64 } { ptr @fld.str.773, i64 6 }] +@str.775 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.776 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.777 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.778 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.779 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.780 = private constant [4 x i8] c"buf\00" +@fld.str.781 = private constant [4 x i8] c"len\00" +@fld.str.782 = private constant [4 x i8] c"pos\00" +@field_names.783 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.780, i64 3 }, { ptr, i64 } { ptr @fld.str.781, i64 3 }, { ptr, i64 } { ptr @fld.str.782, i64 3 }] +@str.784 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.785 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.786 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.787 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.788 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.789 = private constant [7 x i8] c"parent\00" +@fld.str.790 = private constant [12 x i8] c"alloc_count\00" +@fld.str.791 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.792 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.793 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.789, i64 6 }, { ptr, i64 } { ptr @fld.str.790, i64 11 }, { ptr, i64 } { ptr @fld.str.791, i64 13 }, { ptr, i64 } { ptr @fld.str.792, i64 17 }] +@str.794 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.795 = private unnamed_addr constant [5 x i8] c"File\00", align 1 +@str.796 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.797 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.798 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.799 = private constant [3 x i8] c"fd\00" +@field_names.800 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.799, i64 2 }] +@str.801 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.802 = private unnamed_addr constant [11 x i8] c"TraceFrame\00", align 1 +@str.803 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.804 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.805 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.806 = private constant [5 x i8] c"file\00" +@fld.str.807 = private constant [5 x i8] c"line\00" +@fld.str.808 = private constant [4 x i8] c"col\00" +@fld.str.809 = private constant [5 x i8] c"func\00" +@fld.str.810 = private constant [10 x i8] c"line_text\00" +@field_names.811 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.806, i64 4 }, { ptr, i64 } { ptr @fld.str.807, i64 4 }, { ptr, i64 } { ptr @fld.str.808, i64 3 }, { ptr, i64 } { ptr @fld.str.809, i64 4 }, { ptr, i64 } { ptr @fld.str.810, i64 9 }] +@str.812 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.813 = private unnamed_addr constant [14 x i8] c"ProcessResult\00", align 1 +@str.814 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.815 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.816 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.817 = private constant [10 x i8] c"exit_code\00" +@fld.str.818 = private constant [7 x i8] c"stdout\00" +@field_names.819 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.817, i64 9 }, { ptr, i64 } { ptr @fld.str.818, i64 6 }] +@str.820 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.821 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.822 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.823 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.824 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.825 = private constant [8 x i8] c"sin_len\00" +@fld.str.826 = private constant [11 x i8] c"sin_family\00" +@fld.str.827 = private constant [9 x i8] c"sin_port\00" +@fld.str.828 = private constant [9 x i8] c"sin_addr\00" +@fld.str.829 = private constant [9 x i8] c"sin_zero\00" +@field_names.830 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.825, i64 7 }, { ptr, i64 } { ptr @fld.str.826, i64 10 }, { ptr, i64 } { ptr @fld.str.827, i64 8 }, { ptr, i64 } { ptr @fld.str.828, i64 8 }, { ptr, i64 } { ptr @fld.str.829, i64 8 }] +@str.831 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.832 = private unnamed_addr constant [6 x i8] c"Array\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"Object\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 [6 x i8] c"items\00" +@fld.str.846 = private constant [4 x i8] c"len\00" +@fld.str.847 = private constant [4 x i8] c"cap\00" +@field_names.848 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.845, i64 5 }, { ptr, i64 } { ptr @fld.str.846, i64 3 }, { ptr, i64 } { ptr @fld.str.847, i64 3 }] +@str.849 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.850 = private unnamed_addr constant [7 x i8] c"Member\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 [4 x i8] c"key\00" +@fld.str.855 = private constant [4 x i8] c"val\00" +@field_names.856 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.854, i64 3 }, { ptr, i64 } { ptr @fld.str.855, i64 3 }] +@str.857 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.858 = private unnamed_addr constant [5 x i8] c"Sink\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"dst\00" +@fld.str.863 = private constant [4 x i8] c"pos\00" +@fld.str.864 = private constant [5 x i8] c"file\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 4 }] +@str.866 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.867 = private unnamed_addr constant [7 x i8] c"Parser\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 +@fld.str.871 = private constant [4 x i8] c"src\00" +@fld.str.872 = private constant [4 x i8] c"pos\00" +@fld.str.873 = private constant [6 x i8] c"alloc\00" +@field_names.874 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.871, i64 3 }, { 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 [13 x i8] c"BuildOptions\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 +@field_names.880 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.881 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.882 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.887 = private constant [12 x i8] c"takes_value\00" +@fld.str.888 = private constant [9 x i8] c"required\00" +@field_names.889 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.886, i64 4 }, { ptr, i64 } { ptr @fld.str.887, i64 11 }, { ptr, i64 } { ptr @fld.str.888, i64 8 }] +@str.890 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.891 = private unnamed_addr constant [8 x i8] c"Command\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 [6 x i8] c"group\00" +@fld.str.896 = private constant [8 x i8] c"command\00" +@fld.str.897 = private constant [6 x i8] c"flags\00" +@field_names.898 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.895, i64 5 }, { ptr, i64 } { ptr @fld.str.896, i64 7 }, { ptr, i64 } { ptr @fld.str.897, i64 5 }] +@str.899 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.900 = private unnamed_addr constant [10 x i8] c"FlagValue\00", align 1 +@str.901 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.902 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.903 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.904 = private constant [4 x i8] c"set\00" +@fld.str.905 = private constant [6 x i8] c"value\00" +@field_names.906 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.904, i64 3 }, { ptr, i64 } { ptr @fld.str.905, i64 5 }] +@str.907 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.908 = private unnamed_addr constant [5 x i8] c"Diag\00", align 1 +@str.909 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.910 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.911 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.912 = private constant [6 x i8] c"index\00" +@fld.str.913 = private constant [6 x i8] c"token\00" +@field_names.914 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.912, i64 5 }, { ptr, i64 } { ptr @fld.str.913, i64 5 }] +@str.915 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.916 = private unnamed_addr constant [7 x i8] c"Parsed\00", align 1 +@str.917 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.918 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.919 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.920 = private constant [6 x i8] c"group\00" +@fld.str.921 = private constant [8 x i8] c"command\00" +@fld.str.922 = private constant [10 x i8] c"cmd_index\00" +@fld.str.923 = private constant [5 x i8] c"json\00" +@fld.str.924 = private constant [5 x i8] c"rest\00" +@fld.str.925 = private constant [5 x i8] c"spec\00" +@fld.str.926 = private constant [7 x i8] c"values\00" +@field_names.927 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.920, i64 5 }, { ptr, i64 } { ptr @fld.str.921, i64 7 }, { ptr, i64 } { ptr @fld.str.922, i64 9 }, { ptr, i64 } { ptr @fld.str.923, i64 4 }, { ptr, i64 } { ptr @fld.str.924, i64 4 }, { ptr, i64 } { ptr @fld.str.925, i64 4 }, { ptr, i64 } { ptr @fld.str.926, i64 6 }] +@str.928 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.929 = private unnamed_addr constant [7 x i8] c"Sha256\00", align 1 +@str.930 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.931 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.932 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.933 = private constant [2 x i8] c"h\00" +@fld.str.934 = private constant [4 x i8] c"buf\00" +@fld.str.935 = private constant [8 x i8] c"buf_len\00" +@fld.str.936 = private constant [10 x i8] c"total_len\00" +@field_names.937 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.933, i64 1 }, { ptr, i64 } { ptr @fld.str.934, i64 3 }, { ptr, i64 } { ptr @fld.str.935, i64 7 }, { ptr, i64 } { ptr @fld.str.936, i64 9 }] +@str.938 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.939 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1 +@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 [3 x i8] c", \00", align 1 +@fld.str.943 = private constant [5 x i8] c"data\00" +@field_names.944 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.943, i64 4 }] +@str.945 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.946 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1 +@str.947 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.948 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.949 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.950 = private constant [2 x i8] c"x\00" +@fld.str.951 = private constant [2 x i8] c"y\00" +@field_names.952 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.950, i64 1 }, { ptr, i64 } { ptr @fld.str.951, i64 1 }] +@str.953 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.954 = private unnamed_addr constant [6 x i8] c"Point\00", align 1 +@str.955 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.956 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.957 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.958 = private constant [2 x i8] c"x\00" +@fld.str.959 = private constant [2 x i8] c"y\00" +@field_names.960 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.958, i64 1 }, { ptr, i64 } { ptr @fld.str.959, i64 1 }] +@str.961 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.962 = private unnamed_addr constant [8 x i8] c"Counter\00", align 1 +@str.963 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.964 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.965 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.966 = private constant [4 x i8] c"ctx\00" +@fld.str.967 = private constant [9 x i8] c"__vtable\00" +@field_names.968 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.966, i64 3 }, { ptr, i64 } { ptr @fld.str.967, i64 8 }] +@str.969 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.970 = private unnamed_addr constant [18 x i8] c"__Counter__Vtable\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 [3 x i8] c", \00", align 1 +@fld.str.974 = private constant [4 x i8] c"inc\00" +@fld.str.975 = private constant [4 x i8] c"get\00" +@field_names.976 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.974, i64 3 }, { ptr, i64 } { ptr @fld.str.975, i64 3 }] +@str.977 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.978 = private unnamed_addr constant [9 x i8] c"Summable\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 +@fld.str.982 = private constant [4 x i8] c"ctx\00" +@fld.str.983 = private constant [9 x i8] c"__vtable\00" +@field_names.984 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.982, i64 3 }, { ptr, i64 } { ptr @fld.str.983, i64 8 }] +@str.985 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.986 = private unnamed_addr constant [19 x i8] c"__Summable__Vtable\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 +@fld.str.990 = private constant [4 x i8] c"sum\00" +@field_names.991 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.990, i64 3 }] +@str.992 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.993 = private unnamed_addr constant [14 x i8] c"SimpleCounter\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 +@fld.str.997 = private constant [4 x i8] c"val\00" +@field_names.998 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.997, i64 3 }] +@str.999 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.1000 = private unnamed_addr constant [6 x i8] c"Adder\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 [4 x i8] c"ctx\00" +@fld.str.1005 = private constant [4 x i8] c"add\00" +@fld.str.1006 = private constant [6 x i8] c"value\00" +@field_names.1007 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1004, i64 3 }, { ptr, i64 } { ptr @fld.str.1005, i64 3 }, { ptr, i64 } { ptr @fld.str.1006, i64 5 }] +@str.1008 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.1009 = private unnamed_addr constant [12 x i8] c"Accumulator\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 +@fld.str.1013 = private constant [6 x i8] c"total\00" +@field_names.1014 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1013, i64 5 }] +@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 +@fld.str.1017 = private constant [5 x i8] c"read\00" +@fld.str.1018 = private constant [6 x i8] c"write\00" +@fld.str.1019 = private constant [7 x i8] c"append\00" +@fld.str.1020 = private constant [11 x i8] c"read_write\00" +@field_names.1021 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1017, i64 4 }, { ptr, i64 } { ptr @fld.str.1018, i64 5 }, { ptr, i64 } { ptr @fld.str.1019, i64 6 }, { ptr, i64 } { ptr @fld.str.1020, i64 10 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.1025 = private constant [4 x i8] c"set\00" +@fld.str.1026 = private constant [8 x i8] c"current\00" +@fld.str.1027 = private constant [4 x i8] c"end\00" +@field_names.1028 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1025, i64 3 }, { ptr, i64 } { ptr @fld.str.1026, i64 7 }, { ptr, i64 } { ptr @fld.str.1027, i64 3 }] +@str.1029 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@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 +@fld.str.1032 = private constant [6 x i8] c"null_\00" +@fld.str.1033 = private constant [6 x i8] c"bool_\00" +@fld.str.1034 = private constant [5 x i8] c"int_\00" +@fld.str.1035 = private constant [4 x i8] c"str\00" +@fld.str.1036 = private constant [6 x i8] c"array\00" +@fld.str.1037 = private constant [7 x i8] c"object\00" +@field_names.1038 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1032, i64 5 }, { ptr, i64 } { ptr @fld.str.1033, i64 5 }, { ptr, i64 } { ptr @fld.str.1034, i64 4 }, { ptr, i64 } { ptr @fld.str.1035, i64 3 }, { ptr, i64 } { ptr @fld.str.1036, i64 5 }, { ptr, i64 } { ptr @fld.str.1037, i64 6 }] +@str.1039 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.1040 = private unnamed_addr constant [2 x i8] c")\00", align 1 +@str.1041 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.1042 = private constant [6 x i8] c"macos\00" +@fld.str.1043 = private constant [6 x i8] c"linux\00" +@fld.str.1044 = private constant [8 x i8] c"windows\00" +@fld.str.1045 = private constant [5 x i8] c"wasm\00" +@fld.str.1046 = private constant [4 x i8] c"ios\00" +@fld.str.1047 = private constant [8 x i8] c"android\00" +@fld.str.1048 = private constant [8 x i8] c"unknown\00" +@field_names.1049 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1042, i64 5 }, { ptr, i64 } { ptr @fld.str.1043, i64 5 }, { ptr, i64 } { ptr @fld.str.1044, i64 7 }, { ptr, i64 } { ptr @fld.str.1045, i64 4 }, { ptr, i64 } { ptr @fld.str.1046, i64 3 }, { ptr, i64 } { ptr @fld.str.1047, i64 7 }, { 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 +@fld.str.1053 = private constant [8 x i8] c"aarch64\00" +@fld.str.1054 = private constant [7 x i8] c"x86_64\00" +@fld.str.1055 = private constant [7 x i8] c"wasm32\00" +@fld.str.1056 = private constant [7 x i8] c"wasm64\00" +@fld.str.1057 = private constant [8 x i8] c"unknown\00" +@field_names.1058 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.1053, i64 7 }, { ptr, i64 } { ptr @fld.str.1054, i64 6 }, { ptr, i64 } { ptr @fld.str.1055, i64 6 }, { ptr, i64 } { ptr @fld.str.1056, i64 6 }, { ptr, i64 } { ptr @fld.str.1057, i64 7 }] +@str.1059 = private unnamed_addr constant [2 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 [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 [2 x i8] c"[\00", align 1 +@str.1089 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1090 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.1093 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.1094 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.1095 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.1096 = private unnamed_addr constant [3 x i8] c", \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"*void\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 [12 x i8] c"*CAllocator\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 [5 x i8] c"*GPA\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 [12 x i8] c"*ArenaChunk\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 [7 x i8] c"*Arena\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"[*]u8\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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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 [6 x i8] c"*File\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 [4 x i8] c"*u8\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 [5 x i8] c"*s32\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 [10 x i8] c"*SockAddr\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"*u32\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 [9 x i8] c"[*]Value\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 [7 x i8] c"*Array\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 [10 x i8] c"[*]Member\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 [8 x i8] c"*Object\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 [6 x i8] c"*Sink\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 [8 x i8] c"*Parser\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 [5 x i8] c"*s64\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 [8 x i8] c"*Parsed\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 [6 x i8] c"*Diag\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 [8 x i8] c"*Sha256\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 [15 x i8] c"*SimpleCounter\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"*Point\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 [13 x i8] c"*Accumulator\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 [13 x i8] c"**CAllocator\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"**void\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 [8 x i8] c"*string\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 [5 x i8] c"*Any\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 [7 x i8] c"*[]Any\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 [6 x i8] c"*bool\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 [9 x i8] c"*Counter\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 [16 x i8] c"**SimpleCounter\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 [19 x i8] c"*__Counter__Vtable\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 [8 x i8] c"*[1]Any\00", align 1 +@str.1204 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1205 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1206 = private unnamed_addr constant [7 x i8] c"*Adder\00", align 1 +@str.1207 = private unnamed_addr constant [4 x i8] c"@0x\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 +@str.1209 = private unnamed_addr constant [14 x i8] c"**Accumulator\00", align 1 +@str.1210 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.1211 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1212 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1213 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.1214 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -762,85 +762,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -983,7 +905,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.471, i64 1 } + ret { ptr, i64 } { ptr @str.475, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1110,7 +1032,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.472, i64 4 }, %if.then.78 ], [ { ptr @str.473, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.476, i64 4 }, %if.then.78 ], [ { ptr @str.477, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1444,7 +1366,7 @@ entry: br i1 %icmp, label %if.then.442, label %if.merge.443 if.then.442: ; preds = %entry - ret { ptr, i64 } { ptr @str.474, i64 1 } + ret { ptr, i64 } { ptr @str.478, i64 1 } if.merge.443: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1594,7 +1516,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.475, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.479, 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 @@ -1621,12 +1543,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1661,26 +1583,26 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 93, label %match.arm.47 i64 117, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 110, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1723,7 +1645,7 @@ match.merge.37: ; preds = %dispatch.merge.566, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.476, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.480, 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 @@ -1768,12 +1690,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1834,7 +1756,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.324 [ - i64 35, label %dispatch.case.325 + i64 22, label %dispatch.case.325 i64 81, label %dispatch.case.326 i64 87, label %dispatch.case.327 i64 88, label %dispatch.case.328 @@ -1848,7 +1770,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.368 [ - i64 36, label %dispatch.case.369 + i64 23, label %dispatch.case.369 i64 60, label %dispatch.case.370 i64 77, label %dispatch.case.371 i64 85, label %dispatch.case.372 @@ -1861,13 +1783,13 @@ 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 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 - i64 33, label %dispatch.case.408 + i64 25, label %dispatch.case.402 + i64 27, label %dispatch.case.403 + i64 29, label %dispatch.case.404 + i64 31, label %dispatch.case.405 + i64 32, label %dispatch.case.406 + i64 34, label %dispatch.case.407 + i64 36, label %dispatch.case.408 i64 40, label %dispatch.case.409 i64 44, label %dispatch.case.410 i64 47, label %dispatch.case.411 @@ -1968,7 +1890,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.678, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.682, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1990,56 +1912,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2257,7 +2179,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.679, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.683, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.306 dispatch.case.308: ; preds = %match.arm.44 @@ -2298,7 +2220,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.680, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.684, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.323 dispatch.case.325: ; preds = %match.arm.47 @@ -2363,7 +2285,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.681, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.685, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.367 dispatch.case.369: ; preds = %match.arm.48 @@ -2412,7 +2334,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.682, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.686, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.399 dispatch.case.401: ; preds = %match.arm.49 @@ -2687,7 +2609,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.683, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.687, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.566 dispatch.case.568: ; preds = %match.arm.50 @@ -2729,7 +2651,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 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.688, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2825,7 +2747,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.685, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.689, 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 @@ -2833,7 +2755,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.686, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2843,13 +2765,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.687, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.691, 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.688, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.692, 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 @@ -2857,7 +2779,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.689, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.693, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2871,7 +2793,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.690, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.694, 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 @@ -2879,7 +2801,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.691, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2890,7 +2812,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.692, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.696, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2947,7 +2869,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.693, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.697, 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 @@ -2955,7 +2877,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.694, i64 2 }) + %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2966,7 +2888,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.695, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.699, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2986,7 +2908,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.696, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.700, 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 @@ -2994,7 +2916,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.697, 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 }, ptr %alloca, align 8 @@ -3005,7 +2927,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.698, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.702, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -3015,67 +2937,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3251,166 +3257,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3608,64 +3614,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3695,97 +3701,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3824,7 +3830,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind declare void @Mat4.identity(ptr sret({ [16 x float] }), ptr) #0 @@ -3893,1033 +3899,1039 @@ 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.127(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.128(i64, ptr) #0 +declare void @BuildOptions.add_framework.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.129(i64, ptr) #0 +declare void @BuildOptions.set_output_path.131(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.132(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.133(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.132(i64) #0 +declare i64 @BuildOptions.asset_dir_count.134(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.135(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.136(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.137(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.138(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.137(i64) #0 +declare ptr @BuildOptions.binary_path.139(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.141(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.142(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.143(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.142(i64) #0 +declare ptr @BuildOptions.bundle_path.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.143(i64) #0 +declare ptr @BuildOptions.bundle_id.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.144(i64) #0 +declare ptr @BuildOptions.codesign_identity.146(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.145(i64) #0 +declare ptr @BuildOptions.provisioning_profile.147(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.146(i64) #0 +declare ptr @BuildOptions.target_triple.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.147(i64) #0 +declare i1 @BuildOptions.is_macos.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.148(i64) #0 +declare i1 @BuildOptions.is_ios.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.149(i64) #0 +declare i1 @BuildOptions.is_ios_device.151(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.152(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.151(i64) #0 +declare i1 @BuildOptions.is_android.153(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.152(i64) #0 +declare i64 @BuildOptions.framework_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.154(i64) #0 +declare i64 @BuildOptions.framework_path_count.156(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.157(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.158(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.159(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.158(i64) #0 +declare ptr @BuildOptions.manifest_path.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.159(i64) #0 +declare ptr @BuildOptions.keystore_path.161(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.160(i64) #0 +declare i64 @BuildOptions.jni_main_count.162(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.163(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.164(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.163() #0 +declare i64 @build_options.165() #0 ; Function Attrs: nounwind -declare void @assert.164(ptr, i1) #0 +declare void @assert.166(ptr, i1) #0 ; Function Attrs: nounwind -declare void @out.165(ptr) #0 +declare void @out.167(ptr) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.166(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.168(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.167(ptr, ptr, i64) #0 +declare ptr @cstring.169(ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.168(ptr, ptr, ptr) #0 +declare ptr @int_to_string.170(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.169(ptr) #0 +declare ptr @uint_to_string.171(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.170(ptr, ptr, i64) #0 +declare ptr @bool_to_string.172(ptr, i1) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.171(ptr, ptr, ptr) #0 +declare ptr @float_to_string.173(ptr, double) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.172(ptr, ptr, i64) #0 +declare void @hex_group.174(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.173(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare [4 x i64] @decompose_u16x4.175(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.174(ptr, ptr) #0 +declare ptr @int_to_hex_string.176(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.175(ptr, ptr) #0 +declare ptr @concat.177(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.176(ptr, ptr, i64) #0 +declare ptr @substr.178(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.177(ptr, ptr, ptr) #0 +declare ptr @path_join.179(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.178(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare ptr @any_to_string.180(ptr, [2 x i64]) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.179(ptr, ptr) #0 +declare ptr @build_format.181(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.180(ptr, ptr, i64) #0 +declare void @out.182(ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.181(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.183(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.182(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @CAllocator.alloc_bytes.184(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.183(ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.185(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.184(ptr, ptr) #0 +declare i64 @GPA.init.186(ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.185(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.187(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.186(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.188(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @cstring.187(ptr, i64) #0 +declare void @Arena.add_chunk.189(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_string.188(ptr, i64) #0 +declare void @Arena.init.190(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @uint_to_string.189(ptr, i64) #0 +declare void @Arena.reset.191(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @bool_to_string.190(ptr, i1) #0 +declare void @Arena.deinit.192(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @float_to_string.191(ptr, double) #0 +declare ptr @Arena.alloc_bytes.193(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @hex_group.192(ptr, ptr, i64, i64) #0 +declare void @Arena.dealloc_bytes.194(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [4 x i64] @decompose_u16x4.193(ptr, i64) #0 +declare void @BufAlloc.init.195(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_hex_string.194(ptr, i64) #0 +declare void @BufAlloc.reset.196(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @concat.195(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.197(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @substr.196(ptr, ptr, i64, i64) #0 +declare void @BufAlloc.dealloc_bytes.198(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @path_join.197(ptr, ptr) #0 +declare void @TrackingAllocator.init.199(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @any_to_string.198(ptr, [2 x i64]) #0 +declare i64 @TrackingAllocator.leak_count.200(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @build_format.199(ptr, ptr) #0 +declare void @TrackingAllocator.report.201(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.200(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.202(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.201(ptr, ptr, i64) #0 +declare void @TrackingAllocator.dealloc_bytes.203(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.202(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.204(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.203(ptr) #0 +declare ptr @CAllocator.alloc_bytes.205(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.204(ptr, ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.206(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.205(ptr, ptr, ptr) #0 +declare i64 @GPA.init.207(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.206(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.208(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.207(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.209(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.reset.208(ptr, ptr) #0 +declare void @Arena.add_chunk.210(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.209(ptr, ptr) #0 +declare void @Arena.init.211(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.210(ptr, ptr, i64) #0 +declare void @Arena.reset.212(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.211(ptr, ptr, ptr) #0 +declare void @Arena.deinit.213(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.212(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.214(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.213(ptr, ptr) #0 +declare void @Arena.dealloc_bytes.215(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.214(ptr, ptr, i64) #0 +declare void @BufAlloc.init.216(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.215(ptr, ptr, ptr) #0 +declare void @BufAlloc.reset.217(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.216(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.218(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.217(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.219(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.218(ptr, ptr) #0 +declare void @TrackingAllocator.init.220(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.219(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.221(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.220(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.222(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @escape.221(ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes.223(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @log_emit.222(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.224(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.223(ptr, i32, ...) #0 +declare ptr @escape.225(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.224(i32) #0 +declare void @log_emit.226(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.225(i32, ptr, i64) #0 +declare i32 @open.227(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.226(i32, i64, i32) #0 +declare i32 @close.228(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.227(ptr) #0 +declare i64 @read.229(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.228(ptr) #0 +declare i64 @lseek.230(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.229(ptr, i32) #0 +declare i32 @unlink.231(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.230(ptr, i32) #0 +declare i32 @rmdir.232(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.231(ptr, i32) #0 +declare i32 @mkdir.233(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.232(ptr, ptr) #0 +declare i32 @access.234(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.233(ptr, ptr) #0 +declare i32 @chmod.235(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.234(ptr, ptr) #0 +declare i32 @rename.236(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.235(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.237(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.236(ptr, ptr, ptr) #0 +declare i1 @File.close.238(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.237(ptr, ptr, i64, i64) #0 +declare i64 @File.read.239(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.238(ptr, i64) #0 +declare i64 @File.write.240(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.239(ptr, ptr, i64) #0 +declare i64 @File.seek.241(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.240(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.242(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.241(ptr, ptr, ptr) #0 +declare i64 @open_file.243(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.242(ptr, ptr, ptr) #0 +declare void @read_file.244(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.243(ptr, ptr) #0 +declare i1 @write_file.245(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.244(ptr, ptr) #0 +declare i1 @append_file.246(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.245(ptr, ptr) #0 +declare i1 @exists.247(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.246(ptr, ptr) #0 +declare i1 @delete_file.248(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.247(ptr, ptr, i32) #0 +declare i1 @delete_dir.249(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.248(ptr, ptr, ptr) #0 +declare i1 @create_dir.250(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.249(ptr, ptr) #0 +declare i1 @set_mode.251(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.250(ptr, ptr, ptr) #0 +declare i1 @move.252(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.251(ptr, ptr) #0 +declare i1 @create_dir_all.253(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.252(ptr, ptr) #0 +declare i1 @copy_file.254(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @spaces.253(ptr, i32) #0 +declare ptr @basename.255(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.254() #0 +declare ptr @dirname.256(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.255() #0 +declare ptr @spaces.257(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.256(i32) #0 +declare i32 @sx_trace_len.258() #0 ; Function Attrs: nounwind -declare ptr @to_string.257(ptr) #0 +declare i32 @sx_trace_truncated.259() #0 ; Function Attrs: nounwind -declare void @print_current.258(ptr) #0 +declare i64 @sx_trace_frame_at.260(i32) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.259(ptr) #0 +declare ptr @to_string.261(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.260(ptr, ptr) #0 +declare void @print_current.262(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.261(ptr) #0 +declare void @print_interpreter_frames.263(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.262(ptr, i64, i64, ptr) #0 +declare ptr @popen.264(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.263(ptr) #0 +declare i32 @pclose.265(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.264(ptr) #0 +declare i64 @fread.266(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.265(ptr) #0 +declare i32 @feof.267(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.266(ptr) #0 +declare ptr @getenv.268(ptr) #0 ; Function Attrs: nounwind -declare void @run.267(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare i64 @strlen.269(ptr) #0 ; Function Attrs: nounwind -declare void @env.268(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.270(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.269(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @run.271(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.270(i32) #0 +declare void @env.272(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.271(ptr, i8, ptr) #0 +declare void @find_executable.273(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.272(ptr, i1, ptr, ptr) #0 +declare void @_exit.274(i32) #0 ; Function Attrs: nounwind -declare i32 @socket.273(i32, i32, i32) #0 +declare void @exit.275(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @setsockopt.274(i32, i32, i32, ptr, i32) #0 +declare void @assert.276(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @bind.275(i32, ptr, i32) #0 +declare i32 @socket.277(i32, i32, i32) #0 ; Function Attrs: nounwind -declare i32 @listen.276(i32, i32) #0 +declare i32 @setsockopt.278(i32, i32, i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @accept.277(i32, ptr, ptr) #0 +declare i32 @bind.279(i32, ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @read.278(i32, ptr, i64) #0 +declare i32 @listen.280(i32, i32) #0 ; Function Attrs: nounwind -declare i32 @close.279(i32) #0 +declare i32 @accept.281(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i16 @htons.280(ptr, i64) #0 +declare i64 @read.282(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.281(ptr, ptr, ptr, i64, i64, i64) #0 +declare i32 @close.283(i32) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.282(ptr, ptr, i64) #0 +declare i16 @htons.284(ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.283(ptr, ptr, ptr) #0 +declare ptr @mem_realloc.285(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.284(ptr) #0 +declare ptr @CAllocator.alloc_bytes.286(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.285(ptr, ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.287(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.286(ptr, ptr, ptr) #0 +declare i64 @GPA.init.288(ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.287(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.289(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.288(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes.290(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.reset.289(ptr, ptr) #0 +declare void @Arena.add_chunk.291(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.290(ptr, ptr) #0 +declare void @Arena.init.292(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.291(ptr, ptr, i64) #0 +declare void @Arena.reset.293(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.292(ptr, ptr, ptr) #0 +declare void @Arena.deinit.294(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.293(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.295(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.294(ptr, ptr) #0 +declare void @Arena.dealloc_bytes.296(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.295(ptr, ptr, i64) #0 +declare void @BufAlloc.init.297(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.296(ptr, ptr, ptr) #0 +declare void @BufAlloc.reset.298(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.297(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes.299(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.298(ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.300(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.299(ptr, ptr) #0 +declare void @TrackingAllocator.init.301(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.300(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.302(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.301(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.303(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.302(ptr, i32, ...) #0 +declare ptr @TrackingAllocator.alloc_bytes.304(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.303(i32) #0 +declare void @TrackingAllocator.dealloc_bytes.305(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.304(i32, ptr, i64) #0 +declare i32 @open.306(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.305(i32, i64, i32) #0 +declare i32 @close.307(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.306(ptr) #0 +declare i64 @read.308(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.307(ptr) #0 +declare i64 @lseek.309(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.308(ptr, i32) #0 +declare i32 @unlink.310(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.309(ptr, i32) #0 +declare i32 @rmdir.311(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.310(ptr, i32) #0 +declare i32 @mkdir.312(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.311(ptr, ptr) #0 +declare i32 @access.313(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.312(ptr, ptr) #0 +declare i32 @chmod.314(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.313(ptr, ptr) #0 +declare i32 @rename.315(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.314(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.316(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.315(ptr, ptr, ptr) #0 +declare i1 @File.close.317(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.316(ptr, ptr, i64, i64) #0 +declare i64 @File.read.318(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.317(ptr, i64) #0 +declare i64 @File.write.319(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.318(ptr, ptr, i64) #0 +declare i64 @File.seek.320(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.319(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.321(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.320(ptr, ptr, ptr) #0 +declare i64 @open_file.322(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.321(ptr, ptr, ptr) #0 +declare void @read_file.323(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.322(ptr, ptr) #0 +declare i1 @write_file.324(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.323(ptr, ptr) #0 +declare i1 @append_file.325(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.324(ptr, ptr) #0 +declare i1 @exists.326(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.325(ptr, ptr) #0 +declare i1 @delete_file.327(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.326(ptr, ptr, i32) #0 +declare i1 @delete_dir.328(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.327(ptr, ptr, ptr) #0 +declare i1 @create_dir.329(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.328(ptr, ptr) #0 +declare i1 @set_mode.330(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.329(ptr, ptr, ptr) #0 +declare i1 @move.331(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.330(ptr, ptr) #0 +declare i1 @create_dir_all.332(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.331(ptr, ptr) #0 +declare i1 @copy_file.333(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.add.332(ptr, ptr, ptr, ptr) #0 +declare ptr @basename.334(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Array.deinit.333(ptr, ptr, ptr) #0 +declare ptr @dirname.335(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.put.334(ptr, ptr, ptr, ptr, ptr) #0 +declare void @Array.add.336(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Object.deinit.335(ptr, ptr, ptr) #0 +declare void @Array.deinit.337(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put_byte.336(ptr, ptr, i8) #0 +declare void @Object.put.338(ptr, ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.put.337(ptr, ptr, ptr) #0 +declare void @Object.deinit.339(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @Sink.flush.338(ptr, ptr) #0 +declare i32 @Sink.put_byte.340(ptr, ptr, i8) #0 ; Function Attrs: nounwind -declare i8 @hex_digit.339(ptr, i64) #0 +declare i32 @Sink.put.341(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_u_escape.340(ptr, i8, ptr) #0 +declare i32 @Sink.flush.342(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_string.341(ptr, ptr, ptr) #0 +declare i8 @hex_digit.343(ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @write_int.342(ptr, i64, ptr) #0 +declare i32 @write_u_escape.344(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_value.343(ptr, ptr, ptr) #0 +declare i32 @write_string.345(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_array.344(ptr, ptr, ptr) #0 +declare i32 @write_int.346(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_object.345(ptr, ptr, ptr) #0 +declare i32 @write_value.347(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @write_to_buffer.346(ptr, ptr, ptr) #0 +declare i32 @write_array.348(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @write_to_file.347(ptr, ptr, ptr, ptr) #0 +declare i32 @write_object.349(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @hex_value.348(ptr, i8) #0 +declare [2 x i64] @write_to_buffer.350(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @encode_utf8.349(ptr, i64, ptr) #0 +declare i32 @write_to_file.351(ptr, ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.skip_ws.350(ptr, ptr) #0 +declare [2 x i64] @hex_value.352(ptr, i8) #0 ; Function Attrs: nounwind -declare i32 @Parser.expect_lit.351(ptr, ptr, ptr) #0 +declare i64 @encode_utf8.353(ptr, i64, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.read_hex4.352(ptr, ptr, i64, i64) #0 +declare void @Parser.skip_ws.354(ptr, ptr) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.decode_into.353(ptr, ptr, i64, i64, ptr) #0 +declare i32 @Parser.expect_lit.355(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_string.354(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.read_hex4.356(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare [2 x i64] @Parser.parse_number.355(ptr, ptr) #0 +declare [2 x i64] @Parser.decode_into.357(ptr, ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_array.356(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare void @Parser.parse_string.358(ptr sret({ { ptr, i64 }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_object.357(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare [2 x i64] @Parser.parse_number.359(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Parser.parse_value.358(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 +declare void @Parser.parse_array.360(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @parse.359(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 +declare void @Parser.parse_object.361(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.360(i64, ptr) #0 +declare void @Parser.parse_value.362(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.361(i64, ptr) #0 +declare void @parse.363(ptr sret({ { i64, [24 x i8] }, i32 }), ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.362(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.364(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.363(i64, ptr) #0 +declare void @BuildOptions.add_framework.365(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.364(i64, ptr, ptr) #0 +declare void @BuildOptions.set_output_path.366(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.365(i64) #0 +declare void @BuildOptions.set_wasm_shell.367(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.366(i64, i64) #0 +declare void @BuildOptions.add_asset_dir.368(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.367(i64, i64) #0 +declare i64 @BuildOptions.asset_dir_count.369(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.368(i64, ptr) #0 +declare ptr @BuildOptions.asset_dir_src_at.370(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.369(i64, ptr) #0 +declare ptr @BuildOptions.asset_dir_dest_at.371(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.370(i64) #0 +declare void @BuildOptions.set_post_link_callback.372(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.371(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.373(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.372(i64, ptr) #0 +declare ptr @BuildOptions.binary_path.374(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.373(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.375(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.374(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.376(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.375(i64) #0 +declare void @BuildOptions.set_codesign_identity.377(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.376(i64) #0 +declare void @BuildOptions.set_provisioning_profile.378(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.377(i64) #0 +declare ptr @BuildOptions.bundle_path.379(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.378(i64) #0 +declare ptr @BuildOptions.bundle_id.380(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.379(i64) #0 +declare ptr @BuildOptions.codesign_identity.381(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.380(i64) #0 +declare ptr @BuildOptions.provisioning_profile.382(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.381(i64) #0 +declare ptr @BuildOptions.target_triple.383(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.382(i64) #0 +declare i1 @BuildOptions.is_macos.384(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.383(i64) #0 +declare i1 @BuildOptions.is_ios.385(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.384(i64) #0 +declare i1 @BuildOptions.is_ios_device.386(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.385(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.387(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.386(i64, i64) #0 +declare i1 @BuildOptions.is_android.388(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.387(i64) #0 +declare i64 @BuildOptions.framework_count.389(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.388(i64, i64) #0 +declare ptr @BuildOptions.framework_at.390(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.389(i64, ptr) #0 +declare i64 @BuildOptions.framework_path_count.391(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.390(i64, ptr) #0 +declare ptr @BuildOptions.framework_path_at.392(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.391(i64) #0 +declare void @BuildOptions.set_manifest_path.393(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.392(i64) #0 +declare void @BuildOptions.set_keystore_path.394(i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.393(i64) #0 +declare ptr @BuildOptions.manifest_path.395(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.394(i64, i64) #0 +declare ptr @BuildOptions.keystore_path.396(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.395(i64, i64) #0 +declare i64 @BuildOptions.jni_main_count.397(i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.396() #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.398(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @spaces.397(ptr, i32) #0 +declare ptr @BuildOptions.jni_main_java_source_at.399(i64, i64) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.398() #0 +declare i64 @build_options.400() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.399() #0 +declare ptr @spaces.401(ptr, i32) #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.400(i32) #0 +declare i32 @sx_trace_len.402() #0 ; Function Attrs: nounwind -declare ptr @to_string.401(ptr) #0 +declare i32 @sx_trace_truncated.403() #0 ; Function Attrs: nounwind -declare void @print_current.402(ptr) #0 +declare i64 @sx_trace_frame_at.404(i32) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.403(ptr) #0 +declare ptr @to_string.405(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.404(ptr, ptr) #0 +declare void @print_current.406(ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.405(ptr) #0 +declare void @print_interpreter_frames.407(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.406(ptr, i64, i64, ptr) #0 +declare ptr @popen.408(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.407(ptr) #0 +declare i32 @pclose.409(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.408(ptr) #0 +declare i64 @fread.410(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.409(ptr) #0 +declare i32 @feof.411(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.410(ptr) #0 +declare ptr @getenv.412(ptr) #0 ; Function Attrs: nounwind -declare void @run.411(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare i64 @strlen.413(ptr) #0 ; Function Attrs: nounwind -declare void @env.412(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @system.414(ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.413(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @run.415(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.414(i32) #0 +declare void @env.416(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit.415(ptr, i8, ptr) #0 +declare void @find_executable.417(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @assert.416(ptr, i1, ptr, ptr) #0 +declare void @_exit.418(i32) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgv.417() #0 +declare void @exit.419(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare ptr @_NSGetArgc.418() #0 +declare void @assert.420(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @exit_ok.419(ptr) #0 +declare ptr @_NSGetArgv.421() #0 ; Function Attrs: nounwind -declare void @exit_usage.420(ptr) #0 +declare ptr @_NSGetArgc.422() #0 ; Function Attrs: nounwind -declare i64 @os_argc.421(ptr) #0 +declare void @exit_ok.423(ptr) #0 ; Function Attrs: nounwind -declare ptr @os_args.422(ptr, ptr) #0 +declare void @exit_usage.424(ptr) #0 ; Function Attrs: nounwind -declare i1 @Parsed.is_set.423(ptr, ptr, ptr) #0 +declare i64 @os_argc.425(ptr) #0 ; Function Attrs: nounwind -declare ptr @Parsed.value_of.424(ptr, ptr, ptr) #0 +declare ptr @os_args.426(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @is_long_flag.425(ptr, ptr) #0 +declare i1 @Parsed.is_set.427(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare ptr @Parsed.value_of.428(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.427(ptr, i32, ...) #0 +declare i1 @is_long_flag.429(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @close.428(i32) #0 +declare void @parse.430(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 @read.429(i32, ptr, i64) #0 +declare i32 @open.431(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i64 @lseek.430(i32, i64, i32) #0 +declare i32 @close.432(i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.431(ptr) #0 +declare i64 @read.433(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @rmdir.432(ptr) #0 +declare i64 @lseek.434(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @mkdir.433(ptr, i32) #0 +declare i32 @unlink.435(ptr) #0 ; Function Attrs: nounwind -declare i32 @access.434(ptr, i32) #0 +declare i32 @rmdir.436(ptr) #0 ; Function Attrs: nounwind -declare i32 @chmod.435(ptr, i32) #0 +declare i32 @mkdir.437(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.436(ptr, ptr) #0 +declare i32 @access.438(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.437(ptr, ptr) #0 +declare i32 @chmod.439(ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @File.close.438(ptr, ptr) #0 +declare i32 @rename.440(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.439(ptr, ptr, ptr) #0 +declare i1 @File.is_valid.441(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.440(ptr, ptr, ptr) #0 +declare i1 @File.close.442(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.441(ptr, ptr, i64, i64) #0 +declare i64 @File.read.443(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.442(ptr, i64) #0 +declare i64 @File.write.444(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @open_file.443(ptr, ptr, i64) #0 +declare i64 @File.seek.445(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare void @read_file.444(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare i32 @mode_to_flags.446(ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @write_file.445(ptr, ptr, ptr) #0 +declare i64 @open_file.447(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare i1 @append_file.446(ptr, ptr, ptr) #0 +declare void @read_file.448(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.447(ptr, ptr) #0 +declare i1 @write_file.449(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.448(ptr, ptr) #0 +declare i1 @append_file.450(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.449(ptr, ptr) #0 +declare i1 @exists.451(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.450(ptr, ptr) #0 +declare i1 @delete_file.452(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.451(ptr, ptr, i32) #0 +declare i1 @delete_dir.453(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @move.452(ptr, ptr, ptr) #0 +declare i1 @create_dir.454(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.453(ptr, ptr) #0 +declare i1 @set_mode.455(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @copy_file.454(ptr, ptr, ptr) #0 +declare i1 @move.456(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.455(ptr, ptr) #0 +declare i1 @create_dir_all.457(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.456(ptr, ptr) #0 +declare i1 @copy_file.458(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @rotr.457(ptr, i64, i64) #0 +declare ptr @basename.459(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma0.458(ptr, i64) #0 +declare ptr @dirname.460(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @big_sigma1.459(ptr, i64) #0 +declare i64 @rotr.461(ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i64 @small_sigma0.460(ptr, i64) #0 +declare i64 @big_sigma0.462(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @small_sigma1.461(ptr, i64) #0 +declare i64 @big_sigma1.463(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.process_block.462(ptr, ptr) #0 +declare i64 @small_sigma0.464(ptr, i64) #0 ; Function Attrs: nounwind -declare void @Sha256.update.463(ptr, ptr, ptr) #0 +declare i64 @small_sigma1.465(ptr, i64) #0 ; Function Attrs: nounwind -declare [64 x i8] @Sha256.final.464(ptr, ptr) #0 +declare void @Sha256.process_block.466(ptr, ptr) #0 ; Function Attrs: nounwind -declare i8 @nibble_hex.465(ptr, i64) #0 +declare void @Sha256.update.467(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @init.466(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 +declare [64 x i8] @Sha256.final.468(ptr, ptr) #0 ; Function Attrs: nounwind -declare [64 x i8] @sha256_hex.467(ptr, ptr) #0 +declare i8 @nibble_hex.469(ptr, i64) #0 ; Function Attrs: nounwind -declare void @sha256_file.468(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 +declare void @init.470(ptr sret({ [8 x i64], [64 x i8], i64, i64 }), ptr) #0 ; Function Attrs: nounwind -declare void @assert.469(ptr, i1) #0 +declare [64 x i8] @sha256_hex.471(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @sha256_file.472(ptr sret({ [64 x i8], i1 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @assert.473(ptr, i1) #0 ; Function Attrs: nounwind declare ptr @cwd_greet(ptr) #0 @@ -4934,7 +4946,7 @@ declare i32 @add(ptr, i32, i32) #0 declare i32 @mul(ptr, i32, i32) #0 ; Function Attrs: nounwind -declare i32 @add.470(ptr, i32, i32) #0 +declare i32 @add.474(ptr, i32, i32) #0 ; Function Attrs: nounwind define internal void @SimpleCounter.inc(ptr %0, ptr %1) #0 { @@ -5096,14 +5108,14 @@ entry: define internal void @print__ct_sb446f8dda4e4d2e__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.699, i64 26 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.703, 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.700, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.704, 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) @@ -5119,7 +5131,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.701, i64 26 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.705, i64 26 }) ret { ptr, i64 } %call } @@ -5167,7 +5179,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.702, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.706, 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 @@ -5183,7 +5195,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.703, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.707, 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) @@ -5211,7 +5223,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.704, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.708, i64 8 }) ret { ptr, i64 } %call } @@ -5233,7 +5245,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.705, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.709, 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 @@ -5249,7 +5261,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.706, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.710, 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) @@ -5277,7 +5289,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.707, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.711, i64 8 }) ret { ptr, i64 } %call } @@ -5311,7 +5323,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.708, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.712, 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 @@ -5327,7 +5339,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.709, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.713, 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) @@ -5355,7 +5367,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.710, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.714, i64 8 }) ret { ptr, i64 } %call } @@ -5383,7 +5395,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.711, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.715, 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 @@ -5399,7 +5411,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.712, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.716, 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) @@ -5427,7 +5439,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.713, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.717, i64 8 }) ret { ptr, i64 } %call } @@ -5447,7 +5459,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.714, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.718, 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 @@ -5463,7 +5475,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.715, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.719, 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) @@ -5491,7 +5503,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.716, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.720, i64 8 }) ret { ptr, i64 } %call } @@ -5502,7 +5514,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.717, i64 15 }, { ptr, i64 } { ptr @str.718, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 15 }, { ptr, i64 } { ptr @str.722, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5521,12 +5533,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.719, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.723, 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.720, 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.135 @@ -5538,7 +5550,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.724, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5595,7 +5607,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.725, i64 9 }, { ptr, i64 } { ptr @str.726, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 9 }, { ptr, i64 } { ptr @str.730, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5614,24 +5626,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.727, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.731, 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.728, 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 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 [3 x { ptr, i64 }], ptr @field_names.732, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.736, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.733, i64 2 }) + %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -5675,20 +5687,21 @@ fv.case21: ; preds = %if.merge.140 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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.734, i64 10 }, { ptr, i64 } { ptr @str.735, i64 1 }) + %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.738, i64 7 }, { ptr, i64 } { ptr @str.739, 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 +while.hdr.141: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 2 br i1 %icmp, label %while.body.142, label %while.exit.143 while.body.142: ; preds = %while.hdr.141 @@ -5698,24 +5711,102 @@ while.body.142: ; preds = %while.hdr.141 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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.740, 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 }) + %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 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.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.744, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 }) + %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 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.141 + +fv.default: ; preds = %if.merge.145 + br label %fv.merge + +fv.case: ; preds = %if.merge.145 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.145 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.746, i64 10 }, { ptr, i64 } { ptr @str.747, 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 = %if.merge.150, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + 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.748, 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.749, 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 [0 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.751, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5726,7 +5817,7 @@ if.merge.145: ; preds = %if.then.144, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.141 + br label %while.hdr.146 } ; Function Attrs: nounwind @@ -5734,43 +5825,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.752, i64 3 }, { 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 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.146 + br label %while.hdr.151 -while.hdr.146: ; preds = %fv.merge, %entry +while.hdr.151: ; 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 + br i1 %icmp, label %while.body.152, label %while.exit.153 -while.body.147: ; preds = %while.hdr.146 +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.149, label %if.merge.150 + br i1 %icmpN, label %if.then.154, label %if.merge.155 -while.exit.148: ; preds = %while.hdr.146 +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.742, 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.149: ; preds = %while.body.147 +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.743, 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.150 + br label %if.merge.155 -if.merge.150: ; preds = %if.then.149, %while.body.147 +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 [1 x { ptr, i64 }], ptr @field_names.745, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.757, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.758, 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 @@ -5787,12 +5878,12 @@ 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.146 + br label %while.hdr.151 -fv.default: ; preds = %if.merge.150 +fv.default: ; preds = %if.merge.155 br label %fv.merge -fv.case: ; preds = %if.merge.150 +fv.case: ; preds = %if.merge.155 %fv.field = extractvalue { i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge @@ -5803,43 +5894,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 10 }, { ptr, i64 } { ptr @str.760, 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 + br label %while.hdr.156 -while.hdr.151: ; preds = %fv.merge, %entry +while.hdr.156: ; 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 + br i1 %icmp, label %while.body.157, label %while.exit.158 -while.body.152: ; preds = %while.hdr.151 +while.body.157: ; preds = %while.hdr.156 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.154, label %if.merge.155 + br i1 %icmpN, label %if.then.159, label %if.merge.160 -while.exit.153: ; preds = %while.hdr.151 +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.749, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.761, i64 1 }) ret { ptr, i64 } %callN -if.then.154: ; preds = %while.body.152 +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.750, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.762, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.155 + br label %if.merge.160 -if.merge.155: ; preds = %if.then.154, %while.body.152 +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 [2 x { ptr, i64 }], ptr @field_names.753, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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.754, 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 { ptr, i64 }, ptr %alloca, align 8 @@ -5857,18 +5948,18 @@ 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.151 + br label %while.hdr.156 -fv.default: ; preds = %if.merge.155 +fv.default: ; preds = %if.merge.160 br label %fv.merge -fv.case: ; preds = %if.merge.155 +fv.case: ; preds = %if.merge.160 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.155 +fv.case17: ; preds = %if.merge.160 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -5880,91 +5971,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.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 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.156 - -while.hdr.156: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.157, label %while.exit.158 - -while.body.157: ; preds = %while.hdr.156 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.159, label %if.merge.160 - -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.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.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.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.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 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.156 - -fv.default: ; preds = %if.merge.160 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.160 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 8 }, { ptr, i64 } { ptr @str.765, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 5 }, { 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 @@ -5983,27 +5990,27 @@ 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.766, 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.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.767, 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.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.771, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.774, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.775, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -6025,17 +6032,101 @@ fv.default: ; preds = %if.merge.165 br label %fv.merge fv.case: ; preds = %if.merge.165 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.165 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { +entry: + %alloca = alloca { ptr, i64, i64 }, align 8 + store { ptr, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 8 }, { ptr, i64 } { ptr @str.777, 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, 3 + 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.778, 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.779, 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 [3 x { ptr, i64 }], ptr @field_names.783, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %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 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + i64 2, label %fv.case20 + ] + +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.166 + +fv.default: ; preds = %if.merge.170 + br label %fv.merge + +fv.case: ; preds = %if.merge.170 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.170 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.170 %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge @@ -6047,43 +6138,43 @@ 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.773, i64 17 }, { ptr, i64 } { ptr @str.774, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.785, i64 17 }, { ptr, i64 } { ptr @str.786, 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 + br label %while.hdr.171 -while.hdr.166: ; preds = %fv.merge, %entry +while.hdr.171: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 4 - br i1 %icmp, label %while.body.167, label %while.exit.168 + br i1 %icmp, label %while.body.172, label %while.exit.173 -while.body.167: ; preds = %while.hdr.166 +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.169, label %if.merge.170 + br i1 %icmpN, label %if.then.174, label %if.merge.175 -while.exit.168: ; preds = %while.hdr.166 +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.775, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.787, i64 1 }) ret { ptr, i64 } %callN -if.then.169: ; preds = %while.body.167 +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.776, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.788, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.170 + br label %if.merge.175 -if.merge.170: ; preds = %if.then.169, %while.body.167 +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 [4 x { ptr, i64 }], ptr @field_names.781, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.793, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.782, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -6103,110 +6194,31 @@ 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.166 - -fv.default: ; preds = %if.merge.170 - br label %fv.merge - -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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.170 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.170 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 - br label %fv.merge - -fv.case23: ; preds = %if.merge.170 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { -entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 - %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.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 - 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.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.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.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.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 - %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 }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.175 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.175 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.175 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -6215,7 +6227,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.791, i64 4 }, { ptr, i64 } { ptr @str.792, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 4 }, { ptr, i64 } { ptr @str.796, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6234,24 +6246,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.793, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.797, 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.794, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.798, 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.796, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.800, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.797, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -6288,7 +6300,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.798, i64 10 }, { ptr, i64 } { ptr @str.799, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.802, i64 10 }, { ptr, i64 } { ptr @str.803, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6307,24 +6319,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.800, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.804, 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.801, 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 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.807, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.811, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.812, 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 @@ -6390,7 +6402,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.809, i64 13 }, { ptr, i64 } { ptr @str.810, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.813, i64 13 }, { ptr, i64 } { ptr @str.814, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6409,24 +6421,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.811, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.815, 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.812, 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 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.815, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.819, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.816, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -6468,7 +6480,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.817, i64 8 }, { ptr, i64 } { ptr @str.818, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.821, i64 8 }, { ptr, i64 } { ptr @str.822, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6487,24 +6499,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.819, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.823, 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.820, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.824, 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.826, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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.827, 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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -6565,7 +6577,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.828, i64 5 }, { ptr, i64 } { ptr @str.829, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.832, i64 5 }, { 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 @@ -6584,24 +6596,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.830, 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.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.831, 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.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.835, 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.836, 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 %alloca, align 8 @@ -6647,7 +6659,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.837, i64 6 }, { ptr, i64 } { ptr @str.838, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.841, i64 6 }, { 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 @@ -6666,24 +6678,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.839, 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.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.840, 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.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.844, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.848, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.849, 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 @@ -6731,7 +6743,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.846, i64 6 }, { ptr, i64 } { ptr @str.847, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.850, i64 6 }, { ptr, i64 } { ptr @str.851, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6750,24 +6762,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.848, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.852, 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.849, 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 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.852, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.856, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.857, 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 @@ -6811,7 +6823,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.854, i64 4 }, { ptr, i64 } { ptr @str.855, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.858, i64 4 }, { ptr, i64 } { ptr @str.859, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6830,24 +6842,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.856, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.860, 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.857, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.861, 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.861, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.865, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.866, 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 @@ -6897,7 +6909,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.863, i64 6 }, { ptr, i64 } { ptr @str.864, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.867, i64 6 }, { ptr, i64 } { ptr @str.868, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6916,24 +6928,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.865, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.869, 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.866, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.870, 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.870, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.874, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.875, 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 @@ -6982,7 +6994,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.872, i64 12 }, { ptr, i64 } { ptr @str.873, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.876, i64 12 }, { ptr, i64 } { ptr @str.877, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7001,24 +7013,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.874, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.878, 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.875, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.879, 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.876, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.880, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.877, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -7038,7 +7050,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.878, i64 8 }, { ptr, i64 } { ptr @str.879, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.882, i64 8 }, { ptr, i64 } { ptr @str.883, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7057,24 +7069,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.880, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.884, 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.881, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.885, 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.885, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.889, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.886, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -7126,7 +7138,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.887, i64 7 }, { ptr, i64 } { ptr @str.888, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.891, i64 7 }, { ptr, i64 } { ptr @str.892, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7145,24 +7157,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.889, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.893, 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.890, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.894, 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.894, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.898, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.895, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -7214,7 +7226,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.896, i64 9 }, { ptr, i64 } { ptr @str.897, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.900, i64 9 }, { ptr, i64 } { ptr @str.901, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7233,24 +7245,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.898, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.902, 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.899, 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 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.902, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.906, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.903, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -7293,7 +7305,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.904, i64 4 }, { ptr, i64 } { ptr @str.905, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.908, i64 4 }, { ptr, i64 } { ptr @str.909, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7312,24 +7324,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.906, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.910, 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.907, 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 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.910, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.914, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.911, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -7375,7 +7387,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.912, i64 6 }, { ptr, i64 } { ptr @str.913, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.916, i64 6 }, { ptr, i64 } { ptr @str.917, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7394,24 +7406,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.914, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.918, 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.915, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.919, 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.923, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.927, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.924, 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 %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 @@ -7468,7 +7480,7 @@ fv.case28: ; preds = %if.merge.250 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.250 @@ -7493,7 +7505,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.925, i64 6 }, { ptr, i64 } { ptr @str.926, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.929, i64 6 }, { ptr, i64 } { ptr @str.930, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7512,24 +7524,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.927, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.931, 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.928, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.932, 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.933, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.937, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.934, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -7585,7 +7597,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.935, i64 4 }, { ptr, i64 } { ptr @str.936, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.939, i64 4 }, { ptr, i64 } { ptr @str.940, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7604,24 +7616,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.937, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.941, 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.938, 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 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.940, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.944, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.941, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [16 x float] }, ptr %alloca, align 4 @@ -7656,7 +7668,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.942, i64 4 }, { ptr, i64 } { ptr @str.943, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.946, i64 4 }, { ptr, i64 } { ptr @str.947, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7675,24 +7687,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.944, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.948, 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.945, 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 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.948, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.952, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.949, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { float, float }, ptr %alloca, align 4 @@ -7735,7 +7747,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.950, i64 5 }, { ptr, i64 } { ptr @str.951, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.954, i64 5 }, { ptr, i64 } { ptr @str.955, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7754,24 +7766,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.952, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.956, 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.953, 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 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.956, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.960, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, i32 }, ptr %alloca, align 4 @@ -7812,7 +7824,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.958, i64 7 }, { ptr, i64 } { ptr @str.959, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.962, i64 7 }, { ptr, i64 } { ptr @str.963, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7831,24 +7843,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.960, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.964, 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.961, 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 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.964, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.968, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.965, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -7889,7 +7901,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.966, i64 17 }, { ptr, i64 } { ptr @str.967, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.970, i64 17 }, { ptr, i64 } { ptr @str.971, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7908,24 +7920,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.968, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.972, 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.969, 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 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.972, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.976, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -7966,7 +7978,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.974, i64 8 }, { ptr, i64 } { ptr @str.975, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.978, i64 8 }, { ptr, i64 } { ptr @str.979, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -7985,24 +7997,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.976, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.980, 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.977, 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 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.980, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.984, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.985, 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 @@ -8043,7 +8055,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.982, i64 18 }, { ptr, i64 } { ptr @str.983, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.986, i64 18 }, { ptr, i64 } { ptr @str.987, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -8062,24 +8074,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.984, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.988, 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.985, 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.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.987, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.991, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.988, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr }, ptr %alloca, align 8 @@ -8113,7 +8125,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.989, i64 13 }, { ptr, i64 } { ptr @str.990, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.993, i64 13 }, { ptr, i64 } { ptr @str.994, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -8132,24 +8144,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.991, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.995, 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.992, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.996, 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.994, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.998, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.999, 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 @@ -8183,7 +8195,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.996, i64 5 }, { ptr, i64 } { ptr @str.997, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1000, i64 5 }, { ptr, i64 } { ptr @str.1001, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -8202,24 +8214,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.998, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1002, 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.999, 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.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.1003, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.1007, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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.1008, 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 @@ -8267,7 +8279,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.1005, i64 11 }, { ptr, i64 } { ptr @str.1006, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1009, i64 11 }, { ptr, i64 } { ptr @str.1010, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -8286,24 +8298,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.1007, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1011, 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.1008, 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.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.1010, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.1014, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1011, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32 }, ptr %alloca, align 4 @@ -8341,9 +8353,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.1017, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.1021, 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.1012, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1016, 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 @@ -8362,8 +8374,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.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 } { ptr @str.1023, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1022, 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 @@ -8382,9 +8394,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.1024, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.1028, 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.1020, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1024, 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 @@ -8403,8 +8415,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.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 } { ptr @str.1030, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1029, 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 @@ -8434,9 +8446,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.1034, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.1038, 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.1027, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1031, 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 @@ -8453,8 +8465,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.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 } { ptr @str.1040, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1039, 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 @@ -8532,9 +8544,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.1045, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.1049, 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.1037, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1041, 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 @@ -8553,8 +8565,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.320 @@ -8573,9 +8585,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.1054, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.1058, 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.1048, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1052, 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 @@ -8594,8 +8606,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.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 } { ptr @str.1060, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1059, 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 @@ -8612,7 +8624,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.1057, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1061, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.332 @@ -8629,12 +8641,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.1058, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1062, 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.1059, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1063, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.336 @@ -8663,7 +8675,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.1060, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1064, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.337 @@ -8680,12 +8692,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.1061, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1065, 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.1062, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1066, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.341 @@ -8715,7 +8727,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.1063, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1067, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.342 @@ -8732,12 +8744,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.1064, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1068, 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.1065, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1069, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.346 @@ -8765,7 +8777,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.1066, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1070, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.347 @@ -8782,12 +8794,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.1067, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1071, 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.1068, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1072, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.351 @@ -8816,7 +8828,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.1069, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1073, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.352 @@ -8833,12 +8845,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.1070, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1074, 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.1071, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1075, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.356 @@ -8866,7 +8878,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.1072, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1076, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.357 @@ -8883,12 +8895,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.1073, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1077, 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.1074, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1078, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.361 @@ -8919,7 +8931,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.1075, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1079, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.362 @@ -8936,12 +8948,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.1076, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1080, 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.1077, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1081, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.366 @@ -8971,7 +8983,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.1078, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1082, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.374 @@ -8990,12 +9002,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.1079, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1083, 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.1080, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1084, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.378 @@ -9024,7 +9036,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.1081, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1085, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.379 @@ -9043,12 +9055,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.1082, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1086, 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.1083, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1087, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.383 @@ -9077,7 +9089,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.1084, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1088, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.384 @@ -9096,12 +9108,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.1085, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1089, 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.1086, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1090, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.388 @@ -9131,7 +9143,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.1087, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1091, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.389 @@ -9150,12 +9162,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.1088, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1092, 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.1089, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1093, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.393 @@ -9185,7 +9197,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.1090, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.1094, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.394 @@ -9204,12 +9216,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.1091, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1095, 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.1092, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.1096, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.398 @@ -9251,12 +9263,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.1095, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1094, 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.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.1093, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.1097, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -9279,12 +9291,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.1098, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1097, i64 11 }, { 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 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.1096, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] + %bp = phi { ptr, i64 } [ { ptr @str.1100, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] ret { ptr, i64 } %bp } @@ -9307,12 +9319,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.1101, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1100, i64 4 }, { 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 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.1099, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] + %bp = phi { ptr, i64 } [ { ptr @str.1103, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] ret { ptr, i64 } %bp } @@ -9335,12 +9347,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.1104, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1103, i64 11 }, { 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 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.1102, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] + %bp = phi { ptr, i64 } [ { ptr @str.1106, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] ret { ptr, i64 } %bp } @@ -9363,12 +9375,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.1107, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1106, i64 6 }, { 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 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.1105, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] + %bp = phi { ptr, i64 } [ { ptr @str.1109, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] ret { ptr, i64 } %bp } @@ -9390,12 +9402,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.1110, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1109, i64 5 }, { 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 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.1108, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] + %bp = phi { ptr, i64 } [ { ptr @str.1112, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] ret { ptr, i64 } %bp } @@ -9418,12 +9430,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.1113, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1112, i64 9 }, { 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 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.1111, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] + %bp = phi { ptr, i64 } [ { ptr @str.1115, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] ret { ptr, i64 } %bp } @@ -9446,12 +9458,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.1116, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1115, i64 18 }, { 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 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.1114, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] + %bp = phi { ptr, i64 } [ { ptr @str.1118, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] ret { ptr, i64 } %bp } @@ -9474,12 +9486,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.1119, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1118, i64 5 }, { 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 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.1117, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] + %bp = phi { ptr, i64 } [ { ptr @str.1121, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] ret { ptr, i64 } %bp } @@ -9502,12 +9514,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.1122, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1121, i64 3 }, { 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 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.1120, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] + %bp = phi { ptr, i64 } [ { ptr @str.1124, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] ret { ptr, i64 } %bp } @@ -9530,12 +9542,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.1125, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1124, i64 4 }, { 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 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.1123, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] + %bp = phi { ptr, i64 } [ { ptr @str.1127, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] ret { ptr, i64 } %bp } @@ -9558,12 +9570,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.1128, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1127, i64 9 }, { 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 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.1126, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] + %bp = phi { ptr, i64 } [ { ptr @str.1130, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] ret { ptr, i64 } %bp } @@ -9586,12 +9598,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.1131, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1130, i64 4 }, { ptr, i64 } %callN) + %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 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.1129, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] + %bp = phi { ptr, i64 } [ { ptr @str.1133, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] ret { ptr, i64 } %bp } @@ -9613,12 +9625,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.1134, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1133, i64 8 }, { ptr, i64 } %callN) + %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 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.1132, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] + %bp = phi { ptr, i64 } [ { ptr @str.1136, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] ret { ptr, i64 } %bp } @@ -9641,12 +9653,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.1137, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1136, i64 6 }, { ptr, i64 } %callN) + %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 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.1135, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] + %bp = phi { ptr, i64 } [ { ptr @str.1139, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] ret { ptr, i64 } %bp } @@ -9668,12 +9680,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.1140, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1139, i64 9 }, { ptr, i64 } %callN) + %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 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.1138, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] + %bp = phi { ptr, i64 } [ { ptr @str.1142, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] ret { ptr, i64 } %bp } @@ -9696,12 +9708,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.1143, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1142, i64 7 }, { ptr, i64 } %callN) + %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 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.1141, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] + %bp = phi { ptr, i64 } [ { ptr @str.1145, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] ret { ptr, i64 } %bp } @@ -9724,12 +9736,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.1146, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1145, i64 5 }, { ptr, i64 } %callN) + %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 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.1144, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] + %bp = phi { ptr, i64 } [ { ptr @str.1148, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] ret { ptr, i64 } %bp } @@ -9752,12 +9764,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.1149, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1148, i64 7 }, { ptr, i64 } %callN) + %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 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.1147, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] + %bp = phi { ptr, i64 } [ { ptr @str.1151, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] ret { ptr, i64 } %bp } @@ -9780,12 +9792,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.1152, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1151, i64 4 }, { ptr, i64 } %callN) + %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 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.1150, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] + %bp = phi { ptr, i64 } [ { ptr @str.1154, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] ret { ptr, i64 } %bp } @@ -9808,12 +9820,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.1155, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1154, i64 7 }, { ptr, i64 } %callN) + %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 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.1153, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] + %bp = phi { ptr, i64 } [ { ptr @str.1157, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] ret { ptr, i64 } %bp } @@ -9836,12 +9848,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.1158, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1157, i64 5 }, { ptr, i64 } %callN) + %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 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.1156, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] + %bp = phi { ptr, i64 } [ { ptr @str.1160, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] ret { ptr, i64 } %bp } @@ -9864,12 +9876,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.1161, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1160, i64 7 }, { ptr, i64 } %callN) + %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 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.1159, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] + %bp = phi { ptr, i64 } [ { ptr @str.1163, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] ret { ptr, i64 } %bp } @@ -9892,12 +9904,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.1164, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1163, i64 14 }, { ptr, i64 } %callN) + %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 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.1162, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] + %bp = phi { ptr, i64 } [ { ptr @str.1166, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] ret { ptr, i64 } %bp } @@ -9920,12 +9932,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.1167, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1166, i64 6 }, { ptr, i64 } %callN) + %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) br label %if.merge.526 if.merge.526: ; preds = %if.else.525, %if.then.524 - %bp = phi { ptr, i64 } [ { ptr @str.1165, i64 4 }, %if.then.524 ], [ %callN, %if.else.525 ] + %bp = phi { ptr, i64 } [ { ptr @str.1169, i64 4 }, %if.then.524 ], [ %callN, %if.else.525 ] ret { ptr, i64 } %bp } @@ -9948,12 +9960,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.1170, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1169, i64 12 }, { ptr, i64 } %callN) + %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 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.1168, i64 4 }, %if.then.527 ], [ %callN, %if.else.528 ] + %bp = phi { ptr, i64 } [ { ptr @str.1172, i64 4 }, %if.then.527 ], [ %callN, %if.else.528 ] ret { ptr, i64 } %bp } @@ -9976,12 +9988,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.1173, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1172, i64 12 }, { ptr, i64 } %callN) + %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 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.1171, i64 4 }, %if.then.530 ], [ %callN, %if.else.531 ] + %bp = phi { ptr, i64 } [ { ptr @str.1175, i64 4 }, %if.then.530 ], [ %callN, %if.else.531 ] ret { ptr, i64 } %bp } @@ -10004,12 +10016,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.1176, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1175, i64 6 }, { ptr, i64 } %callN) + %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) br label %if.merge.535 if.merge.535: ; preds = %if.else.534, %if.then.533 - %bp = phi { ptr, i64 } [ { ptr @str.1174, i64 4 }, %if.then.533 ], [ %callN, %if.else.534 ] + %bp = phi { ptr, i64 } [ { ptr @str.1178, i64 4 }, %if.then.533 ], [ %callN, %if.else.534 ] ret { ptr, i64 } %bp } @@ -10032,12 +10044,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.1179, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1178, i64 7 }, { ptr, i64 } %callN) + %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 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.1177, i64 4 }, %if.then.536 ], [ %callN, %if.else.537 ] + %bp = phi { ptr, i64 } [ { ptr @str.1181, i64 4 }, %if.then.536 ], [ %callN, %if.else.537 ] ret { ptr, i64 } %bp } @@ -10060,12 +10072,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.1182, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1181, i64 4 }, { ptr, i64 } %callN) + %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 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.1180, i64 4 }, %if.then.539 ], [ %callN, %if.else.540 ] + %bp = phi { ptr, i64 } [ { ptr @str.1184, i64 4 }, %if.then.539 ], [ %callN, %if.else.540 ] ret { ptr, i64 } %bp } @@ -10088,12 +10100,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.1185, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1184, i64 6 }, { ptr, i64 } %callN) + %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 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.1183, i64 4 }, %if.then.542 ], [ %callN, %if.else.543 ] + %bp = phi { ptr, i64 } [ { ptr @str.1187, i64 4 }, %if.then.542 ], [ %callN, %if.else.543 ] ret { ptr, i64 } %bp } @@ -10116,12 +10128,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.1188, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1187, i64 5 }, { ptr, i64 } %callN) + %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 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.1186, i64 4 }, %if.then.545 ], [ %callN, %if.else.546 ] + %bp = phi { ptr, i64 } [ { ptr @str.1190, i64 4 }, %if.then.545 ], [ %callN, %if.else.546 ] ret { ptr, i64 } %bp } @@ -10144,12 +10156,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.1191, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1190, i64 8 }, { ptr, i64 } %callN) + %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 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.1189, i64 4 }, %if.then.548 ], [ %callN, %if.else.549 ] + %bp = phi { ptr, i64 } [ { ptr @str.1193, i64 4 }, %if.then.548 ], [ %callN, %if.else.549 ] ret { ptr, i64 } %bp } @@ -10172,12 +10184,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.1194, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1193, i64 15 }, { ptr, i64 } %callN) + %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 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.1192, i64 4 }, %if.then.551 ], [ %callN, %if.else.552 ] + %bp = phi { ptr, i64 } [ { ptr @str.1196, i64 4 }, %if.then.551 ], [ %callN, %if.else.552 ] ret { ptr, i64 } %bp } @@ -10200,12 +10212,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.1197, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1196, i64 18 }, { ptr, i64 } %callN) + %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 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.1195, i64 4 }, %if.then.554 ], [ %callN, %if.else.555 ] + %bp = phi { ptr, i64 } [ { ptr @str.1199, i64 4 }, %if.then.554 ], [ %callN, %if.else.555 ] ret { ptr, i64 } %bp } @@ -10228,12 +10240,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.1200, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1199, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1204, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1203, 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.1198, i64 4 }, %if.then.557 ], [ %callN, %if.else.558 ] + %bp = phi { ptr, i64 } [ { ptr @str.1202, i64 4 }, %if.then.557 ], [ %callN, %if.else.558 ] ret { ptr, i64 } %bp } @@ -10256,12 +10268,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.1203, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1202, i64 6 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1207, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1206, 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.1201, i64 4 }, %if.then.560 ], [ %callN, %if.else.561 ] + %bp = phi { ptr, i64 } [ { ptr @str.1205, i64 4 }, %if.then.560 ], [ %callN, %if.else.561 ] ret { ptr, i64 } %bp } @@ -10284,12 +10296,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.1206, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1205, i64 13 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1210, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.1209, 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.1204, i64 4 }, %if.then.563 ], [ %callN, %if.else.564 ] + %bp = phi { ptr, i64 } [ { ptr @str.1208, i64 4 }, %if.then.563 ], [ %callN, %if.else.564 ] ret { ptr, i64 } %bp } @@ -10305,7 +10317,7 @@ entry: br i1 %lnot, label %if.then.572, label %if.merge.573 if.then.572: ; preds = %entry - ret { ptr, i64 } { ptr @str.1207, i64 4 } + ret { ptr, i64 } { ptr @str.1211, i64 4 } if.merge.573: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -10329,7 +10341,7 @@ entry: br i1 %lnot, label %if.then.574, label %if.merge.575 if.then.574: ; preds = %entry - ret { ptr, i64 } { ptr @str.1208, i64 4 } + ret { ptr, i64 } { ptr @str.1212, i64 4 } if.merge.575: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -10353,7 +10365,7 @@ entry: br i1 %lnot, label %if.then.576, label %if.merge.577 if.then.576: ; preds = %entry - ret { ptr, i64 } { ptr @str.1209, i64 4 } + ret { ptr, i64 } { ptr @str.1213, i64 4 } if.merge.577: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -10377,7 +10389,7 @@ entry: br i1 %lnot, label %if.then.578, label %if.merge.579 if.then.578: ; preds = %entry - ret { ptr, i64 } { ptr @str.1210, i64 4 } + ret { ptr, i64 } { ptr @str.1214, 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 f8be76a..516e742 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [13 x i8] c"**CAllocator\00" +@tn.str.241 = private constant [7 x i8] c"**void\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"*[]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"[3]Any\00" +@tn.str.248 = private constant [8 x i8] c"*[3]Any\00" +@tn.str.249 = private constant [8 x i8] c"*string\00" +@tn.str.250 = private constant [6 x i8] c"*bool\00" +@tn.str.251 = private constant [7 x i8] c"[2]Any\00" +@tn.str.252 = private constant [8 x i8] c"*[2]Any\00" +@tn.str.253 = private constant [7 x i8] c"[5]Any\00" +@tn.str.254 = private constant [8 x i8] c"*[5]Any\00" +@tn.str.255 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.256 = private constant [5 x i8] c"*f64\00" +@tn.str.257 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.258 = private constant [11 x i8] c"*Allocator\00" +@tn.str.259 = private constant [9 x i8] c"*Context\00" +@tn.str.260 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.261 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.262 = private constant [8 x i8] c"*Member\00" +@tn.str.263 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.264 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.265 = private constant [9 x i8] c"*Command\00" +@tn.str.266 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.267 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.268 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.269 = private constant [7 x i8] c"*Value\00" +@tn.str.270 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.271 = private constant [14 x i8] c"*Architecture\00" +@tn.str.272 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.273 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.274 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.275 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.276 = private constant [10 x i8] c"*[]string\00" +@tn.str.277 = private constant [6 x i8] c"*[]u8\00" +@tn.str.278 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.279 = private constant [11 x i8] c"*[]Command\00" +@tn.str.280 = private constant [6 x i8] c"**GPA\00" +@tn.str.281 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.282 = private constant [8 x i8] c"**Arena\00" +@tn.str.283 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.284 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.285 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.286 = private constant [7 x i8] c"**File\00" +@tn.str.287 = private constant [5 x i8] c"**u8\00" +@tn.str.288 = private constant [6 x i8] c"**s32\00" +@tn.str.289 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.290 = private constant [6 x i8] c"**u32\00" +@tn.str.291 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.292 = private constant [8 x i8] c"**Array\00" +@tn.str.293 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.294 = private constant [9 x i8] c"**Object\00" +@tn.str.295 = private constant [7 x i8] c"**Sink\00" +@tn.str.296 = private constant [9 x i8] c"**Parser\00" +@tn.str.297 = private constant [6 x i8] c"**s64\00" +@tn.str.298 = private constant [9 x i8] c"**Parsed\00" +@tn.str.299 = private constant [7 x i8] c"**Diag\00" +@tn.str.300 = private constant [9 x i8] c"**Sha256\00" +@tn.str.301 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.302 = private constant [8 x i8] c"***void\00" +@tn.str.303 = private constant [6 x i8] c"**Any\00" +@tn.str.304 = private constant [8 x i8] c"**[]Any\00" +@tn.str.305 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.306 = private constant [9 x i8] c"**[3]Any\00" +@tn.str.307 = private constant [9 x i8] c"**string\00" +@tn.str.308 = private constant [7 x i8] c"**bool\00" +@tn.str.309 = private constant [9 x i8] c"**[2]Any\00" +@tn.str.310 = private constant [9 x i8] c"**[5]Any\00" +@tn.str.311 = private constant [7 x i8] c"*?File\00" +@tn.str.312 = private constant [9 x i8] c"*?string\00" +@tn.str.313 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.314 = 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.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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 12 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { 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 6 }, { ptr, i64 } { ptr @tn.str.246, i64 7 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.251, i64 6 }, { 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 7 }, { ptr, i64 } { ptr @tn.str.256, i64 4 }, { ptr, i64 } { ptr @tn.str.257, i64 16 }, { ptr, i64 } { ptr @tn.str.258, i64 10 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 11 }, { ptr, i64 } { ptr @tn.str.261, i64 14 }, { ptr, i64 } { ptr @tn.str.262, i64 7 }, { ptr, i64 } { ptr @tn.str.263, i64 13 }, { ptr, i64 } { ptr @tn.str.264, i64 9 }, { ptr, i64 } { ptr @tn.str.265, i64 8 }, { ptr, i64 } { ptr @tn.str.266, i64 10 }, { ptr, i64 } { ptr @tn.str.267, i64 9 }, { ptr, i64 } { ptr @tn.str.268, i64 9 }, { ptr, i64 } { ptr @tn.str.269, i64 6 }, { ptr, i64 } { ptr @tn.str.270, i64 16 }, { ptr, i64 } { ptr @tn.str.271, i64 13 }, { ptr, i64 } { ptr @tn.str.272, i64 14 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.278, i64 11 }, { ptr, i64 } { ptr @tn.str.279, i64 10 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 12 }, { ptr, i64 } { ptr @tn.str.282, i64 7 }, { ptr, i64 } { ptr @tn.str.283, i64 6 }, { ptr, i64 } { ptr @tn.str.284, i64 10 }, { ptr, i64 } { ptr @tn.str.285, i64 19 }, { ptr, i64 } { ptr @tn.str.286, i64 6 }, { ptr, i64 } { ptr @tn.str.287, i64 4 }, { ptr, i64 } { ptr @tn.str.288, i64 5 }, { ptr, i64 } { ptr @tn.str.289, i64 10 }, { ptr, i64 } { ptr @tn.str.290, i64 5 }, { ptr, i64 } { ptr @tn.str.291, i64 9 }, { ptr, i64 } { ptr @tn.str.292, i64 7 }, { ptr, i64 } { ptr @tn.str.293, i64 10 }, { 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 5 }, { 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 13 }, { ptr, i64 } { ptr @tn.str.302, i64 7 }, { ptr, i64 } { ptr @tn.str.303, i64 5 }, { ptr, i64 } { ptr @tn.str.304, i64 7 }, { ptr, i64 } { ptr @tn.str.305, i64 8 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { 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 8 }, { ptr, i64 } { ptr @tn.str.311, i64 6 }, { ptr, i64 } { ptr @tn.str.312, i64 8 }, { ptr, i64 } { ptr @tn.str.313, i64 15 }, { ptr, i64 } { ptr @tn.str.314, i64 8 }] @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 [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 [1 x i8] zeroinitializer, align 1 +@str.319 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.320 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.321 = private unnamed_addr constant [15 x i8] c"result := \22\22; \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 [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.326 = private unnamed_addr constant [6 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 [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.331 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.332 = private unnamed_addr constant [5 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 [2 x i8] c"x\00", 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 +@str.338 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.339 = private unnamed_addr constant [16 x i8] c"{} {} {} {} {}\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 [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 }] +@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 [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.362 = private constant [5 x i8] c"data\00" +@field_names.363 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.361, i64 9 }, { ptr, i64 } { ptr @fld.str.362, i64 4 }] +@str.364 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.365 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.369 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.370 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.371 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.376 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.375, i64 11 }] +@str.377 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.378 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.383 = private constant [4 x i8] c"cap\00" +@field_names.384 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.382, i64 4 }, { 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.391 = private constant [10 x i8] c"end_index\00" +@fld.str.392 = private constant [7 x i8] c"parent\00" +@field_names.393 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.390, i64 5 }, { ptr, i64 } { ptr @fld.str.391, i64 9 }, { ptr, i64 } { ptr @fld.str.392, i64 6 }] +@str.394 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.395 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.400 = private constant [4 x i8] c"len\00" +@fld.str.401 = private constant [4 x i8] c"pos\00" +@field_names.402 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.399, i64 3 }, { ptr, i64 } { ptr @fld.str.400, i64 3 }, { ptr, i64 } { ptr @fld.str.401, i64 3 }] @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.404 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.408 = private constant [7 x i8] c"parent\00" +@fld.str.409 = private constant [12 x i8] c"alloc_count\00" +@fld.str.410 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.411 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.412 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.408, i64 6 }, { ptr, i64 } { ptr @fld.str.409, i64 11 }, { ptr, i64 } { ptr @fld.str.410, i64 13 }, { ptr, i64 } { ptr @fld.str.411, i64 17 }] +@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 [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 [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 [3 x i8] c", \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"*void\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"*CAllocator\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 [5 x i8] c"*GPA\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 [12 x i8] c"*ArenaChunk\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 [7 x i8] c"*Arena\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"[*]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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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 [6 x i8] c"*File\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 [4 x i8] c"*u8\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"*s32\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"*SockAddr\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 [5 x i8] c"*u32\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 [9 x i8] c"[*]Value\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 [7 x i8] c"*Array\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 [10 x i8] c"[*]Member\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"*Object\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"*Sink\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"*Parser\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"*s64\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"*Parsed\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 [6 x i8] c"*Diag\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"*Sha256\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 [13 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 [7 x i8] c"**void\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 [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 [8 x i8] c"*[1]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 [8 x i8] c"*[3]Any\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"*string\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"*bool\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"*[2]Any\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 [8 x i8] c"*[5]Any\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 [5 x i8] c"null\00", align 1 +@str.746 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.747 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -640,85 +640,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -861,7 +783,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -988,7 +910,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1322,7 +1244,7 @@ entry: br i1 %icmp, label %if.then.389, label %if.merge.390 if.then.389: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.390: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1472,7 +1394,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1499,12 +1421,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1529,7 +1451,7 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 @@ -1538,19 +1460,19 @@ entry: i64 100, label %match.arm.47 i64 104, label %match.arm.47 i64 106, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 95, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1588,7 +1510,7 @@ match.merge.37: ; preds = %dispatch.merge.498, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1633,12 +1555,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1689,7 +1611,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.264 [ - i64 35, label %dispatch.case.265 + i64 22, label %dispatch.case.265 i64 81, label %dispatch.case.266 i64 87, label %dispatch.case.267 i64 88, label %dispatch.case.268 @@ -1705,7 +1627,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.320 [ - i64 36, label %dispatch.case.321 + i64 23, label %dispatch.case.321 i64 60, label %dispatch.case.322 i64 77, label %dispatch.case.323 i64 85, label %dispatch.case.324 @@ -1718,13 +1640,13 @@ 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 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 - i64 33, label %dispatch.case.360 + i64 25, label %dispatch.case.354 + i64 27, label %dispatch.case.355 + i64 29, label %dispatch.case.356 + i64 31, label %dispatch.case.357 + i64 32, label %dispatch.case.358 + i64 34, label %dispatch.case.359 + i64 36, label %dispatch.case.360 i64 40, label %dispatch.case.361 i64 44, label %dispatch.case.362 i64 47, label %dispatch.case.363 @@ -1820,7 +1742,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.313, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1842,56 +1764,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2029,7 +1951,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.314, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.316, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.246 dispatch.case.248: ; preds = %match.arm.44 @@ -2070,7 +1992,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.315, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.317, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.263 dispatch.case.265: ; preds = %match.arm.47 @@ -2151,7 +2073,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.316, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.318, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.319 dispatch.case.321: ; preds = %match.arm.48 @@ -2200,7 +2122,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.317, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.319, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.351 dispatch.case.353: ; preds = %match.arm.49 @@ -2440,7 +2362,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.318, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.320, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.498 dispatch.case.500: ; preds = %match.arm.50 @@ -2482,7 +2404,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.319, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.321, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2578,7 +2500,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.320, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.322, 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 @@ -2586,7 +2508,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.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 @@ -2596,13 +2518,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.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 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.323, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.325, 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 @@ -2610,7 +2532,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.324, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.326, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2624,7 +2546,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.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 @@ -2632,7 +2554,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.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 i64, ptr %allocaN, align 8 @@ -2643,7 +2565,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.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 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2700,7 +2622,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.328, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, 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 @@ -2708,7 +2630,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.329, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, 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 @@ -2719,7 +2641,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.330, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2739,7 +2661,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.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 @@ -2747,7 +2669,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.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 { ptr, i64 }, ptr %alloca, align 8 @@ -2758,7 +2680,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.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 br label %if.merge.36 @@ -2768,67 +2690,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3004,166 +3010,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3361,64 +3367,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3448,97 +3454,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3577,7 +3583,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -3594,7 +3600,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.334, i64 1 }, i1 true) + %callN = call i64 @count__pack_string_bool(ptr @__sx_default_context, { ptr, i64 } { ptr @str.336, i64 1 }, i1 true) %allocaN = alloca i64, align 8 store i64 %callN, ptr %allocaN, align 8 %load = load i64, ptr %alloca, align 8 @@ -3714,7 +3720,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.335, i64 15 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.337, i64 15 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3753,7 +3759,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.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 i64, ptr %allocaN, align 8 %ba.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %loadN, 1 @@ -3819,7 +3825,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 15 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.339, i64 15 }) ret { ptr, i64 } %call } @@ -3830,7 +3836,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 @@ -3849,12 +3855,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.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.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.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.125 @@ -3866,7 +3872,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.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 @@ -3923,7 +3929,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.346, i64 9 }, { ptr, i64 } { ptr @str.347, i64 1 }) + %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 @@ -3942,24 +3948,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.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.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.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.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 [3 x { ptr, i64 }], ptr @field_names.353, 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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -4003,20 +4009,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.355, i64 10 }, { ptr, i64 } { ptr @str.356, i64 1 }) + %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.357, i64 7 }, { 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.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, 2 br i1 %icmp, label %while.body.132, label %while.exit.133 while.body.132: ; preds = %while.hdr.131 @@ -4026,24 +4033,102 @@ 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.357, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, 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 }) + %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.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.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.360, 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 { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 + +fv.default: ; preds = %if.merge.135 + br label %fv.merge + +fv.case: ; preds = %if.merge.135 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.135 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.365, i64 10 }, { 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.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.367, 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.368, 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.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 {}, ptr %alloca, align 1 @@ -4054,7 +4139,7 @@ if.merge.135: ; preds = %if.then.134, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 + br label %while.hdr.136 } ; Function Attrs: nounwind @@ -4062,43 +4147,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.371, i64 3 }, { 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.136 + br label %while.hdr.141 -while.hdr.136: ; preds = %fv.merge, %entry +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.137, label %while.exit.138 + br i1 %icmp, label %while.body.142, label %while.exit.143 -while.body.137: ; preds = %while.hdr.136 +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.139, label %if.merge.140 + br i1 %icmpN, label %if.then.144, label %if.merge.145 -while.exit.138: ; preds = %while.hdr.136 +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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 1 }) ret { ptr, i64 } %callN -if.then.139: ; preds = %while.body.137 +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 }) + %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.140 + br label %if.merge.145 -if.merge.140: ; preds = %if.then.139, %while.body.137 +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.366, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.367, 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 { i64 }, ptr %alloca, align 8 @@ -4115,12 +4200,12 @@ 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 + br label %while.hdr.141 -fv.default: ; preds = %if.merge.140 +fv.default: ; preds = %if.merge.145 br label %fv.merge -fv.case: ; preds = %if.merge.140 +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 @@ -4131,43 +4216,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 10 }, { 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.141 + br label %while.hdr.146 -while.hdr.141: ; preds = %fv.merge, %entry +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.142, label %while.exit.143 + br i1 %icmp, label %while.body.147, label %while.exit.148 -while.body.142: ; preds = %while.hdr.141 +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.144, label %if.merge.145 + br i1 %icmpN, label %if.then.149, label %if.merge.150 -while.exit.143: ; preds = %while.hdr.141 +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.380, i64 1 }) ret { ptr, i64 } %callN -if.then.144: ; preds = %while.body.142 +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.381, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 + br label %if.merge.150 -if.merge.145: ; preds = %if.then.144, %while.body.142 +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.374, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.384, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.385, 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 @@ -4185,18 +4270,18 @@ 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.141 + br label %while.hdr.146 -fv.default: ; preds = %if.merge.145 +fv.default: ; preds = %if.merge.150 br label %fv.merge -fv.case: ; preds = %if.merge.145 +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 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.145 +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 @@ -4208,91 +4293,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 }) - %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.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.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.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.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 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.146 - -fv.default: ; preds = %if.merge.150 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.150 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 8 }, { ptr, i64 } { ptr @str.386, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.386, i64 5 }, { ptr, i64 } { ptr @str.387, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4311,27 +4312,27 @@ 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.387, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, 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.388, 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 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.392, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.393, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.394, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4353,29 +4354,30 @@ fv.default: ; preds = %if.merge.155 br label %fv.merge fv.case: ; preds = %if.merge.155 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.155 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.155 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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 }) + %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.395, i64 8 }, { ptr, i64 } { ptr @str.396, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4384,7 +4386,7 @@ entry: while.hdr.156: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.157, label %while.exit.158 while.body.157: ; preds = %while.hdr.156 @@ -4394,19 +4396,19 @@ 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.396, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, 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.397, 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 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.402, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4414,17 +4416,16 @@ if.merge.160: ; preds = %if.then.159, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4437,35 +4438,29 @@ fv.default: ; preds = %if.merge.160 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.160 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.160 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.404, i64 17 }, { 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 @@ -4474,7 +4469,7 @@ entry: while.hdr.161: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.162, label %while.exit.163 while.body.162: ; preds = %while.hdr.161 @@ -4496,23 +4491,25 @@ if.then.164: ; preds = %while.body.162 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.410, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4525,16 +4522,25 @@ fv.default: ; preds = %if.merge.165 br label %fv.merge fv.case: ; preds = %if.merge.165 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.165 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.165 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4543,7 +4549,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 @@ -4562,24 +4568,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.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.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.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.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.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 @@ -4616,7 +4622,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 @@ -4635,24 +4641,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.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.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.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.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.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 @@ -4718,7 +4724,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 @@ -4737,24 +4743,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.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.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.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.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.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 @@ -4796,7 +4802,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 @@ -4815,24 +4821,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.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.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.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.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.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 @@ -4893,7 +4899,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 @@ -4912,24 +4918,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.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.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.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.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.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 @@ -4975,7 +4981,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 @@ -4994,24 +5000,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.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.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.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.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.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 @@ -5059,7 +5065,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 @@ -5078,24 +5084,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.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.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.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.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.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 @@ -5139,7 +5145,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 @@ -5158,24 +5164,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.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.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.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.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.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 @@ -5225,7 +5231,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 @@ -5244,24 +5250,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.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.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.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.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.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 @@ -5310,7 +5316,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 @@ -5329,24 +5335,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.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.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.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.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.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 @@ -5366,7 +5372,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 @@ -5385,24 +5391,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.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.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.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.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.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 @@ -5454,7 +5460,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 @@ -5473,24 +5479,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.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.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.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.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.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 @@ -5542,7 +5548,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 @@ -5561,24 +5567,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.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.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.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.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.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 @@ -5621,7 +5627,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 @@ -5640,24 +5646,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.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.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.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.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.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 @@ -5703,7 +5709,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 @@ -5722,24 +5728,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.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.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.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.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.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 @@ -5796,7 +5802,7 @@ fv.case28: ; preds = %if.merge.240 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.240 @@ -5821,7 +5827,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 @@ -5840,24 +5846,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.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.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.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.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.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 @@ -5916,9 +5922,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 @@ -5937,8 +5943,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.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.254 @@ -5957,9 +5963,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 @@ -5978,8 +5984,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.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.256 @@ -6009,9 +6015,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 @@ -6028,8 +6034,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.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.258 @@ -6107,9 +6113,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 @@ -6128,8 +6134,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.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.260 @@ -6148,9 +6154,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 @@ -6169,8 +6175,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.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.262 @@ -6187,7 +6193,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.274 @@ -6204,12 +6210,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.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.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.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.278 @@ -6238,7 +6244,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.279 @@ -6255,12 +6261,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.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.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.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.283 @@ -6290,7 +6296,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.284 @@ -6307,12 +6313,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.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.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.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.288 @@ -6340,7 +6346,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.289 @@ -6357,12 +6363,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.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.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.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.293 @@ -6391,7 +6397,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.294 @@ -6408,12 +6414,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.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.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.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.298 @@ -6442,7 +6448,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.299 @@ -6459,12 +6465,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.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.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.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.303 @@ -6495,7 +6501,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.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.304 @@ -6512,12 +6518,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.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.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.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.308 @@ -6548,7 +6554,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.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.309 @@ -6565,12 +6571,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.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.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.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.313 @@ -6601,7 +6607,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.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 @@ -6618,12 +6624,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 @@ -6653,7 +6659,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.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.326 @@ -6672,12 +6678,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.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.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.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.330 @@ -6706,7 +6712,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.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.331 @@ -6725,12 +6731,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.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.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.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.335 @@ -6759,7 +6765,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.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.336 @@ -6778,12 +6784,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.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.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.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.340 @@ -6813,7 +6819,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.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.341 @@ -6832,12 +6838,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.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.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.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.345 @@ -6867,7 +6873,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.640, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.642, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.346 @@ -6886,12 +6892,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.641, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.643, 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.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 br label %if.merge.350 @@ -6933,12 +6939,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.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.388 if.merge.388: ; preds = %if.else.387, %if.then.386 - %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.386 ], [ %callN, %if.else.387 ] + %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.386 ], [ %callN, %if.else.387 ] ret { ptr, i64 } %bp } @@ -6961,12 +6967,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.648, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.647, i64 11 }, { 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 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.646, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] + %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] ret { ptr, i64 } %bp } @@ -6989,12 +6995,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.651, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.650, i64 4 }, { 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 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.649, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] + %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] ret { ptr, i64 } %bp } @@ -7017,12 +7023,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.654, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.653, i64 11 }, { 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 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.652, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] + %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] ret { ptr, i64 } %bp } @@ -7045,12 +7051,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.657, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.656, i64 6 }, { 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 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.655, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] + %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] ret { ptr, i64 } %bp } @@ -7072,12 +7078,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.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.416 if.merge.416: ; preds = %if.else.415, %if.then.414 - %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] + %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] ret { ptr, i64 } %bp } @@ -7100,12 +7106,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.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.419 if.merge.419: ; preds = %if.else.418, %if.then.417 - %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] + %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] ret { ptr, i64 } %bp } @@ -7128,12 +7134,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.666, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, i64 18 }, { 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 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.664, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -7156,12 +7162,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.669, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, i64 5 }, { 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 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.667, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -7184,12 +7190,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.672, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.671, i64 3 }, { 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 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.670, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -7212,12 +7218,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.675, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.674, i64 4 }, { 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 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.673, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -7240,12 +7246,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.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.434 if.merge.434: ; preds = %if.else.433, %if.then.432 - %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -7268,12 +7274,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.681, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.680, i64 4 }, { 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 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.679, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -7295,12 +7301,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.684, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.683, i64 8 }, { 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 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.682, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -7323,12 +7329,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.687, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 6 }, { 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 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.685, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -7350,12 +7356,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.690, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.689, i64 9 }, { 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 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.688, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -7378,12 +7384,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.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.449 if.merge.449: ; preds = %if.else.448, %if.then.447 - %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -7406,12 +7412,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.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.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -7434,12 +7440,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.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.455 if.merge.455: ; preds = %if.else.454, %if.then.453 - %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -7462,12 +7468,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.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.458 if.merge.458: ; preds = %if.else.457, %if.then.456 - %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -7490,12 +7496,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.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.461 if.merge.461: ; preds = %if.else.460, %if.then.459 - %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -7518,12 +7524,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.708, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 5 }, { 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 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.706, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -7546,12 +7552,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.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.467 if.merge.467: ; preds = %if.else.466, %if.then.465 - %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -7574,12 +7580,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.714, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.713, i64 12 }, { 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 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.712, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -7602,12 +7608,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.717, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 6 }, { 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 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.715, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -7630,12 +7636,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.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.476 if.merge.476: ; preds = %if.else.475, %if.then.474 - %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -7658,12 +7664,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.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.479 if.merge.479: ; preds = %if.else.478, %if.then.477 - %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -7686,12 +7692,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.726, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.725, i64 7 }, { 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 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.724, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -7714,12 +7720,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.729, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.728, i64 7 }, { 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 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.727, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -7742,12 +7748,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.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.488 if.merge.488: ; preds = %if.else.487, %if.then.486 - %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] + %bp = phi { ptr, i64 } [ { ptr @str.732, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] ret { ptr, i64 } %bp } @@ -7770,12 +7776,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.735, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 5 }, { 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 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.733, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] + %bp = phi { ptr, i64 } [ { ptr @str.735, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] ret { ptr, i64 } %bp } @@ -7798,12 +7804,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.738, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 7 }, { 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 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.736, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] + %bp = phi { ptr, i64 } [ { ptr @str.738, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] ret { ptr, i64 } %bp } @@ -7826,12 +7832,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.741, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 7 }, { 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 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.739, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] + %bp = phi { ptr, i64 } [ { ptr @str.741, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] ret { ptr, i64 } %bp } @@ -7847,7 +7853,7 @@ entry: br i1 %lnot, label %if.then.504, label %if.merge.505 if.then.504: ; preds = %entry - ret { ptr, i64 } { ptr @str.742, i64 4 } + ret { ptr, i64 } { ptr @str.744, i64 4 } if.merge.505: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7871,7 +7877,7 @@ entry: br i1 %lnot, label %if.then.506, label %if.merge.507 if.then.506: ; preds = %entry - ret { ptr, i64 } { ptr @str.743, i64 4 } + ret { ptr, i64 } { ptr @str.745, i64 4 } if.merge.507: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7895,7 +7901,7 @@ entry: br i1 %lnot, label %if.then.508, label %if.merge.509 if.then.508: ; preds = %entry - ret { ptr, i64 } { ptr @str.744, i64 4 } + ret { ptr, i64 } { ptr @str.746, i64 4 } if.merge.509: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7919,7 +7925,7 @@ entry: br i1 %lnot, label %if.then.510, label %if.merge.511 if.then.510: ; preds = %entry - ret { ptr, i64 } { ptr @str.745, i64 4 } + ret { ptr, i64 } { ptr @str.747, 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 614ed45..3e78957 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [13 x i8] c"**CAllocator\00" +@tn.str.241 = private constant [7 x i8] c"**void\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"[3]Any\00" +@tn.str.245 = private constant [8 x i8] c"*[3]Any\00" +@tn.str.246 = private constant [7 x i8] c"*[]Any\00" +@tn.str.247 = private constant [8 x i8] c"*string\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 [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 [6 x i8] c"**Any\00" +@tn.str.300 = private constant [9 x i8] c"**[3]Any\00" +@tn.str.301 = private constant [8 x i8] c"**[]Any\00" +@tn.str.302 = private constant [9 x i8] c"**string\00" +@tn.str.303 = private constant [9 x i8] c"**[1]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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 12 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { 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 7 }, { ptr, i64 } { ptr @tn.str.248, i64 6 }, { ptr, i64 } { ptr @tn.str.249, i64 7 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.300, i64 8 }, { ptr, i64 } { ptr @tn.str.301, i64 7 }, { 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 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.328 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 -@str.329 = 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 [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 +@str.331 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.332 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 +@str.333 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.334 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.335 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.336 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@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 }] +@fld.str.337 = private constant [5 x i8] c"line\00" +@fld.str.338 = private constant [4 x i8] c"col\00" +@fld.str.339 = 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.337, i64 4 }, { ptr, i64 } { ptr @fld.str.338, 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 [10 x i8] c"Allocator\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 [4 x i8] c"ctx\00" +@fld.str.346 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.347 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.348 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.345, i64 3 }, { ptr, i64 } { ptr @fld.str.346, i64 11 }, { ptr, i64 } { ptr @fld.str.347, i64 13 }] +@str.349 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.350 = private unnamed_addr constant [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.355 = private constant [5 x i8] c"data\00" +@field_names.356 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.354, i64 9 }, { ptr, i64 } { ptr @fld.str.355, 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 [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 [8 x i8] c"Context\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 [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 +@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 [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.412 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.411, i64 2 }] +@str.413 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.414 = private unnamed_addr constant [11 x i8] c"TraceFrame\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 [5 x i8] c"file\00" +@fld.str.419 = private constant [5 x i8] c"line\00" +@fld.str.420 = private constant [4 x i8] c"col\00" +@fld.str.421 = private constant [5 x i8] c"func\00" +@fld.str.422 = private constant [10 x i8] c"line_text\00" +@field_names.423 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.418, i64 4 }, { ptr, i64 } { ptr @fld.str.419, i64 4 }, { ptr, i64 } { ptr @fld.str.420, i64 3 }, { ptr, i64 } { ptr @fld.str.421, i64 4 }, { ptr, i64 } { ptr @fld.str.422, i64 9 }] +@str.424 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.425 = private unnamed_addr constant [14 x i8] c"ProcessResult\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 [10 x i8] c"exit_code\00" +@fld.str.430 = private constant [7 x i8] c"stdout\00" +@field_names.431 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.429, i64 9 }, { ptr, i64 } { ptr @fld.str.430, i64 6 }] +@str.432 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.433 = private unnamed_addr constant [9 x i8] c"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.438 = private constant [11 x i8] c"sin_family\00" +@fld.str.439 = private constant [9 x i8] c"sin_port\00" +@fld.str.440 = private constant [9 x i8] c"sin_addr\00" +@fld.str.441 = private constant [9 x i8] c"sin_zero\00" +@field_names.442 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.437, i64 7 }, { ptr, i64 } { ptr @fld.str.438, i64 10 }, { ptr, i64 } { ptr @fld.str.439, i64 8 }, { ptr, i64 } { ptr @fld.str.440, i64 8 }, { ptr, i64 } { ptr @fld.str.441, i64 8 }] +@str.443 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.444 = private unnamed_addr constant [6 x i8] c"Array\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 [6 x i8] c"items\00" +@fld.str.449 = private constant [4 x i8] c"len\00" +@fld.str.450 = private constant [4 x i8] c"cap\00" +@field_names.451 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.448, i64 5 }, { ptr, i64 } { ptr @fld.str.449, i64 3 }, { ptr, i64 } { ptr @fld.str.450, i64 3 }] +@str.452 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.453 = private unnamed_addr constant [7 x i8] c"Object\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 [6 x i8] c"items\00" +@fld.str.458 = private constant [4 x i8] c"len\00" +@fld.str.459 = private constant [4 x i8] c"cap\00" +@field_names.460 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.457, i64 5 }, { ptr, i64 } { ptr @fld.str.458, i64 3 }, { ptr, i64 } { ptr @fld.str.459, i64 3 }] +@str.461 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.462 = private unnamed_addr constant [7 x i8] c"Member\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 [4 x i8] c"key\00" +@fld.str.467 = private constant [4 x i8] c"val\00" +@field_names.468 = private constant [2 x { ptr, i64 }] [{ 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 [5 x i8] c"Sink\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"dst\00" +@fld.str.475 = private constant [4 x i8] c"pos\00" +@fld.str.476 = private constant [5 x i8] c"file\00" +@field_names.477 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.474, i64 3 }, { ptr, i64 } { ptr @fld.str.475, i64 3 }, { ptr, i64 } { ptr @fld.str.476, i64 4 }] +@str.478 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.479 = private unnamed_addr constant [7 x i8] c"Parser\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"src\00" +@fld.str.484 = private constant [4 x i8] c"pos\00" +@fld.str.485 = private constant [6 x i8] c"alloc\00" +@field_names.486 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.483, i64 3 }, { ptr, i64 } { ptr @fld.str.484, i64 3 }, { ptr, i64 } { ptr @fld.str.485, i64 5 }] +@str.487 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.488 = private unnamed_addr constant [13 x i8] c"BuildOptions\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 +@field_names.492 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.493 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.494 = private unnamed_addr constant [9 x i8] c"FlagSpec\00", align 1 +@str.495 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.496 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.497 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.498 = private constant [5 x i8] c"name\00" +@fld.str.499 = private constant [12 x i8] c"takes_value\00" +@fld.str.500 = private constant [9 x i8] c"required\00" +@field_names.501 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.498, i64 4 }, { ptr, i64 } { ptr @fld.str.499, i64 11 }, { 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 [8 x i8] c"Command\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"group\00" +@fld.str.508 = private constant [8 x i8] c"command\00" +@fld.str.509 = private constant [6 x i8] c"flags\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 7 }, { ptr, i64 } { ptr @fld.str.509, i64 5 }] +@str.511 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.512 = private unnamed_addr constant [10 x i8] c"FlagValue\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 [4 x i8] c"set\00" +@fld.str.517 = private constant [6 x i8] c"value\00" +@field_names.518 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.516, i64 3 }, { 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 [5 x i8] c"Diag\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"index\00" +@fld.str.525 = private constant [6 x i8] c"token\00" +@field_names.526 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.524, i64 5 }, { 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 [7 x i8] c"Parsed\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"group\00" +@fld.str.533 = private constant [8 x i8] c"command\00" +@fld.str.534 = private constant [10 x i8] c"cmd_index\00" +@fld.str.535 = private constant [5 x i8] c"json\00" +@fld.str.536 = private constant [5 x i8] c"rest\00" +@fld.str.537 = private constant [5 x i8] c"spec\00" +@fld.str.538 = private constant [7 x i8] c"values\00" +@field_names.539 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.532, i64 5 }, { ptr, i64 } { ptr @fld.str.533, i64 7 }, { ptr, i64 } { ptr @fld.str.534, i64 9 }, { ptr, i64 } { ptr @fld.str.535, i64 4 }, { ptr, i64 } { ptr @fld.str.536, i64 4 }, { ptr, i64 } { ptr @fld.str.537, i64 4 }, { ptr, i64 } { ptr @fld.str.538, i64 6 }] +@str.540 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.541 = private unnamed_addr constant [7 x i8] c"Sha256\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 [2 x i8] c"h\00" +@fld.str.546 = private constant [4 x i8] c"buf\00" +@fld.str.547 = private constant [8 x i8] c"buf_len\00" +@fld.str.548 = private constant [10 x i8] c"total_len\00" +@field_names.549 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.545, i64 1 }, { ptr, i64 } { ptr @fld.str.546, i64 3 }, { ptr, i64 } { ptr @fld.str.547, i64 7 }, { ptr, i64 } { ptr @fld.str.548, i64 9 }] +@str.550 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.551 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.552 = private constant [5 x i8] c"read\00" +@fld.str.553 = private constant [6 x i8] c"write\00" +@fld.str.554 = private constant [7 x i8] c"append\00" +@fld.str.555 = private constant [11 x i8] c"read_write\00" +@field_names.556 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.552, i64 4 }, { ptr, i64 } { ptr @fld.str.553, i64 5 }, { ptr, i64 } { ptr @fld.str.554, i64 6 }, { ptr, i64 } { ptr @fld.str.555, i64 10 }] +@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 +@str.559 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.560 = private constant [4 x i8] c"set\00" +@fld.str.561 = private constant [8 x i8] c"current\00" +@fld.str.562 = private constant [4 x i8] c"end\00" +@field_names.563 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.560, i64 3 }, { ptr, i64 } { ptr @fld.str.561, i64 7 }, { ptr, i64 } { ptr @fld.str.562, i64 3 }] +@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 [6 x i8] c"null_\00" +@fld.str.568 = private constant [6 x i8] c"bool_\00" +@fld.str.569 = private constant [5 x i8] c"int_\00" +@fld.str.570 = private constant [4 x i8] c"str\00" +@fld.str.571 = private constant [6 x i8] c"array\00" +@fld.str.572 = private constant [7 x i8] c"object\00" +@field_names.573 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.567, i64 5 }, { ptr, i64 } { ptr @fld.str.568, i64 5 }, { ptr, i64 } { ptr @fld.str.569, i64 4 }, { ptr, i64 } { ptr @fld.str.570, i64 3 }, { ptr, i64 } { ptr @fld.str.571, i64 5 }, { ptr, i64 } { ptr @fld.str.572, i64 6 }] +@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"macos\00" +@fld.str.578 = private constant [6 x i8] c"linux\00" +@fld.str.579 = private constant [8 x i8] c"windows\00" +@fld.str.580 = private constant [5 x i8] c"wasm\00" +@fld.str.581 = private constant [4 x i8] c"ios\00" +@fld.str.582 = private constant [8 x i8] c"android\00" +@fld.str.583 = private constant [8 x i8] c"unknown\00" +@field_names.584 = private constant [7 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 7 }, { ptr, i64 } { ptr @fld.str.580, i64 4 }, { ptr, i64 } { ptr @fld.str.581, i64 3 }, { ptr, i64 } { ptr @fld.str.582, i64 7 }, { ptr, i64 } { ptr @fld.str.583, i64 7 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.588 = private constant [8 x i8] c"aarch64\00" +@fld.str.589 = private constant [7 x i8] c"x86_64\00" +@fld.str.590 = private constant [7 x i8] c"wasm32\00" +@fld.str.591 = private constant [7 x i8] c"wasm64\00" +@fld.str.592 = private constant [8 x i8] c"unknown\00" +@field_names.593 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.588, i64 7 }, { ptr, i64 } { ptr @fld.str.589, i64 6 }, { ptr, i64 } { ptr @fld.str.590, i64 6 }, { ptr, i64 } { ptr @fld.str.591, i64 6 }, { ptr, i64 } { ptr @fld.str.592, i64 7 }] +@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 [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 [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"*[3]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 [8 x i8] c"*[1]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 +@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 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -621,85 +621,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -842,7 +764,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -969,7 +891,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1303,7 +1225,7 @@ entry: br i1 %icmp, label %if.then.375, label %if.merge.376 if.then.375: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.376: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1453,7 +1375,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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,12 +1402,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1510,26 +1432,26 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 97, label %match.arm.47 i64 101, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 95, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1565,7 +1487,7 @@ match.merge.37: ; preds = %dispatch.merge.478, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1610,12 +1532,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1666,7 +1588,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.264 [ - i64 35, label %dispatch.case.265 + i64 22, label %dispatch.case.265 i64 81, label %dispatch.case.266 i64 87, label %dispatch.case.267 i64 88, label %dispatch.case.268 @@ -1680,7 +1602,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.308 [ - i64 36, label %dispatch.case.309 + i64 23, label %dispatch.case.309 i64 60, label %dispatch.case.310 i64 77, label %dispatch.case.311 i64 85, label %dispatch.case.312 @@ -1693,13 +1615,13 @@ 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 28, label %dispatch.case.345 - i64 29, label %dispatch.case.346 - i64 31, label %dispatch.case.347 - i64 33, label %dispatch.case.348 + i64 25, label %dispatch.case.342 + i64 27, label %dispatch.case.343 + i64 29, label %dispatch.case.344 + i64 31, label %dispatch.case.345 + i64 32, label %dispatch.case.346 + i64 34, label %dispatch.case.347 + i64 36, label %dispatch.case.348 i64 40, label %dispatch.case.349 i64 44, label %dispatch.case.350 i64 47, label %dispatch.case.351 @@ -1793,7 +1715,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.307, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.309, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1815,56 +1737,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2002,7 +1924,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.308, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.310, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.246 dispatch.case.248: ; preds = %match.arm.44 @@ -2043,7 +1965,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.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.263 dispatch.case.265: ; preds = %match.arm.47 @@ -2108,7 +2030,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.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.307 dispatch.case.309: ; preds = %match.arm.48 @@ -2157,7 +2079,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.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.339 dispatch.case.341: ; preds = %match.arm.49 @@ -2383,7 +2305,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.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.478 dispatch.case.480: ; preds = %match.arm.50 @@ -2425,7 +2347,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 @@ -2521,7 +2443,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.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 @@ -2529,7 +2451,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.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 @@ -2539,13 +2461,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.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.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.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 @@ -2553,7 +2475,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.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 @@ -2567,7 +2489,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.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 @@ -2575,7 +2497,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.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 @@ -2586,7 +2508,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 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 @@ -2643,7 +2565,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.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 @@ -2651,7 +2573,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.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 @@ -2662,7 +2584,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 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 @@ -2682,7 +2604,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.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 @@ -2690,7 +2612,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.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 @@ -2701,7 +2623,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 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.36 @@ -2711,67 +2633,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2947,166 +2953,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3304,64 +3310,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3391,97 +3397,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3520,7 +3526,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -3586,7 +3592,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.328, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.330, 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 @@ -3601,7 +3607,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.329, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.331, 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 @@ -3623,7 +3629,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.330, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.332, i64 3 }) ret { ptr, i64 } %call } @@ -3650,7 +3656,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.331, i64 15 }, { ptr, i64 } { ptr @str.332, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.333, i64 15 }, { ptr, i64 } { ptr @str.334, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3669,12 +3675,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.333, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, 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.334, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.125 @@ -3686,7 +3692,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.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 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3743,7 +3749,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.339, i64 9 }, { ptr, i64 } { ptr @str.340, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.341, i64 9 }, { ptr, i64 } { ptr @str.342, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3762,24 +3768,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.341, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.343, 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.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 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 [3 x { ptr, i64 }], ptr @field_names.346, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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 { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -3823,20 +3829,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.348, i64 10 }, { ptr, i64 } { ptr @str.349, i64 1 }) + %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.350, i64 7 }, { 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 = %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, 2 br i1 %icmp, label %while.body.132, label %while.exit.133 while.body.132: ; preds = %while.hdr.131 @@ -3846,24 +3853,102 @@ 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.350, i64 1 }) + %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.351, 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 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.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.353, i64 2 }) + %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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 + +fv.default: ; preds = %if.merge.135 + br label %fv.merge + +fv.case: ; preds = %if.merge.135 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.135 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.358, i64 10 }, { 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.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.360, 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.361, 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.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 %alloca, align 1 @@ -3874,7 +3959,7 @@ if.merge.135: ; preds = %if.then.134, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 + br label %while.hdr.136 } ; Function Attrs: nounwind @@ -3882,43 +3967,43 @@ 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 }) + %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.136 + br label %while.hdr.141 -while.hdr.136: ; preds = %fv.merge, %entry +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.137, label %while.exit.138 + br i1 %icmp, label %while.body.142, label %while.exit.143 -while.body.137: ; preds = %while.hdr.136 +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.139, label %if.merge.140 + br i1 %icmpN, label %if.then.144, label %if.merge.145 -while.exit.138: ; preds = %while.hdr.136 +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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, i64 1 }) ret { ptr, i64 } %callN -if.then.139: ; preds = %while.body.137 +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 }) + %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.140 + br label %if.merge.145 -if.merge.140: ; preds = %if.then.139, %while.body.137 +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.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.360, 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 %alloca, align 8 @@ -3935,12 +4020,12 @@ 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 + br label %while.hdr.141 -fv.default: ; preds = %if.merge.140 +fv.default: ; preds = %if.merge.145 br label %fv.merge -fv.case: ; preds = %if.merge.140 +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 @@ -3951,43 +4036,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %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.141 + br label %while.hdr.146 -while.hdr.141: ; preds = %fv.merge, %entry +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.142, label %while.exit.143 + br i1 %icmp, label %while.body.147, label %while.exit.148 -while.body.142: ; preds = %while.hdr.141 +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.144, label %if.merge.145 + br i1 %icmpN, label %if.then.149, label %if.merge.150 -while.exit.143: ; preds = %while.hdr.141 +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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 1 }) ret { ptr, i64 } %callN -if.then.144: ; preds = %while.body.142 +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 }) + %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.145 + br label %if.merge.150 -if.merge.145: ; preds = %if.then.144, %while.body.142 +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.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.368, 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 %alloca, align 8 @@ -4005,18 +4090,18 @@ 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.141 + br label %while.hdr.146 -fv.default: ; preds = %if.merge.145 +fv.default: ; preds = %if.merge.150 br label %fv.merge -fv.case: ; preds = %if.merge.145 +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 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.145 +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 @@ -4028,91 +4113,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.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 - 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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.146 - -fv.default: ; preds = %if.merge.150 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.150 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 8 }, { ptr, i64 } { ptr @str.379, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.379, i64 5 }, { 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 @@ -4131,27 +4132,27 @@ 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.380, 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.381, 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.385, 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.386, 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 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4173,29 +4174,30 @@ fv.default: ; preds = %if.merge.155 br label %fv.merge fv.case: ; preds = %if.merge.155 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.155 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.155 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.387, i64 17 }, { ptr, i64 } { ptr @str.388, i64 1 }) + %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 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4204,7 +4206,7 @@ entry: while.hdr.156: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.157, label %while.exit.158 while.body.157: ; preds = %while.hdr.156 @@ -4214,19 +4216,19 @@ 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.389, 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.390, 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.395, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4234,17 +4236,16 @@ if.merge.160: ; preds = %if.then.159, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4257,35 +4258,29 @@ fv.default: ; preds = %if.merge.160 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.160 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.160 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.397, i64 7 }, { ptr, i64 } { ptr @str.398, i64 1 }) + 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 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4294,7 +4289,7 @@ entry: while.hdr.161: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.162, label %while.exit.163 while.body.162: ; preds = %while.hdr.161 @@ -4316,23 +4311,25 @@ if.then.164: ; preds = %while.body.162 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.403, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4345,16 +4342,25 @@ fv.default: ; preds = %if.merge.165 br label %fv.merge fv.case: ; preds = %if.merge.165 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.165 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.165 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4363,7 +4369,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.405, i64 4 }, { ptr, i64 } { ptr @str.406, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.407, i64 4 }, { 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 @@ -4382,24 +4388,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.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.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.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.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.410, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i32 }, ptr %alloca, align 4 @@ -4436,7 +4442,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.412, i64 10 }, { ptr, i64 } { ptr @str.413, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.414, i64 10 }, { 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 @@ -4455,24 +4461,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.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.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.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.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.421, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4538,7 +4544,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.423, i64 13 }, { ptr, i64 } { ptr @str.424, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.425, i64 13 }, { 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 @@ -4557,24 +4563,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.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.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.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.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.429, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, i64 } }, ptr %alloca, align 8 @@ -4616,7 +4622,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.431, i64 8 }, { ptr, i64 } { ptr @str.432, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.433, i64 8 }, { 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 @@ -4635,24 +4641,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.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.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.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.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.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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4713,7 +4719,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.442, i64 5 }, { ptr, i64 } { ptr @str.443, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.444, i64 5 }, { 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 @@ -4732,24 +4738,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.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.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.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.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.449, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { ptr, i64, i64 }, ptr %alloca, align 8 @@ -4795,7 +4801,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.451, i64 6 }, { ptr, i64 } { ptr @str.452, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.453, i64 6 }, { 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 @@ -4814,24 +4820,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.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.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.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.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.458, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { ptr, i64, i64 }, ptr %alloca, align 8 @@ -4879,7 +4885,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.460, i64 6 }, { ptr, i64 } { ptr @str.461, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.462, i64 6 }, { 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 @@ -4898,24 +4904,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.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.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.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.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.466, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.468, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -4959,7 +4965,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.468, i64 4 }, { ptr, i64 } { ptr @str.469, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.470, i64 4 }, { ptr, i64 } { ptr @str.471, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4978,24 +4984,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.470, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.472, 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.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 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.475, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.477, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i64, ptr }, ptr %alloca, align 8 @@ -5045,7 +5051,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.477, i64 6 }, { ptr, i64 } { ptr @str.478, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.479, i64 6 }, { ptr, i64 } { ptr @str.480, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5064,24 +5070,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.479, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, 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.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 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.484, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5130,7 +5136,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.486, i64 12 }, { ptr, i64 } { ptr @str.487, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.488, i64 12 }, { 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 @@ -5149,24 +5155,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.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.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.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.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.490, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.492, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -5186,7 +5192,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.492, i64 8 }, { ptr, i64 } { ptr @str.493, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.494, i64 8 }, { ptr, i64 } { ptr @str.495, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5205,24 +5211,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.494, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, 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.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 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.499, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5274,7 +5280,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.501, i64 7 }, { ptr, i64 } { ptr @str.502, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.503, i64 7 }, { 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 @@ -5293,24 +5299,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.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.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.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.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.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 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5362,7 +5368,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.510, i64 9 }, { ptr, i64 } { ptr @str.511, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.512, i64 9 }, { 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 @@ -5381,24 +5387,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.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.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.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.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.516, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.518, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5441,7 +5447,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.518, i64 4 }, { ptr, i64 } { ptr @str.519, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.520, i64 4 }, { ptr, i64 } { ptr @str.521, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5460,24 +5466,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.520, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.522, 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.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 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.524, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5523,7 +5529,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.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 @@ -5542,24 +5548,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.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.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.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.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.537, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.539, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %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 @@ -5616,7 +5622,7 @@ fv.case28: ; preds = %if.merge.240 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.240 @@ -5641,7 +5647,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.539, i64 6 }, { ptr, i64 } { ptr @str.540, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.541, i64 6 }, { ptr, i64 } { ptr @str.542, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5660,24 +5666,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.541, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.543, 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.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 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.547, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5736,9 +5742,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.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 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.549, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.551, 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 +5763,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.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 } { ptr @str.558, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.557, 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 @@ -5777,9 +5783,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.561, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.557, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.559, 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 @@ -5798,8 +5804,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.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.256 @@ -5829,9 +5835,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.571, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 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.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, [24 x i8] }, ptr %alloca, align 8 @@ -5848,8 +5854,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.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.258 @@ -5927,9 +5933,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.582, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.584, 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, ptr %alloca, align 8 @@ -5948,8 +5954,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.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 } { ptr @str.586, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.585, 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 @@ -5968,9 +5974,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.591, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.593, 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.585, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.587, 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 @@ -5989,8 +5995,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.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 } { ptr @str.595, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.594, 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 @@ -6007,7 +6013,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.594, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.596, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.272 @@ -6024,12 +6030,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.595, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.597, 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.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 br label %if.merge.276 @@ -6058,7 +6064,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.597, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.599, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.277 @@ -6075,12 +6081,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.598, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.600, 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.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.281 @@ -6110,7 +6116,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.600, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.602, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.282 @@ -6127,12 +6133,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.601, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, 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.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 br label %if.merge.286 @@ -6160,7 +6166,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.603, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.605, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.287 @@ -6177,12 +6183,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.604, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, 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.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 br label %if.merge.291 @@ -6211,7 +6217,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.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.292 @@ -6228,12 +6234,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.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.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.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.296 @@ -6262,7 +6268,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.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.297 @@ -6279,12 +6285,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.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.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.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.301 @@ -6315,7 +6321,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.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.302 @@ -6332,12 +6338,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.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.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.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.306 @@ -6367,7 +6373,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.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.314 @@ -6386,12 +6392,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.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.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.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.318 @@ -6420,7 +6426,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.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.319 @@ -6439,12 +6445,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.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.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.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.323 @@ -6473,7 +6479,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.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.324 @@ -6492,12 +6498,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.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.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.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.328 @@ -6527,7 +6533,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.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.329 @@ -6546,12 +6552,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.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.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.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.333 @@ -6581,7 +6587,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.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.334 @@ -6600,12 +6606,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.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.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.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.338 @@ -6647,12 +6653,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.632, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.631, i64 5 }, { ptr, i64 } %callN) + %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) br label %if.merge.374 if.merge.374: ; preds = %if.else.373, %if.then.372 - %bp = phi { ptr, i64 } [ { ptr @str.630, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] + %bp = phi { ptr, i64 } [ { ptr @str.632, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] ret { ptr, i64 } %bp } @@ -6675,12 +6681,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.635, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, i64 11 }, { ptr, i64 } %callN) + %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) br label %if.merge.390 if.merge.390: ; preds = %if.else.389, %if.then.388 - %bp = phi { ptr, i64 } [ { ptr @str.633, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] + %bp = phi { ptr, i64 } [ { ptr @str.635, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] ret { ptr, i64 } %bp } @@ -6703,12 +6709,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.638, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 4 }, { ptr, i64 } %callN) + %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) br label %if.merge.393 if.merge.393: ; preds = %if.else.392, %if.then.391 - %bp = phi { ptr, i64 } [ { ptr @str.636, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] + %bp = phi { ptr, i64 } [ { ptr @str.638, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] ret { ptr, i64 } %bp } @@ -6731,12 +6737,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.641, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 11 }, { 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 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.639, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6759,12 +6765,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.644, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 6 }, { 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 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.642, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6786,12 +6792,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.647, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 5 }, { 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 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.645, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6814,12 +6820,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.650, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 9 }, { 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 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.648, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6842,12 +6848,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.653, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 18 }, { 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 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.651, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6870,12 +6876,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.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.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -6898,12 +6904,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.659, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 3 }, { 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 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.657, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -6926,12 +6932,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.662, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 4 }, { 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 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.660, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -6954,12 +6960,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.665, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 9 }, { 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 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.663, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -6982,12 +6988,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.668, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 4 }, { 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 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.666, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -7009,12 +7015,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.671, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 8 }, { 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 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.669, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7037,12 +7043,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.674, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 6 }, { 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 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.672, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7064,12 +7070,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.677, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 9 }, { 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 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.675, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7092,12 +7098,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.680, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 7 }, { 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 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.678, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7120,12 +7126,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.683, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 5 }, { 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 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.681, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7148,12 +7154,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.686, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 7 }, { 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 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.684, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7176,12 +7182,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.689, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 4 }, { 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 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.687, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7204,12 +7210,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.692, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 7 }, { 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 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.690, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7232,12 +7238,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.695, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 5 }, { 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 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.693, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7260,12 +7266,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.698, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 7 }, { 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 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.696, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7288,12 +7294,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.701, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 12 }, { 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 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.699, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7316,12 +7322,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.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.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7344,12 +7350,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.707, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 4 }, { 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 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.705, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7372,12 +7378,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.710, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.709, i64 7 }, { 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 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.708, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7400,12 +7406,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.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.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7428,12 +7434,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.716, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 7 }, { 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 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.714, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7456,12 +7462,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.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.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7484,12 +7490,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.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.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7505,7 +7511,7 @@ entry: br i1 %lnot, label %if.then.484, label %if.merge.485 if.then.484: ; preds = %entry - ret { ptr, i64 } { ptr @str.723, i64 4 } + ret { ptr, i64 } { ptr @str.725, i64 4 } if.merge.485: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7529,7 +7535,7 @@ entry: br i1 %lnot, label %if.then.486, label %if.merge.487 if.then.486: ; preds = %entry - ret { ptr, i64 } { ptr @str.724, i64 4 } + ret { ptr, i64 } { ptr @str.726, i64 4 } if.merge.487: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7553,7 +7559,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, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7577,7 +7583,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 { [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 8357e89..a7fbdc0 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [13 x i8] c"**CAllocator\00" +@tn.str.241 = private constant [7 x i8] c"**void\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 [8 x i8] c"*string\00" +@tn.str.248 = private constant [6 x i8] c"*bool\00" +@tn.str.249 = private constant [5 x i8] c"*f64\00" +@tn.str.250 = private constant [8 x i8] c"*[4]s64\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"**[1]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 [7 x i8] c"**bool\00" +@tn.str.302 = private constant [6 x i8] c"**f64\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 [160 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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 12 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { 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 7 }, { ptr, i64 } { ptr @tn.str.248, i64 5 }, { ptr, i64 } { ptr @tn.str.249, i64 4 }, { ptr, i64 } { ptr @tn.str.250, i64 7 }, { 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 6 }, { ptr, i64 } { ptr @tn.str.302, i64 5 }, { 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 [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 [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 [3 x i8] c"hi\00", align 1 +@str.329 = private unnamed_addr constant [6 x i8] c"hello\00", align 1 +@str.330 = private unnamed_addr constant [4 x i8] c"s64\00", 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 +@str.332 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.333 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1 +@str.334 = private unnamed_addr constant [7 x i8] c"string\00", align 1 +@str.335 = private unnamed_addr constant [4 x i8] c"f64\00", align 1 +@str.336 = private unnamed_addr constant [8 x i8] c"got s64\00", align 1 +@str.337 = private unnamed_addr constant [11 x i8] c"got string\00", align 1 +@str.338 = private unnamed_addr constant [9 x i8] c"got bool\00", align 1 +@str.339 = private unnamed_addr constant [10 x i8] c"got other\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 [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 }] +@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 [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.362 = private constant [5 x i8] c"data\00" +@field_names.363 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.361, i64 9 }, { ptr, i64 } { ptr @fld.str.362, i64 4 }] +@str.364 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.365 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.369 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.370 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.371 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.376 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.375, i64 11 }] +@str.377 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.378 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.383 = private constant [4 x i8] c"cap\00" +@field_names.384 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.382, i64 4 }, { 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.391 = private constant [10 x i8] c"end_index\00" +@fld.str.392 = private constant [7 x i8] c"parent\00" +@field_names.393 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.390, i64 5 }, { ptr, i64 } { ptr @fld.str.391, i64 9 }, { ptr, i64 } { ptr @fld.str.392, i64 6 }] +@str.394 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.395 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.400 = private constant [4 x i8] c"len\00" +@fld.str.401 = private constant [4 x i8] c"pos\00" +@field_names.402 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.399, i64 3 }, { ptr, i64 } { ptr @fld.str.400, i64 3 }, { ptr, i64 } { ptr @fld.str.401, i64 3 }] @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.404 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.408 = private constant [7 x i8] c"parent\00" +@fld.str.409 = private constant [12 x i8] c"alloc_count\00" +@fld.str.410 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.411 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.412 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.408, i64 6 }, { ptr, i64 } { ptr @fld.str.409, i64 11 }, { ptr, i64 } { ptr @fld.str.410, i64 13 }, { ptr, i64 } { ptr @fld.str.411, i64 17 }] +@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 [5 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"*[1]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 [7 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"*string\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"*f64\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 @@ -625,85 +625,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -846,7 +768,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -973,7 +895,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1307,7 +1229,7 @@ entry: br i1 %icmp, label %if.then.369, label %if.merge.370 if.then.369: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.370: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1457,7 +1379,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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,12 +1406,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1514,25 +1436,25 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 97, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 95, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1568,7 +1490,7 @@ match.merge.37: ; preds = %dispatch.merge.472, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1613,12 +1535,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1669,7 +1591,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.264 [ - i64 35, label %dispatch.case.265 + i64 22, label %dispatch.case.265 i64 81, label %dispatch.case.266 i64 87, label %dispatch.case.267 i64 88, label %dispatch.case.268 @@ -1682,7 +1604,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.302 [ - i64 36, label %dispatch.case.303 + i64 23, label %dispatch.case.303 i64 60, label %dispatch.case.304 i64 77, label %dispatch.case.305 i64 85, label %dispatch.case.306 @@ -1695,13 +1617,13 @@ 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 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 - i64 33, label %dispatch.case.342 + i64 25, label %dispatch.case.336 + i64 27, label %dispatch.case.337 + i64 29, label %dispatch.case.338 + i64 31, label %dispatch.case.339 + i64 32, label %dispatch.case.340 + i64 34, label %dispatch.case.341 + i64 36, label %dispatch.case.342 i64 40, label %dispatch.case.343 i64 44, label %dispatch.case.344 i64 47, label %dispatch.case.345 @@ -1795,7 +1717,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 @@ -1817,56 +1739,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2004,7 +1926,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 @@ -2045,7 +1967,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 @@ -2102,7 +2024,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 @@ -2151,7 +2073,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 @@ -2377,7 +2299,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 @@ -2419,7 +2341,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 @@ -2515,7 +2437,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 @@ -2523,7 +2445,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 @@ -2533,13 +2455,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 @@ -2547,7 +2469,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 @@ -2561,7 +2483,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 @@ -2569,7 +2491,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 @@ -2580,7 +2502,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 @@ -2637,7 +2559,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 @@ -2645,7 +2567,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 @@ -2656,7 +2578,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 @@ -2676,7 +2598,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 @@ -2684,7 +2606,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 @@ -2695,7 +2617,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 @@ -2705,67 +2627,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2941,166 +2947,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3298,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.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3385,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.95(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.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3514,20 +3520,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.126(ptr, i1) #0 +declare void @assert.128(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.326, i64 2 }) + %callN = call { ptr, i64 } @show__pack_string(ptr @__sx_default_context, { ptr, i64 } { ptr @str.328, 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.327, i64 5 }) + %callN = call { ptr, i64 } @describe__pack_string(ptr @__sx_default_context, { ptr, i64 } { ptr @str.329, 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) @@ -3566,14 +3572,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.328, i64 3 } + ret { ptr, i64 } { ptr @str.330, 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.329, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.331, 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 @@ -3591,7 +3597,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 %allocaN, align 8 %ba.tmp9 = alloca { ptr, i64 }, align 8 @@ -3616,7 +3622,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 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.333, i64 3 }) ret { ptr, i64 } %call } @@ -3639,7 +3645,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 6 } + ret { ptr, i64 } { ptr @str.334, i64 6 } } ; Function Attrs: nounwind @@ -3659,7 +3665,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 3 } + ret { ptr, i64 } { ptr @str.335, i64 3 } } ; Function Attrs: nounwind @@ -3678,7 +3684,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 7 } + ret { ptr, i64 } { ptr @str.336, i64 7 } } ; Function Attrs: nounwind @@ -3700,7 +3706,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 10 } + ret { ptr, i64 } { ptr @str.337, i64 10 } } ; Function Attrs: nounwind @@ -3720,7 +3726,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.336, i64 8 } + ret { ptr, i64 } { ptr @str.338, i64 8 } } ; Function Attrs: nounwind @@ -3740,7 +3746,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.337, i64 9 } + ret { ptr, i64 } { ptr @str.339, i64 9 } } ; Function Attrs: nounwind @@ -3750,7 +3756,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 @@ -3769,12 +3775,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.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.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.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.125 @@ -3786,7 +3792,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.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 @@ -3843,7 +3849,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.346, i64 9 }, { ptr, i64 } { ptr @str.347, i64 1 }) + %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 @@ -3862,24 +3868,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.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.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.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.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 [3 x { ptr, i64 }], ptr @field_names.353, 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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -3923,20 +3929,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.355, i64 10 }, { ptr, i64 } { ptr @str.356, i64 1 }) + %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.357, i64 7 }, { 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.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, 2 br i1 %icmp, label %while.body.132, label %while.exit.133 while.body.132: ; preds = %while.hdr.131 @@ -3946,24 +3953,102 @@ 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.357, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, 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 }) + %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.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.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.360, 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 { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.131 + +fv.default: ; preds = %if.merge.135 + br label %fv.merge + +fv.case: ; preds = %if.merge.135 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.135 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.365, i64 10 }, { 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.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.367, 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.368, 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.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 {}, ptr %alloca, align 1 @@ -3974,7 +4059,7 @@ if.merge.135: ; preds = %if.then.134, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.131 + br label %while.hdr.136 } ; Function Attrs: nounwind @@ -3982,43 +4067,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.371, i64 3 }, { 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.136 + br label %while.hdr.141 -while.hdr.136: ; preds = %fv.merge, %entry +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.137, label %while.exit.138 + br i1 %icmp, label %while.body.142, label %while.exit.143 -while.body.137: ; preds = %while.hdr.136 +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.139, label %if.merge.140 + br i1 %icmpN, label %if.then.144, label %if.merge.145 -while.exit.138: ; preds = %while.hdr.136 +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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 1 }) ret { ptr, i64 } %callN -if.then.139: ; preds = %while.body.137 +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 }) + %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.140 + br label %if.merge.145 -if.merge.140: ; preds = %if.then.139, %while.body.137 +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.366, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.367, 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 { i64 }, ptr %alloca, align 8 @@ -4035,12 +4120,12 @@ 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 + br label %while.hdr.141 -fv.default: ; preds = %if.merge.140 +fv.default: ; preds = %if.merge.145 br label %fv.merge -fv.case: ; preds = %if.merge.140 +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 @@ -4051,43 +4136,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 10 }, { 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.141 + br label %while.hdr.146 -while.hdr.141: ; preds = %fv.merge, %entry +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.142, label %while.exit.143 + br i1 %icmp, label %while.body.147, label %while.exit.148 -while.body.142: ; preds = %while.hdr.141 +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.144, label %if.merge.145 + br i1 %icmpN, label %if.then.149, label %if.merge.150 -while.exit.143: ; preds = %while.hdr.141 +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.380, i64 1 }) ret { ptr, i64 } %callN -if.then.144: ; preds = %while.body.142 +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.381, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.145 + br label %if.merge.150 -if.merge.145: ; preds = %if.then.144, %while.body.142 +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.374, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.384, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.385, 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 @@ -4105,18 +4190,18 @@ 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.141 + br label %while.hdr.146 -fv.default: ; preds = %if.merge.145 +fv.default: ; preds = %if.merge.150 br label %fv.merge -fv.case: ; preds = %if.merge.145 +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 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.145 +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 @@ -4128,91 +4213,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 }) - %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.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.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.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.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 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.146 - -fv.default: ; preds = %if.merge.150 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.150 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 8 }, { ptr, i64 } { ptr @str.386, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.386, i64 5 }, { ptr, i64 } { ptr @str.387, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4231,27 +4232,27 @@ 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.387, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.388, 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.388, 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 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.392, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.393, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.394, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4273,29 +4274,30 @@ fv.default: ; preds = %if.merge.155 br label %fv.merge fv.case: ; preds = %if.merge.155 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.155 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.155 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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 }) + %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.395, i64 8 }, { ptr, i64 } { ptr @str.396, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4304,7 +4306,7 @@ entry: while.hdr.156: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.157, label %while.exit.158 while.body.157: ; preds = %while.hdr.156 @@ -4314,19 +4316,19 @@ 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.396, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, 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.397, 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 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.402, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4334,17 +4336,16 @@ if.merge.160: ; preds = %if.then.159, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4357,35 +4358,29 @@ fv.default: ; preds = %if.merge.160 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.160 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.160 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.160 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.404, i64 17 }, { 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 @@ -4394,7 +4389,7 @@ entry: while.hdr.161: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.162, label %while.exit.163 while.body.162: ; preds = %while.hdr.161 @@ -4416,23 +4411,25 @@ if.then.164: ; preds = %while.body.162 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.410, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4445,16 +4442,25 @@ fv.default: ; preds = %if.merge.165 br label %fv.merge fv.case: ; preds = %if.merge.165 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.165 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.165 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4463,7 +4469,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 @@ -4482,24 +4488,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.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.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.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.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.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 @@ -4536,7 +4542,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 @@ -4555,24 +4561,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.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.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.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.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.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 @@ -4638,7 +4644,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 @@ -4657,24 +4663,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.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.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.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.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.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 @@ -4716,7 +4722,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 @@ -4735,24 +4741,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.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.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.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.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.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 @@ -4813,7 +4819,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 @@ -4832,24 +4838,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.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.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.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.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.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 @@ -4895,7 +4901,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 @@ -4914,24 +4920,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.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.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.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.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.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 @@ -4979,7 +4985,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 @@ -4998,24 +5004,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.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.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.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.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.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 @@ -5059,7 +5065,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 @@ -5078,24 +5084,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.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.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.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.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.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 @@ -5145,7 +5151,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 @@ -5164,24 +5170,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.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.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.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.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.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 @@ -5230,7 +5236,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 @@ -5249,24 +5255,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.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.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.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.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.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 @@ -5286,7 +5292,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 @@ -5305,24 +5311,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.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.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.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.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.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 @@ -5374,7 +5380,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 @@ -5393,24 +5399,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.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.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.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.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.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 @@ -5462,7 +5468,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 @@ -5481,24 +5487,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.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.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.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.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.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 @@ -5541,7 +5547,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 @@ -5560,24 +5566,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.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.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.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.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.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 @@ -5623,7 +5629,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 @@ -5642,24 +5648,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.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.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.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.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.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 @@ -5716,7 +5722,7 @@ fv.case28: ; preds = %if.merge.240 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.240 @@ -5741,7 +5747,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 @@ -5760,24 +5766,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.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.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.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.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.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 @@ -5836,9 +5842,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 @@ -5857,8 +5863,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.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.254 @@ -5877,9 +5883,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 @@ -5898,8 +5904,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.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.256 @@ -5929,9 +5935,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 @@ -5948,8 +5954,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.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.258 @@ -6027,9 +6033,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 @@ -6048,8 +6054,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.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.260 @@ -6068,9 +6074,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 @@ -6089,8 +6095,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.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.262 @@ -6107,7 +6113,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.271 @@ -6124,12 +6130,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.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.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.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.275 @@ -6158,7 +6164,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.276 @@ -6175,12 +6181,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.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.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.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.280 @@ -6210,7 +6216,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.281 @@ -6227,12 +6233,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.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.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.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.285 @@ -6260,7 +6266,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.286 @@ -6277,12 +6283,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.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.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.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.290 @@ -6311,7 +6317,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.291 @@ -6328,12 +6334,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.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.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.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.295 @@ -6362,7 +6368,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.296 @@ -6379,12 +6385,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.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.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.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.300 @@ -6414,7 +6420,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.308 @@ -6433,12 +6439,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.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.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.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.312 @@ -6467,7 +6473,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.313 @@ -6486,12 +6492,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.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.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.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.317 @@ -6520,7 +6526,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.318 @@ -6539,12 +6545,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.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.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.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.322 @@ -6574,7 +6580,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.323 @@ -6593,12 +6599,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.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.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.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.327 @@ -6628,7 +6634,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.328 @@ -6647,12 +6653,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.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.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.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.332 @@ -6694,12 +6700,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.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.368 if.merge.368: ; preds = %if.else.367, %if.then.366 - %bp = phi { ptr, i64 } [ { ptr @str.634, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] + %bp = phi { ptr, i64 } [ { ptr @str.636, i64 4 }, %if.then.366 ], [ %callN, %if.else.367 ] ret { ptr, i64 } %bp } @@ -6722,12 +6728,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.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.384 if.merge.384: ; preds = %if.else.383, %if.then.382 - %bp = phi { ptr, i64 } [ { ptr @str.637, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] + %bp = phi { ptr, i64 } [ { ptr @str.639, i64 4 }, %if.then.382 ], [ %callN, %if.else.383 ] ret { ptr, i64 } %bp } @@ -6750,12 +6756,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.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.387 if.merge.387: ; preds = %if.else.386, %if.then.385 - %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] + %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.385 ], [ %callN, %if.else.386 ] ret { ptr, i64 } %bp } @@ -6778,12 +6784,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 } @@ -6806,12 +6812,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 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.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 } @@ -6833,12 +6839,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 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.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 } @@ -6861,12 +6867,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 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.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 } @@ -6889,12 +6895,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 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.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 } @@ -6917,12 +6923,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 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.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 } @@ -6945,12 +6951,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 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.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 } @@ -6973,12 +6979,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 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.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 } @@ -7001,12 +7007,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 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.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 } @@ -7029,12 +7035,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 } @@ -7056,12 +7062,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 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.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 } @@ -7084,12 +7090,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 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.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 } @@ -7111,12 +7117,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 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.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 } @@ -7139,12 +7145,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 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.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 } @@ -7167,12 +7173,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 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.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 } @@ -7195,12 +7201,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 } @@ -7223,12 +7229,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 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.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 } @@ -7251,12 +7257,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 } @@ -7279,12 +7285,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 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.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 } @@ -7307,12 +7313,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 } @@ -7335,12 +7341,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 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.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 } @@ -7363,12 +7369,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 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.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 } @@ -7391,12 +7397,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 4 }, { 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 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.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 } @@ -7419,12 +7425,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 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.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 } @@ -7447,12 +7453,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 6 }, { 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 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.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 } @@ -7475,12 +7481,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 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.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 } @@ -7503,12 +7509,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 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.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 } @@ -7531,12 +7537,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 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.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 } @@ -7552,7 +7558,7 @@ entry: br i1 %lnot, label %if.then.478, label %if.merge.479 if.then.478: ; preds = %entry - ret { ptr, i64 } { ptr @str.727, i64 4 } + ret { ptr, i64 } { ptr @str.729, i64 4 } if.merge.479: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7576,7 +7582,7 @@ entry: br i1 %lnot, label %if.then.480, label %if.merge.481 if.then.480: ; preds = %entry - ret { ptr, i64 } { ptr @str.728, i64 4 } + ret { ptr, i64 } { ptr @str.730, i64 4 } if.merge.481: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7600,7 +7606,7 @@ entry: br i1 %lnot, label %if.then.482, label %if.merge.483 if.then.482: ; preds = %entry - ret { ptr, i64 } { ptr @str.729, i64 4 } + ret { ptr, i64 } { ptr @str.731, i64 4 } if.merge.483: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7624,7 +7630,7 @@ entry: br i1 %lnot, label %if.then.484, label %if.merge.485 if.then.484: ; preds = %entry - ret { ptr, i64 } { ptr @str.730, i64 4 } + ret { ptr, i64 } { ptr @str.732, 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 7397d32..19f248d 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [8 x i8] c"Greeter\00" +@tn.str.241 = private constant [18 x i8] c"__Greeter__Vtable\00" +@tn.str.242 = private constant [4 x i8] c"Dog\00" +@tn.str.243 = private constant [4 x i8] c"Cat\00" +@tn.str.244 = private constant [5 x i8] c"*Dog\00" +@tn.str.245 = private constant [5 x i8] c"*Cat\00" +@tn.str.246 = private constant [10 x i8] c"[]Greeter\00" +@tn.str.247 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.248 = private constant [7 x i8] c"**void\00" +@tn.str.249 = private constant [6 x i8] c"[]Any\00" +@tn.str.250 = private constant [5 x i8] c"*Any\00" +@tn.str.251 = private constant [7 x i8] c"[2]Any\00" +@tn.str.252 = private constant [8 x i8] c"*[2]Any\00" +@tn.str.253 = private constant [7 x i8] c"*[]Any\00" +@tn.str.254 = private constant [6 x i8] c"**Dog\00" +@tn.str.255 = private constant [6 x i8] c"**Cat\00" +@tn.str.256 = private constant [8 x i8] c"*string\00" +@tn.str.257 = private constant [7 x i8] c"[1]Any\00" +@tn.str.258 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.259 = private constant [6 x i8] c"*bool\00" +@tn.str.260 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.261 = private constant [5 x i8] c"*f64\00" +@tn.str.262 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.263 = private constant [11 x i8] c"*Allocator\00" +@tn.str.264 = private constant [9 x i8] c"*Context\00" +@tn.str.265 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.266 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.267 = private constant [8 x i8] c"*Member\00" +@tn.str.268 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.269 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.270 = private constant [9 x i8] c"*Command\00" +@tn.str.271 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.272 = private constant [9 x i8] c"*Greeter\00" +@tn.str.273 = private constant [19 x i8] c"*__Greeter__Vtable\00" +@tn.str.274 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.275 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.276 = private constant [7 x i8] c"*Value\00" +@tn.str.277 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.278 = private constant [14 x i8] c"*Architecture\00" +@tn.str.279 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.280 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.281 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.282 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.283 = private constant [10 x i8] c"*[]string\00" +@tn.str.284 = private constant [6 x i8] c"*[]u8\00" +@tn.str.285 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.286 = private constant [11 x i8] c"*[]Command\00" +@tn.str.287 = private constant [11 x i8] c"*[]Greeter\00" +@tn.str.288 = private constant [6 x i8] c"**GPA\00" +@tn.str.289 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.290 = private constant [8 x i8] c"**Arena\00" +@tn.str.291 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.292 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.293 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.294 = private constant [7 x i8] c"**File\00" +@tn.str.295 = private constant [5 x i8] c"**u8\00" +@tn.str.296 = private constant [6 x i8] c"**s32\00" +@tn.str.297 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.298 = private constant [6 x i8] c"**u32\00" +@tn.str.299 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.300 = private constant [8 x i8] c"**Array\00" +@tn.str.301 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.302 = private constant [9 x i8] c"**Object\00" +@tn.str.303 = private constant [7 x i8] c"**Sink\00" +@tn.str.304 = private constant [9 x i8] c"**Parser\00" +@tn.str.305 = private constant [6 x i8] c"**s64\00" +@tn.str.306 = private constant [9 x i8] c"**Parsed\00" +@tn.str.307 = private constant [7 x i8] c"**Diag\00" +@tn.str.308 = private constant [9 x i8] c"**Sha256\00" +@tn.str.309 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.310 = private constant [8 x i8] c"***void\00" +@tn.str.311 = private constant [6 x i8] c"**Any\00" +@tn.str.312 = private constant [9 x i8] c"**[2]Any\00" +@tn.str.313 = private constant [8 x i8] c"**[]Any\00" +@tn.str.314 = private constant [7 x i8] c"***Dog\00" +@tn.str.315 = private constant [7 x i8] c"***Cat\00" +@tn.str.316 = private constant [9 x i8] c"**string\00" +@tn.str.317 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.318 = private constant [7 x i8] c"**bool\00" +@tn.str.319 = private constant [7 x i8] c"*?File\00" +@tn.str.320 = private constant [9 x i8] c"*?string\00" +@tn.str.321 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.322 = 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.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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 7 }, { ptr, i64 } { ptr @tn.str.241, i64 17 }, { ptr, i64 } { ptr @tn.str.242, i64 3 }, { ptr, i64 } { ptr @tn.str.243, i64 3 }, { ptr, i64 } { ptr @tn.str.244, i64 4 }, { ptr, i64 } { ptr @tn.str.245, i64 4 }, { ptr, i64 } { ptr @tn.str.246, i64 9 }, { ptr, i64 } { ptr @tn.str.247, i64 12 }, { ptr, i64 } { ptr @tn.str.248, i64 6 }, { ptr, i64 } { ptr @tn.str.249, i64 5 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 6 }, { ptr, i64 } { ptr @tn.str.252, i64 7 }, { ptr, i64 } { ptr @tn.str.253, i64 6 }, { ptr, i64 } { ptr @tn.str.254, i64 5 }, { ptr, i64 } { ptr @tn.str.255, i64 5 }, { ptr, i64 } { ptr @tn.str.256, i64 7 }, { ptr, i64 } { ptr @tn.str.257, i64 6 }, { ptr, i64 } { ptr @tn.str.258, i64 7 }, { ptr, i64 } { ptr @tn.str.259, i64 5 }, { ptr, i64 } { ptr @tn.str.260, i64 7 }, { ptr, i64 } { ptr @tn.str.261, i64 4 }, { ptr, i64 } { ptr @tn.str.262, i64 16 }, { ptr, i64 } { ptr @tn.str.263, i64 10 }, { ptr, i64 } { ptr @tn.str.264, i64 8 }, { ptr, i64 } { ptr @tn.str.265, i64 11 }, { ptr, i64 } { ptr @tn.str.266, i64 14 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 13 }, { ptr, i64 } { ptr @tn.str.269, i64 9 }, { ptr, i64 } { ptr @tn.str.270, i64 8 }, { ptr, i64 } { ptr @tn.str.271, i64 10 }, { ptr, i64 } { ptr @tn.str.272, i64 8 }, { ptr, i64 } { ptr @tn.str.273, i64 18 }, { 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 16 }, { ptr, i64 } { ptr @tn.str.278, i64 13 }, { ptr, i64 } { ptr @tn.str.279, i64 14 }, { ptr, i64 } { ptr @tn.str.280, i64 7 }, { ptr, i64 } { ptr @tn.str.281, i64 7 }, { ptr, i64 } { ptr @tn.str.282, i64 8 }, { ptr, i64 } { ptr @tn.str.283, i64 9 }, { ptr, i64 } { ptr @tn.str.284, i64 5 }, { ptr, i64 } { ptr @tn.str.285, i64 11 }, { ptr, i64 } { ptr @tn.str.286, i64 10 }, { ptr, i64 } { ptr @tn.str.287, i64 10 }, { ptr, i64 } { ptr @tn.str.288, i64 5 }, { ptr, i64 } { ptr @tn.str.289, i64 12 }, { ptr, i64 } { ptr @tn.str.290, i64 7 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 10 }, { ptr, i64 } { ptr @tn.str.293, i64 19 }, { ptr, i64 } { ptr @tn.str.294, i64 6 }, { ptr, i64 } { ptr @tn.str.295, i64 4 }, { ptr, i64 } { ptr @tn.str.296, i64 5 }, { ptr, i64 } { ptr @tn.str.297, i64 10 }, { ptr, i64 } { ptr @tn.str.298, i64 5 }, { ptr, i64 } { ptr @tn.str.299, i64 9 }, { ptr, i64 } { ptr @tn.str.300, i64 7 }, { ptr, i64 } { ptr @tn.str.301, i64 10 }, { 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 5 }, { 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 13 }, { ptr, i64 } { ptr @tn.str.310, i64 7 }, { 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 6 }, { ptr, i64 } { ptr @tn.str.316, i64 8 }, { ptr, i64 } { ptr @tn.str.317, i64 8 }, { ptr, i64 } { ptr @tn.str.318, i64 6 }, { ptr, i64 } { ptr @tn.str.319, i64 6 }, { ptr, i64 } { ptr @tn.str.320, i64 8 }, { ptr, i64 } { ptr @tn.str.321, i64 15 }, { ptr, i64 } { ptr @tn.str.322, i64 8 }] @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 [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 [1 x i8] zeroinitializer, align 1 +@str.327 = 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 [15 x i8] c"result := \22\22; \00", align 1 +@str.330 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.331 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.332 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.333 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.334 = private unnamed_addr constant [6 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 [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 [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 [1 x i8] zeroinitializer, align 1 +@str.345 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.346 = private unnamed_addr constant [12 x i8] c"dog+cat={}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.348 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.349 = private unnamed_addr constant [12 x i8] c"cat+dog={}\0A\00", 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 +@str.351 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.352 = private unnamed_addr constant [12 x i8] c"dog+dog={}\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 [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 }] +@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 [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.375 = private constant [5 x i8] c"data\00" +@field_names.376 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.374, i64 9 }, { ptr, i64 } { ptr @fld.str.375, i64 4 }] +@str.377 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.378 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.382 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.383 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.384 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.389 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.388, i64 11 }] +@str.390 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.391 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.396 = private constant [4 x i8] c"cap\00" +@field_names.397 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.395, i64 4 }, { 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.404 = private constant [10 x i8] c"end_index\00" +@fld.str.405 = private constant [7 x i8] c"parent\00" +@field_names.406 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.403, i64 5 }, { ptr, i64 } { ptr @fld.str.404, i64 9 }, { ptr, i64 } { ptr @fld.str.405, i64 6 }] +@str.407 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.408 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.413 = private constant [4 x i8] c"len\00" +@fld.str.414 = private constant [4 x i8] c"pos\00" +@field_names.415 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.412, i64 3 }, { ptr, i64 } { ptr @fld.str.413, i64 3 }, { 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 [8 x i8] c"Context\00", align 1 +@str.417 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.421 = private constant [7 x i8] c"parent\00" +@fld.str.422 = private constant [12 x i8] c"alloc_count\00" +@fld.str.423 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.424 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.425 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.421, i64 6 }, { ptr, i64 } { ptr @fld.str.422, i64 11 }, { ptr, i64 } { ptr @fld.str.423, i64 13 }, { ptr, i64 } { ptr @fld.str.424, i64 17 }] +@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"Greeter\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"ctx\00" +@fld.str.576 = private constant [9 x i8] c"__vtable\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 8 }] +@str.578 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.579 = private unnamed_addr constant [18 x i8] c"__Greeter__Vtable\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"greet\00" +@field_names.584 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.583, i64 5 }] +@str.585 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.586 = private unnamed_addr constant [4 x i8] c"Dog\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 +@str.589 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.590 = private constant [4 x i8] c"age\00" +@field_names.591 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.590, i64 3 }] +@str.592 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.593 = private unnamed_addr constant [4 x i8] c"Cat\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 +@fld.str.597 = private constant [6 x i8] c"lives\00" +@field_names.598 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.597, i64 5 }] +@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 +@fld.str.601 = private constant [5 x i8] c"read\00" +@fld.str.602 = private constant [6 x i8] c"write\00" +@fld.str.603 = private constant [7 x i8] c"append\00" +@fld.str.604 = private constant [11 x i8] c"read_write\00" +@field_names.605 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.601, i64 4 }, { ptr, i64 } { ptr @fld.str.602, i64 5 }, { ptr, i64 } { ptr @fld.str.603, i64 6 }, { ptr, i64 } { ptr @fld.str.604, i64 10 }] +@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 +@fld.str.609 = private constant [4 x i8] c"set\00" +@fld.str.610 = private constant [8 x i8] c"current\00" +@fld.str.611 = private constant [4 x i8] c"end\00" +@field_names.612 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.609, i64 3 }, { ptr, i64 } { ptr @fld.str.610, i64 7 }, { ptr, i64 } { ptr @fld.str.611, i64 3 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.616 = private constant [6 x i8] c"null_\00" +@fld.str.617 = private constant [6 x i8] c"bool_\00" +@fld.str.618 = private constant [5 x i8] c"int_\00" +@fld.str.619 = private constant [4 x i8] c"str\00" +@fld.str.620 = private constant [6 x i8] c"array\00" +@fld.str.621 = private constant [7 x i8] c"object\00" +@field_names.622 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.616, i64 5 }, { ptr, i64 } { ptr @fld.str.617, i64 5 }, { ptr, i64 } { ptr @fld.str.618, i64 4 }, { ptr, i64 } { ptr @fld.str.619, i64 3 }, { ptr, i64 } { ptr @fld.str.620, i64 5 }, { ptr, i64 } { ptr @fld.str.621, i64 6 }] +@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 [6 x i8] c"macos\00" +@fld.str.627 = private constant [6 x i8] c"linux\00" +@fld.str.628 = private constant [8 x i8] c"windows\00" +@fld.str.629 = private constant [5 x i8] c"wasm\00" +@fld.str.630 = private constant [4 x i8] c"ios\00" +@fld.str.631 = private constant [8 x i8] c"android\00" +@fld.str.632 = private constant [8 x i8] c"unknown\00" +@field_names.633 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.626, i64 5 }, { ptr, i64 } { ptr @fld.str.627, i64 5 }, { ptr, i64 } { ptr @fld.str.628, i64 7 }, { ptr, i64 } { ptr @fld.str.629, i64 4 }, { ptr, i64 } { ptr @fld.str.630, i64 3 }, { ptr, i64 } { ptr @fld.str.631, i64 7 }, { ptr, i64 } { ptr @fld.str.632, i64 7 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.637 = private constant [8 x i8] c"aarch64\00" +@fld.str.638 = private constant [7 x i8] c"x86_64\00" +@fld.str.639 = private constant [7 x i8] c"wasm32\00" +@fld.str.640 = private constant [7 x i8] c"wasm64\00" +@fld.str.641 = private constant [8 x i8] c"unknown\00" +@field_names.642 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.637, i64 7 }, { ptr, i64 } { ptr @fld.str.638, i64 6 }, { ptr, i64 } { ptr @fld.str.639, i64 6 }, { ptr, i64 } { ptr @fld.str.640, i64 6 }, { ptr, i64 } { ptr @fld.str.641, i64 7 }] +@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 +@str.646 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.647 = private unnamed_addr constant [3 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 +@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 +@str.652 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.653 = private unnamed_addr constant [3 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 +@str.656 = private unnamed_addr constant [3 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 [5 x i8] c"null\00", align 1 +@str.685 = private unnamed_addr constant [6 x i8] c"*void\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 [12 x i8] c"*CAllocator\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"*GPA\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"*ArenaChunk\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 [7 x i8] c"*Arena\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"[*]u8\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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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 [6 x i8] c"*File\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 [4 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 [5 x i8] c"*s32\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 [10 x i8] c"*SockAddr\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"*u32\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 [9 x i8] c"[*]Value\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"*Array\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"[*]Member\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"*Object\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"*Sink\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"*Parser\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"*s64\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"*Parsed\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"*Diag\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"*Sha256\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"*Dog\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 [5 x i8] c"*Cat\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 [13 x i8] c"**CAllocator\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 [7 x i8] c"**void\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 [5 x i8] c"*Any\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 [8 x i8] c"*[2]Any\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"*[]Any\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"**Dog\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 [6 x i8] c"**Cat\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 [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 [6 x i8] c"*bool\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"null\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"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -685,85 +685,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -906,7 +828,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1033,7 +955,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1367,7 +1289,7 @@ entry: br i1 %icmp, label %if.then.409, label %if.merge.410 if.then.409: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.410: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1517,7 +1439,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1544,12 +1466,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1578,27 +1500,27 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 104, label %match.arm.47 i64 110, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 99, label %match.arm.48 i64 102, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1638,7 +1560,7 @@ match.merge.37: ; preds = %dispatch.merge.524, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1683,12 +1605,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1743,7 +1665,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.288 [ - i64 35, label %dispatch.case.289 + i64 22, label %dispatch.case.289 i64 81, label %dispatch.case.290 i64 87, label %dispatch.case.291 i64 88, label %dispatch.case.292 @@ -1757,7 +1679,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.332 [ - i64 36, label %dispatch.case.333 + i64 23, label %dispatch.case.333 i64 60, label %dispatch.case.334 i64 77, label %dispatch.case.335 i64 85, label %dispatch.case.336 @@ -1771,13 +1693,13 @@ 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 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 - i64 33, label %dispatch.case.378 + i64 25, label %dispatch.case.372 + i64 27, label %dispatch.case.373 + i64 29, label %dispatch.case.374 + i64 31, label %dispatch.case.375 + i64 32, label %dispatch.case.376 + i64 34, label %dispatch.case.377 + i64 36, label %dispatch.case.378 i64 40, label %dispatch.case.379 i64 44, label %dispatch.case.380 i64 47, label %dispatch.case.381 @@ -1875,7 +1797,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.321, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.323, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1897,56 +1819,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2116,7 +2038,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.322, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.324, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.270 dispatch.case.272: ; preds = %match.arm.44 @@ -2157,7 +2079,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.323, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.325, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.287 dispatch.case.289: ; preds = %match.arm.47 @@ -2222,7 +2144,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.324, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.326, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.331 dispatch.case.333: ; preds = %match.arm.48 @@ -2279,7 +2201,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.325, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.327, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.369 dispatch.case.371: ; preds = %match.arm.49 @@ -2533,7 +2455,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.326, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.328, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.524 dispatch.case.526: ; preds = %match.arm.50 @@ -2575,7 +2497,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.327, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.329, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2671,7 +2593,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.328, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.330, 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 @@ -2679,7 +2601,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.329, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.331, 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 @@ -2689,13 +2611,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.330, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.332, 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.331, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.333, 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 @@ -2703,7 +2625,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.332, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.334, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2717,7 +2639,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.333, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.335, 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 @@ -2725,7 +2647,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 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.336, 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 @@ -2736,7 +2658,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 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.337, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2793,7 +2715,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.336, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.338, 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 @@ -2801,7 +2723,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 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 i64, ptr %allocaN, align 8 @@ -2812,7 +2734,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 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.340, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2832,7 +2754,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.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 @@ -2840,7 +2762,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 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, i64 }, ptr %alloca, align 8 @@ -2851,7 +2773,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 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 br label %if.merge.36 @@ -2861,67 +2783,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3097,166 +3103,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3454,64 +3460,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3541,97 +3547,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3670,7 +3676,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i64 @Dog.greet(ptr %0, ptr %1) #0 { @@ -3777,7 +3783,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.342, i64 11 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.344, 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 @@ -3792,7 +3798,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.343, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.345, 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) @@ -3819,7 +3825,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.344, i64 11 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.346, i64 11 }) ret { ptr, i64 } %call } @@ -3867,7 +3873,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.345, i64 11 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.347, 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 @@ -3882,7 +3888,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.346, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.348, 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) @@ -3909,7 +3915,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.347, i64 11 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.349, i64 11 }) ret { ptr, i64 } %call } @@ -3957,7 +3963,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.348, i64 11 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.350, 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 @@ -3972,7 +3978,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 { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 8) @@ -3999,7 +4005,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.350, i64 11 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.352, i64 11 }) ret { ptr, i64 } %call } @@ -4010,7 +4016,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 @@ -4029,12 +4035,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.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.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.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.129 @@ -4046,7 +4052,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.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 @@ -4103,7 +4109,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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 }) + %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 @@ -4122,24 +4128,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.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.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.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.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 [3 x { ptr, i64 }], ptr @field_names.366, 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.367, 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 @@ -4183,20 +4189,21 @@ fv.case21: ; preds = %if.merge.134 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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.368, i64 10 }, { ptr, i64 } { ptr @str.369, i64 1 }) + %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.370, i64 7 }, { 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.135 -while.hdr.135: ; preds = %if.merge.139, %entry +while.hdr.135: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 2 br i1 %icmp, label %while.body.136, label %while.exit.137 while.body.136: ; preds = %while.hdr.135 @@ -4206,24 +4213,102 @@ while.body.136: ; preds = %while.hdr.135 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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.372, 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 }) + %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.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.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.373, 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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.135 + +fv.default: ; preds = %if.merge.139 + br label %fv.merge + +fv.case: ; preds = %if.merge.139 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.139 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.378, i64 10 }, { 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.140 + +while.hdr.140: ; preds = %if.merge.144, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + 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.380, 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.381, 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 [0 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.383, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -4234,7 +4319,7 @@ if.merge.139: ; preds = %if.then.138, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.135 + br label %while.hdr.140 } ; Function Attrs: nounwind @@ -4242,43 +4327,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.384, i64 3 }, { 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 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.140 + br label %while.hdr.145 -while.hdr.140: ; preds = %fv.merge, %entry +while.hdr.145: ; 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 + br i1 %icmp, label %while.body.146, label %while.exit.147 -while.body.141: ; preds = %while.hdr.140 +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.143, label %if.merge.144 + br i1 %icmpN, label %if.then.148, label %if.merge.149 -while.exit.142: ; preds = %while.hdr.140 +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.376, 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.143: ; preds = %while.body.141 +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.377, 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.144 + br label %if.merge.149 -if.merge.144: ; preds = %if.then.143, %while.body.141 +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 [1 x { ptr, i64 }], ptr @field_names.379, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.380, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64 }, ptr %alloca, align 8 @@ -4295,12 +4380,12 @@ 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.140 + br label %while.hdr.145 -fv.default: ; preds = %if.merge.144 +fv.default: ; preds = %if.merge.149 br label %fv.merge -fv.case: ; preds = %if.merge.144 +fv.case: ; preds = %if.merge.149 %fv.field = extractvalue { i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge @@ -4311,43 +4396,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.391, i64 10 }, { 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 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.145 + br label %while.hdr.150 -while.hdr.145: ; preds = %fv.merge, %entry +while.hdr.150: ; 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 + br i1 %icmp, label %while.body.151, label %while.exit.152 -while.body.146: ; preds = %while.hdr.145 +while.body.151: ; preds = %while.hdr.150 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.148, label %if.merge.149 + br i1 %icmpN, label %if.then.153, label %if.merge.154 -while.exit.147: ; preds = %while.hdr.145 +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.383, 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.148: ; preds = %while.body.146 +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.384, 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.149 + br label %if.merge.154 -if.merge.149: ; preds = %if.then.148, %while.body.146 +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 [2 x { ptr, i64 }], ptr @field_names.387, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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.388, 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 %alloca, align 8 @@ -4365,18 +4450,18 @@ 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.145 + br label %while.hdr.150 -fv.default: ; preds = %if.merge.149 +fv.default: ; preds = %if.merge.154 br label %fv.merge -fv.case: ; preds = %if.merge.149 +fv.case: ; preds = %if.merge.154 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.149 +fv.case17: ; preds = %if.merge.154 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -4388,91 +4473,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 }) - %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.150 - -while.hdr.150: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.151, label %while.exit.152 - -while.body.151: ; preds = %while.hdr.150 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.153, label %if.merge.154 - -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.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.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.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.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 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.150 - -fv.default: ; preds = %if.merge.154 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.154 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.398, i64 8 }, { ptr, i64 } { ptr @str.399, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.399, i64 5 }, { 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 @@ -4491,27 +4492,27 @@ 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.400, 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.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.401, 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.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.405, 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.406, 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 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4533,29 +4534,30 @@ fv.default: ; preds = %if.merge.159 br label %fv.merge fv.case: ; preds = %if.merge.159 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.159 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.159 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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 }) + %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.408, i64 8 }, { 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 @@ -4564,7 +4566,7 @@ entry: while.hdr.160: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.161, label %while.exit.162 while.body.161: ; preds = %while.hdr.160 @@ -4574,19 +4576,19 @@ 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.409, 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.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.410, 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.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.415, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4594,17 +4596,16 @@ if.merge.164: ; preds = %if.then.163, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4617,35 +4618,29 @@ fv.default: ; preds = %if.merge.164 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.164 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.164 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.164 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.417, i64 17 }, { 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 @@ -4654,7 +4649,7 @@ entry: while.hdr.165: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.166, label %while.exit.167 while.body.166: ; preds = %while.hdr.165 @@ -4676,23 +4671,25 @@ if.then.168: ; preds = %while.body.166 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.423, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4705,16 +4702,25 @@ fv.default: ; preds = %if.merge.169 br label %fv.merge fv.case: ; preds = %if.merge.169 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.169 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.169 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.169 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4723,7 +4729,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 @@ -4742,24 +4748,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.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.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.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.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.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 @@ -4796,7 +4802,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 @@ -4815,24 +4821,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.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.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.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.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.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 @@ -4898,7 +4904,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 @@ -4917,24 +4923,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.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.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.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.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.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 @@ -4976,7 +4982,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 @@ -4995,24 +5001,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.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.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.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.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.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 @@ -5073,7 +5079,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 @@ -5092,24 +5098,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.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.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.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.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.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 @@ -5155,7 +5161,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 @@ -5174,24 +5180,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.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.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.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.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.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 @@ -5239,7 +5245,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 @@ -5258,24 +5264,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.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.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.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.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.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 @@ -5319,7 +5325,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 @@ -5338,24 +5344,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.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.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.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.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.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 @@ -5405,7 +5411,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 @@ -5424,24 +5430,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.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.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.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.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.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 @@ -5490,7 +5496,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 @@ -5509,24 +5515,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.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.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.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.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.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 @@ -5546,7 +5552,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 @@ -5565,24 +5571,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.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.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.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.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.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 @@ -5634,7 +5640,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 @@ -5653,24 +5659,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.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.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.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.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.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 @@ -5722,7 +5728,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 @@ -5741,24 +5747,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.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.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.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.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.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 @@ -5801,7 +5807,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 @@ -5820,24 +5826,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.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.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.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.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.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 @@ -5883,7 +5889,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 @@ -5902,24 +5908,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.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.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.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.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.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 @@ -5976,7 +5982,7 @@ fv.case28: ; preds = %if.merge.244 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.244 @@ -6001,7 +6007,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 @@ -6020,24 +6026,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.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.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.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.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.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 @@ -6092,7 +6098,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.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 @@ -6111,24 +6117,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.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.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.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.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.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 { ptr, ptr }, ptr %alloca, align 8 @@ -6169,7 +6175,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.577, i64 17 }, { ptr, i64 } { ptr @str.578, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 17 }, { 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 @@ -6188,24 +6194,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.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.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.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.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.582, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.584, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, 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 @@ -6239,7 +6245,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.584, i64 3 }, { ptr, i64 } { ptr @str.585, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.586, i64 3 }, { ptr, i64 } { ptr @str.587, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6258,24 +6264,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.586, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.588, 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.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 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.589, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.591, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.590, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.592, 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 @@ -6308,7 +6314,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.591, i64 3 }, { ptr, i64 } { ptr @str.592, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.593, i64 3 }, { ptr, i64 } { ptr @str.594, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6327,24 +6333,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.593, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.595, 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.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.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.596, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i64 }, ptr %alloca, align 8 @@ -6381,9 +6387,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.603, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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.598, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.600, 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 @@ -6402,8 +6408,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.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.278 @@ -6422,9 +6428,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.610, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.612, 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.606, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.608, 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 @@ -6443,8 +6449,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.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 } { ptr @str.614, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.613, 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 @@ -6474,9 +6480,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.620, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.622, 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, [24 x i8] }, ptr %alloca, align 8 @@ -6493,8 +6499,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.282 @@ -6572,9 +6578,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.631, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.633, 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.623, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.625, 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 @@ -6593,8 +6599,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.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 } { ptr @str.635, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.634, 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 @@ -6613,9 +6619,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.640, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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.634, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.636, 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 @@ -6634,8 +6640,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.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.286 @@ -6652,7 +6658,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.643, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.645, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.296 @@ -6669,12 +6675,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.644, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.646, 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.645, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.647, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.300 @@ -6703,7 +6709,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.646, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.648, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.301 @@ -6720,12 +6726,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.647, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.649, 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.648, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.650, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.305 @@ -6755,7 +6761,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.649, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.651, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.306 @@ -6772,12 +6778,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.650, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.652, 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.651, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.653, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.310 @@ -6805,7 +6811,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.652, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.654, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.311 @@ -6822,12 +6828,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.653, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.655, 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.654, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.656, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.315 @@ -6856,7 +6862,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.655, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.657, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.316 @@ -6873,12 +6879,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.656, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.658, 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.657, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.659, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.320 @@ -6907,7 +6913,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.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.321 @@ -6924,12 +6930,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.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.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.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.325 @@ -6960,7 +6966,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.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.326 @@ -6977,12 +6983,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.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.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.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.330 @@ -7012,7 +7018,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.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.339 @@ -7031,12 +7037,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.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.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.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.343 @@ -7065,7 +7071,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.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.344 @@ -7084,12 +7090,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.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.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.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.348 @@ -7118,7 +7124,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.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.349 @@ -7137,12 +7143,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.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.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.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.353 @@ -7172,7 +7178,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.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.354 @@ -7191,12 +7197,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.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.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.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.358 @@ -7226,7 +7232,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.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.359 @@ -7245,12 +7251,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.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.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.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.363 @@ -7280,7 +7286,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.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.364 @@ -7299,12 +7305,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.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.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.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.368 @@ -7346,12 +7352,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.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.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -7374,12 +7380,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.687, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.686, i64 11 }, { 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 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.685, i64 4 }, %if.then.422 ], [ %callN, %if.else.423 ] + %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.422 ], [ %callN, %if.else.423 ] ret { ptr, i64 } %bp } @@ -7402,12 +7408,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.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.427 if.merge.427: ; preds = %if.else.426, %if.then.425 - %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] + %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] ret { ptr, i64 } %bp } @@ -7430,12 +7436,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.693, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.692, i64 11 }, { 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 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.691, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] + %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] ret { ptr, i64 } %bp } @@ -7458,12 +7464,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.696, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.695, i64 6 }, { 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 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.694, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] + %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] ret { ptr, i64 } %bp } @@ -7485,12 +7491,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.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.436 if.merge.436: ; preds = %if.else.435, %if.then.434 - %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] + %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] ret { ptr, i64 } %bp } @@ -7513,12 +7519,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.702, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.701, i64 9 }, { 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 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.700, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] ret { ptr, i64 } %bp } @@ -7541,12 +7547,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.705, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.704, i64 18 }, { 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 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.703, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] ret { ptr, i64 } %bp } @@ -7569,12 +7575,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.708, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.707, i64 5 }, { 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 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.706, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] ret { ptr, i64 } %bp } @@ -7597,12 +7603,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.711, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.710, i64 3 }, { 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 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.709, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] ret { ptr, i64 } %bp } @@ -7625,12 +7631,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.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.451 if.merge.451: ; preds = %if.else.450, %if.then.449 - %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] ret { ptr, i64 } %bp } @@ -7653,12 +7659,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.717, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.716, i64 9 }, { 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 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.715, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] ret { ptr, i64 } %bp } @@ -7681,12 +7687,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.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.457 if.merge.457: ; preds = %if.else.456, %if.then.455 - %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] + %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] ret { ptr, i64 } %bp } @@ -7708,12 +7714,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.723, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.722, i64 8 }, { 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 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.721, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] + %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] ret { ptr, i64 } %bp } @@ -7736,12 +7742,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.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.463 if.merge.463: ; preds = %if.else.462, %if.then.461 - %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] + %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] ret { ptr, i64 } %bp } @@ -7763,12 +7769,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.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.466 if.merge.466: ; preds = %if.else.465, %if.then.464 - %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] + %bp = phi { ptr, i64 } [ { ptr @str.729, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] ret { ptr, i64 } %bp } @@ -7791,12 +7797,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.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.469 if.merge.469: ; preds = %if.else.468, %if.then.467 - %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] + %bp = phi { ptr, i64 } [ { ptr @str.732, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] ret { ptr, i64 } %bp } @@ -7819,12 +7825,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.735, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.734, i64 5 }, { 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 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.733, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] + %bp = phi { ptr, i64 } [ { ptr @str.735, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] ret { ptr, i64 } %bp } @@ -7847,12 +7853,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.738, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.737, i64 7 }, { 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 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.736, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] + %bp = phi { ptr, i64 } [ { ptr @str.738, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] ret { ptr, i64 } %bp } @@ -7875,12 +7881,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.741, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.740, i64 4 }, { 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 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.739, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] + %bp = phi { ptr, i64 } [ { ptr @str.741, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] ret { ptr, i64 } %bp } @@ -7903,12 +7909,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.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.481 if.merge.481: ; preds = %if.else.480, %if.then.479 - %bp = phi { ptr, i64 } [ { ptr @str.742, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] + %bp = phi { ptr, i64 } [ { ptr @str.744, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] ret { ptr, i64 } %bp } @@ -7931,12 +7937,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.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.484 if.merge.484: ; preds = %if.else.483, %if.then.482 - %bp = phi { ptr, i64 } [ { ptr @str.745, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] + %bp = phi { ptr, i64 } [ { ptr @str.747, i64 4 }, %if.then.482 ], [ %callN, %if.else.483 ] ret { ptr, i64 } %bp } @@ -7959,12 +7965,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.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.487 if.merge.487: ; preds = %if.else.486, %if.then.485 - %bp = phi { ptr, i64 } [ { ptr @str.748, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] + %bp = phi { ptr, i64 } [ { ptr @str.750, i64 4 }, %if.then.485 ], [ %callN, %if.else.486 ] ret { ptr, i64 } %bp } @@ -7987,12 +7993,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.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.490 if.merge.490: ; preds = %if.else.489, %if.then.488 - %bp = phi { ptr, i64 } [ { ptr @str.751, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] + %bp = phi { ptr, i64 } [ { ptr @str.753, i64 4 }, %if.then.488 ], [ %callN, %if.else.489 ] ret { ptr, i64 } %bp } @@ -8015,12 +8021,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.756, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.755, i64 4 }, { 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 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.754, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] + %bp = phi { ptr, i64 } [ { ptr @str.756, i64 4 }, %if.then.491 ], [ %callN, %if.else.492 ] ret { ptr, i64 } %bp } @@ -8043,12 +8049,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.759, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.758, i64 12 }, { 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 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.757, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] + %bp = phi { ptr, i64 } [ { ptr @str.759, i64 4 }, %if.then.494 ], [ %callN, %if.else.495 ] ret { ptr, i64 } %bp } @@ -8071,12 +8077,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.762, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.761, i64 6 }, { 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 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.760, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] + %bp = phi { ptr, i64 } [ { ptr @str.762, i64 4 }, %if.then.497 ], [ %callN, %if.else.498 ] ret { ptr, i64 } %bp } @@ -8099,12 +8105,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.765, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.764, i64 4 }, { 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 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.763, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] + %bp = phi { ptr, i64 } [ { ptr @str.765, i64 4 }, %if.then.500 ], [ %callN, %if.else.501 ] ret { ptr, i64 } %bp } @@ -8127,12 +8133,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.768, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.767, i64 7 }, { 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 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.766, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] + %bp = phi { ptr, i64 } [ { ptr @str.768, i64 4 }, %if.then.503 ], [ %callN, %if.else.504 ] ret { ptr, i64 } %bp } @@ -8155,12 +8161,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.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.508 if.merge.508: ; preds = %if.else.507, %if.then.506 - %bp = phi { ptr, i64 } [ { ptr @str.769, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] + %bp = phi { ptr, i64 } [ { ptr @str.771, i64 4 }, %if.then.506 ], [ %callN, %if.else.507 ] ret { ptr, i64 } %bp } @@ -8183,12 +8189,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.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.511 if.merge.511: ; preds = %if.else.510, %if.then.509 - %bp = phi { ptr, i64 } [ { ptr @str.772, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] + %bp = phi { ptr, i64 } [ { ptr @str.774, i64 4 }, %if.then.509 ], [ %callN, %if.else.510 ] ret { ptr, i64 } %bp } @@ -8211,12 +8217,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.777, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.776, i64 5 }, { 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 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.775, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] + %bp = phi { ptr, i64 } [ { ptr @str.777, i64 4 }, %if.then.512 ], [ %callN, %if.else.513 ] ret { ptr, i64 } %bp } @@ -8239,12 +8245,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.780, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.779, i64 7 }, { 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 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.778, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] + %bp = phi { ptr, i64 } [ { ptr @str.780, i64 4 }, %if.then.515 ], [ %callN, %if.else.516 ] ret { ptr, i64 } %bp } @@ -8267,12 +8273,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.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.520 if.merge.520: ; preds = %if.else.519, %if.then.518 - %bp = phi { ptr, i64 } [ { ptr @str.781, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] + %bp = phi { ptr, i64 } [ { ptr @str.783, i64 4 }, %if.then.518 ], [ %callN, %if.else.519 ] ret { ptr, i64 } %bp } @@ -8295,12 +8301,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.786, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.785, i64 5 }, { 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 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.784, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] + %bp = phi { ptr, i64 } [ { ptr @str.786, i64 4 }, %if.then.521 ], [ %callN, %if.else.522 ] ret { ptr, i64 } %bp } @@ -8316,7 +8322,7 @@ entry: br i1 %lnot, label %if.then.530, label %if.merge.531 if.then.530: ; preds = %entry - ret { ptr, i64 } { ptr @str.787, i64 4 } + ret { ptr, i64 } { ptr @str.789, i64 4 } if.merge.531: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8340,7 +8346,7 @@ entry: br i1 %lnot, label %if.then.532, label %if.merge.533 if.then.532: ; preds = %entry - ret { ptr, i64 } { ptr @str.788, i64 4 } + ret { ptr, i64 } { ptr @str.790, i64 4 } if.merge.533: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8364,7 +8370,7 @@ entry: br i1 %lnot, label %if.then.534, label %if.merge.535 if.then.534: ; preds = %entry - ret { ptr, i64 } { ptr @str.789, i64 4 } + ret { ptr, i64 } { ptr @str.791, i64 4 } if.merge.535: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8388,7 +8394,7 @@ entry: br i1 %lnot, label %if.then.536, label %if.merge.537 if.then.536: ; preds = %entry - ret { ptr, i64 } { ptr @str.790, i64 4 } + ret { ptr, i64 } { ptr @str.792, i64 4 } if.merge.537: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 diff --git a/examples/expected/0903-optionals-optional-roundtrip.ir b/examples/expected/0903-optionals-optional-roundtrip.ir index 58a2a60..9b4464c 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [5 x i8] c"?f32\00" +@tn.str.241 = private constant [13 x i8] c"ProposedSize\00" +@tn.str.242 = private constant [8 x i8] c"Sizable\00" +@tn.str.243 = private constant [18 x i8] c"__Sizable__Vtable\00" +@tn.str.244 = private constant [7 x i8] c"Widget\00" +@tn.str.245 = private constant [8 x i8] c"*Widget\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 [8 x i8] c"*string\00" +@tn.str.249 = private constant [6 x i8] c"[]Any\00" +@tn.str.250 = private constant [5 x i8] c"*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 [14 x i8] c"*ProposedSize\00" +@tn.str.254 = private constant [5 x i8] c"*f32\00" +@tn.str.255 = private constant [5 x i8] c"*f64\00" +@tn.str.256 = private constant [7 x i8] c"[1]Any\00" +@tn.str.257 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.258 = private constant [9 x i8] c"*Sizable\00" +@tn.str.259 = private constant [9 x i8] c"**Widget\00" +@tn.str.260 = private constant [19 x i8] c"*__Sizable__Vtable\00" +@tn.str.261 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.262 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.263 = private constant [11 x i8] c"*Allocator\00" +@tn.str.264 = private constant [9 x i8] c"*Context\00" +@tn.str.265 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.266 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.267 = private constant [8 x i8] c"*Member\00" +@tn.str.268 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.269 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.270 = private constant [9 x i8] c"*Command\00" +@tn.str.271 = private constant [11 x i8] c"*FlagValue\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 [6 x i8] c"**GPA\00" +@tn.str.286 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.287 = private constant [8 x i8] c"**Arena\00" +@tn.str.288 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.289 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.290 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.291 = private constant [7 x i8] c"**File\00" +@tn.str.292 = private constant [5 x i8] c"**u8\00" +@tn.str.293 = private constant [6 x i8] c"**s32\00" +@tn.str.294 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.295 = private constant [6 x i8] c"**u32\00" +@tn.str.296 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.297 = private constant [8 x i8] c"**Array\00" +@tn.str.298 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.299 = private constant [9 x i8] c"**Object\00" +@tn.str.300 = private constant [7 x i8] c"**Sink\00" +@tn.str.301 = private constant [9 x i8] c"**Parser\00" +@tn.str.302 = private constant [6 x i8] c"**s64\00" +@tn.str.303 = private constant [9 x i8] c"**Parsed\00" +@tn.str.304 = private constant [7 x i8] c"**Diag\00" +@tn.str.305 = private constant [9 x i8] c"**Sha256\00" +@tn.str.306 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.307 = private constant [8 x i8] c"***void\00" +@tn.str.308 = private constant [9 x i8] c"**string\00" +@tn.str.309 = private constant [6 x i8] c"**Any\00" +@tn.str.310 = private constant [8 x i8] c"**[]Any\00" +@tn.str.311 = private constant [7 x i8] c"**bool\00" +@tn.str.312 = private constant [15 x i8] c"**ProposedSize\00" +@tn.str.313 = private constant [6 x i8] c"**f32\00" +@tn.str.314 = private constant [6 x i8] c"**f64\00" +@tn.str.315 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.316 = private constant [10 x i8] c"**Sizable\00" +@tn.str.317 = private constant [10 x i8] c"***Widget\00" +@tn.str.318 = private constant [20 x i8] c"**__Sizable__Vtable\00" +@tn.str.319 = private constant [7 x i8] c"*?File\00" +@tn.str.320 = private constant [9 x i8] c"*?string\00" +@tn.str.321 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.322 = private constant [9 x i8] c"*?[64]u8\00" +@tn.str.323 = 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.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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 4 }, { ptr, i64 } { ptr @tn.str.241, i64 12 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 17 }, { ptr, i64 } { ptr @tn.str.244, i64 6 }, { ptr, i64 } { ptr @tn.str.245, i64 7 }, { ptr, i64 } { ptr @tn.str.246, i64 12 }, { ptr, i64 } { ptr @tn.str.247, i64 6 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 5 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 6 }, { ptr, i64 } { ptr @tn.str.252, i64 5 }, { ptr, i64 } { ptr @tn.str.253, i64 13 }, { ptr, i64 } { ptr @tn.str.254, i64 4 }, { ptr, i64 } { ptr @tn.str.255, i64 4 }, { ptr, i64 } { ptr @tn.str.256, i64 6 }, { ptr, i64 } { ptr @tn.str.257, i64 7 }, { ptr, i64 } { ptr @tn.str.258, i64 8 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 18 }, { ptr, i64 } { ptr @tn.str.261, i64 7 }, { ptr, i64 } { ptr @tn.str.262, i64 16 }, { ptr, i64 } { ptr @tn.str.263, i64 10 }, { ptr, i64 } { ptr @tn.str.264, i64 8 }, { ptr, i64 } { ptr @tn.str.265, i64 11 }, { ptr, i64 } { ptr @tn.str.266, i64 14 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 13 }, { ptr, i64 } { ptr @tn.str.269, i64 9 }, { ptr, i64 } { ptr @tn.str.270, i64 8 }, { ptr, i64 } { ptr @tn.str.271, i64 10 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.286, i64 12 }, { ptr, i64 } { ptr @tn.str.287, i64 7 }, { ptr, i64 } { ptr @tn.str.288, i64 6 }, { ptr, i64 } { ptr @tn.str.289, i64 10 }, { ptr, i64 } { ptr @tn.str.290, i64 19 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 4 }, { ptr, i64 } { ptr @tn.str.293, i64 5 }, { ptr, i64 } { ptr @tn.str.294, i64 10 }, { ptr, i64 } { ptr @tn.str.295, i64 5 }, { ptr, i64 } { ptr @tn.str.296, i64 9 }, { ptr, i64 } { ptr @tn.str.297, i64 7 }, { ptr, i64 } { ptr @tn.str.298, i64 10 }, { 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 5 }, { 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 13 }, { ptr, i64 } { ptr @tn.str.307, i64 7 }, { ptr, i64 } { ptr @tn.str.308, i64 8 }, { ptr, i64 } { ptr @tn.str.309, i64 5 }, { ptr, i64 } { ptr @tn.str.310, i64 7 }, { ptr, i64 } { ptr @tn.str.311, i64 6 }, { ptr, i64 } { ptr @tn.str.312, i64 14 }, { ptr, i64 } { ptr @tn.str.313, i64 5 }, { ptr, i64 } { ptr @tn.str.314, i64 5 }, { ptr, i64 } { ptr @tn.str.315, i64 8 }, { ptr, i64 } { ptr @tn.str.316, i64 9 }, { ptr, i64 } { ptr @tn.str.317, i64 9 }, { ptr, i64 } { ptr @tn.str.318, i64 19 }, { ptr, i64 } { ptr @tn.str.319, i64 6 }, { ptr, i64 } { ptr @tn.str.320, i64 8 }, { ptr, i64 } { ptr @tn.str.321, i64 15 }, { ptr, i64 } { ptr @tn.str.322, i64 8 }, { ptr, i64 } { ptr @tn.str.323, i64 5 }] @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 [22 x i8] c"=== Direct calls ===\0A\00", align 1 -@str.344 = 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 [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 [1 x i8] zeroinitializer, align 1 +@str.346 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.347 = private unnamed_addr constant [22 x i8] c"=== Direct calls ===\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.349 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.350 = private unnamed_addr constant [9 x i8] c"d1 = {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.352 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.353 = private unnamed_addr constant [9 x i8] c"d2 = {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.355 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.356 = private unnamed_addr constant [9 x i8] c"d3 = {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.358 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.359 = private unnamed_addr constant [9 x i8] c"d4 = {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.361 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.362 = private unnamed_addr constant [27 x i8] c"=== Protocol dispatch ===\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.364 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.365 = private unnamed_addr constant [9 x i8] c"r1 = {}\0A\00", 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 [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"r2 = {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.370 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.371 = private unnamed_addr constant [9 x i8] c"r3 = {}\0A\00", 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 +@str.373 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.374 = private unnamed_addr constant [9 x i8] c"r4 = {}\0A\00", align 1 +@str.375 = private unnamed_addr constant [16 x i8] c"Source_Location\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 = private constant [5 x i8] c"file\00" -@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 }] +@fld.str.379 = private constant [5 x i8] c"line\00" +@fld.str.380 = private constant [4 x i8] c"col\00" +@fld.str.381 = 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.379, i64 4 }, { ptr, i64 } { ptr @fld.str.380, i64 3 }, { ptr, i64 } { ptr @fld.str.381, i64 4 }] +@str.382 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.383 = private unnamed_addr constant [10 x i8] c"Allocator\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"ctx\00" +@fld.str.388 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.389 = private constant [14 x i8] c"dealloc_bytes\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 11 }, { ptr, i64 } { ptr @fld.str.389, i64 13 }] +@str.391 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.392 = private unnamed_addr constant [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.397 = private constant [5 x i8] c"data\00" +@field_names.398 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.396, i64 9 }, { ptr, i64 } { ptr @fld.str.397, i64 4 }] +@str.399 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.400 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.404 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.405 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.406 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.411 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.410, i64 11 }] +@str.412 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.413 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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"next\00" +@fld.str.418 = private constant [4 x i8] c"cap\00" +@field_names.419 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.417, i64 4 }, { ptr, i64 } { ptr @fld.str.418, i64 3 }] +@str.420 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.421 = private unnamed_addr constant [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.426 = private constant [10 x i8] c"end_index\00" +@fld.str.427 = private constant [7 x i8] c"parent\00" +@field_names.428 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.425, i64 5 }, { 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"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.435 = private constant [4 x i8] c"len\00" +@fld.str.436 = private constant [4 x i8] c"pos\00" +@field_names.437 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.434, i64 3 }, { ptr, i64 } { ptr @fld.str.435, i64 3 }, { ptr, i64 } { ptr @fld.str.436, i64 3 }] @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.439 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.443 = private constant [7 x i8] c"parent\00" +@fld.str.444 = private constant [12 x i8] c"alloc_count\00" +@fld.str.445 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.446 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.447 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.443, i64 6 }, { ptr, i64 } { ptr @fld.str.444, i64 11 }, { ptr, i64 } { ptr @fld.str.445, i64 13 }, { ptr, i64 } { ptr @fld.str.446, i64 17 }] +@str.448 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.449 = private unnamed_addr constant [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.454 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.453, i64 2 }] +@str.455 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.456 = private unnamed_addr constant [11 x i8] c"TraceFrame\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 [5 x i8] c"file\00" +@fld.str.461 = private constant [5 x i8] c"line\00" +@fld.str.462 = private constant [4 x i8] c"col\00" +@fld.str.463 = private constant [5 x i8] c"func\00" +@fld.str.464 = private constant [10 x i8] c"line_text\00" +@field_names.465 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.460, i64 4 }, { ptr, i64 } { ptr @fld.str.461, i64 4 }, { ptr, i64 } { ptr @fld.str.462, i64 3 }, { ptr, i64 } { ptr @fld.str.463, i64 4 }, { ptr, i64 } { ptr @fld.str.464, i64 9 }] +@str.466 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.467 = private unnamed_addr constant [14 x i8] c"ProcessResult\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 [10 x i8] c"exit_code\00" +@fld.str.472 = private constant [7 x i8] c"stdout\00" +@field_names.473 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.471, i64 9 }, { ptr, i64 } { ptr @fld.str.472, i64 6 }] +@str.474 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.475 = private unnamed_addr constant [9 x i8] c"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.480 = private constant [11 x i8] c"sin_family\00" +@fld.str.481 = private constant [9 x i8] c"sin_port\00" +@fld.str.482 = private constant [9 x i8] c"sin_addr\00" +@fld.str.483 = private constant [9 x i8] c"sin_zero\00" +@field_names.484 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.479, i64 7 }, { ptr, i64 } { ptr @fld.str.480, i64 10 }, { ptr, i64 } { ptr @fld.str.481, i64 8 }, { ptr, i64 } { ptr @fld.str.482, i64 8 }, { ptr, i64 } { ptr @fld.str.483, i64 8 }] +@str.485 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.486 = private unnamed_addr constant [6 x i8] c"Array\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 [6 x i8] c"items\00" +@fld.str.491 = private constant [4 x i8] c"len\00" +@fld.str.492 = private constant [4 x i8] c"cap\00" +@field_names.493 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.490, i64 5 }, { ptr, i64 } { ptr @fld.str.491, i64 3 }, { ptr, i64 } { ptr @fld.str.492, i64 3 }] +@str.494 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.495 = private unnamed_addr constant [7 x i8] c"Object\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 [6 x i8] c"items\00" +@fld.str.500 = private constant [4 x i8] c"len\00" +@fld.str.501 = private constant [4 x i8] c"cap\00" +@field_names.502 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.499, i64 5 }, { ptr, i64 } { ptr @fld.str.500, i64 3 }, { ptr, i64 } { ptr @fld.str.501, i64 3 }] +@str.503 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.504 = private unnamed_addr constant [7 x i8] c"Member\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 [4 x i8] c"key\00" +@fld.str.509 = private constant [4 x i8] c"val\00" +@field_names.510 = private constant [2 x { ptr, i64 }] [{ 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 [5 x i8] c"Sink\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 [4 x i8] c"dst\00" +@fld.str.517 = private constant [4 x i8] c"pos\00" +@fld.str.518 = private constant [5 x i8] c"file\00" +@field_names.519 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.516, i64 3 }, { ptr, i64 } { ptr @fld.str.517, i64 3 }, { ptr, i64 } { ptr @fld.str.518, i64 4 }] +@str.520 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.521 = private unnamed_addr constant [7 x i8] c"Parser\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"src\00" +@fld.str.526 = private constant [4 x i8] c"pos\00" +@fld.str.527 = private constant [6 x i8] c"alloc\00" +@field_names.528 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.525, i64 3 }, { 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 [13 x i8] c"BuildOptions\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 +@field_names.534 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.535 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.536 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.541 = private constant [12 x i8] c"takes_value\00" +@fld.str.542 = private constant [9 x i8] c"required\00" +@field_names.543 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.540, i64 4 }, { ptr, i64 } { ptr @fld.str.541, i64 11 }, { ptr, i64 } { ptr @fld.str.542, i64 8 }] +@str.544 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.545 = private unnamed_addr constant [8 x i8] c"Command\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 [6 x i8] c"flags\00" +@field_names.552 = private constant [3 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 5 }] +@str.553 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.554 = private unnamed_addr constant [10 x i8] c"FlagValue\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 [4 x i8] c"set\00" +@fld.str.559 = private constant [6 x i8] c"value\00" +@field_names.560 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.558, i64 3 }, { ptr, i64 } { ptr @fld.str.559, i64 5 }] +@str.561 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.562 = private unnamed_addr constant [5 x i8] c"Diag\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"index\00" +@fld.str.567 = private constant [6 x i8] c"token\00" +@field_names.568 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.566, i64 5 }, { ptr, i64 } { ptr @fld.str.567, i64 5 }] +@str.569 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.570 = private unnamed_addr constant [7 x i8] c"Parsed\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 [6 x i8] c"group\00" +@fld.str.575 = private constant [8 x i8] c"command\00" +@fld.str.576 = private constant [10 x i8] c"cmd_index\00" +@fld.str.577 = private constant [5 x i8] c"json\00" +@fld.str.578 = private constant [5 x i8] c"rest\00" +@fld.str.579 = private constant [5 x i8] c"spec\00" +@fld.str.580 = private constant [7 x i8] c"values\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 7 }, { ptr, i64 } { ptr @fld.str.576, i64 9 }, { ptr, i64 } { ptr @fld.str.577, i64 4 }, { ptr, i64 } { ptr @fld.str.578, i64 4 }, { ptr, i64 } { ptr @fld.str.579, i64 4 }, { ptr, i64 } { ptr @fld.str.580, i64 6 }] +@str.582 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.583 = private unnamed_addr constant [7 x i8] c"Sha256\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 [2 x i8] c"h\00" +@fld.str.588 = private constant [4 x i8] c"buf\00" +@fld.str.589 = private constant [8 x i8] c"buf_len\00" +@fld.str.590 = private constant [10 x i8] c"total_len\00" +@field_names.591 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.587, i64 1 }, { ptr, i64 } { ptr @fld.str.588, i64 3 }, { ptr, i64 } { ptr @fld.str.589, i64 7 }, { ptr, i64 } { ptr @fld.str.590, i64 9 }] +@str.592 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.593 = private unnamed_addr constant [13 x i8] c"ProposedSize\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 +@fld.str.597 = private constant [6 x i8] c"width\00" +@fld.str.598 = private constant [7 x i8] c"height\00" +@field_names.599 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.597, i64 5 }, { ptr, i64 } { ptr @fld.str.598, i64 6 }] +@str.600 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.601 = private unnamed_addr constant [8 x i8] c"Sizable\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 +@fld.str.605 = private constant [4 x i8] c"ctx\00" +@fld.str.606 = private constant [9 x i8] c"__vtable\00" +@field_names.607 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.605, i64 3 }, { ptr, i64 } { ptr @fld.str.606, i64 8 }] +@str.608 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.609 = private unnamed_addr constant [18 x i8] c"__Sizable__Vtable\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 [5 x i8] c"size\00" +@field_names.614 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.613, i64 4 }] +@str.615 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.616 = private unnamed_addr constant [7 x i8] c"Widget\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 [2 x i8] c".\00", align 1 +@fld.str.623 = private constant [5 x i8] c"read\00" +@fld.str.624 = private constant [6 x i8] c"write\00" +@fld.str.625 = private constant [7 x i8] c"append\00" +@fld.str.626 = private constant [11 x i8] c"read_write\00" +@field_names.627 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.623, i64 4 }, { ptr, i64 } { ptr @fld.str.624, i64 5 }, { ptr, i64 } { ptr @fld.str.625, i64 6 }, { ptr, i64 } { ptr @fld.str.626, i64 10 }] +@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 [4 x i8] c"set\00" +@fld.str.632 = private constant [8 x i8] c"current\00" +@fld.str.633 = private constant [4 x i8] c"end\00" +@field_names.634 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.631, i64 3 }, { ptr, i64 } { ptr @fld.str.632, i64 7 }, { ptr, i64 } { ptr @fld.str.633, i64 3 }] +@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"null_\00" +@fld.str.639 = private constant [6 x i8] c"bool_\00" +@fld.str.640 = private constant [5 x i8] c"int_\00" +@fld.str.641 = private constant [4 x i8] c"str\00" +@fld.str.642 = private constant [6 x i8] c"array\00" +@fld.str.643 = private constant [7 x i8] c"object\00" +@field_names.644 = private constant [6 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 4 }, { ptr, i64 } { ptr @fld.str.641, i64 3 }, { ptr, i64 } { ptr @fld.str.642, i64 5 }, { ptr, i64 } { ptr @fld.str.643, i64 6 }] +@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"macos\00" +@fld.str.649 = private constant [6 x i8] c"linux\00" +@fld.str.650 = private constant [8 x i8] c"windows\00" +@fld.str.651 = private constant [5 x i8] c"wasm\00" +@fld.str.652 = private constant [4 x i8] c"ios\00" +@fld.str.653 = private constant [8 x i8] c"android\00" +@fld.str.654 = private constant [8 x i8] c"unknown\00" +@field_names.655 = private constant [7 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 7 }, { ptr, i64 } { ptr @fld.str.651, i64 4 }, { ptr, i64 } { ptr @fld.str.652, i64 3 }, { ptr, i64 } { ptr @fld.str.653, i64 7 }, { 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 +@fld.str.659 = private constant [8 x i8] c"aarch64\00" +@fld.str.660 = private constant [7 x i8] c"x86_64\00" +@fld.str.661 = private constant [7 x i8] c"wasm32\00" +@fld.str.662 = private constant [7 x i8] c"wasm64\00" +@fld.str.663 = private constant [8 x i8] c"unknown\00" +@field_names.664 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.659, i64 7 }, { ptr, i64 } { ptr @fld.str.660, i64 6 }, { ptr, i64 } { ptr @fld.str.661, i64 6 }, { ptr, i64 } { ptr @fld.str.662, i64 6 }, { ptr, i64 } { ptr @fld.str.663, i64 7 }] +@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 [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 [8 x i8] c"*Widget\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 [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 [5 x i8] c"*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 [6 x i8] c"*bool\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 [14 x i8] c"*ProposedSize\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"*f32\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 [5 x i8] c"*f64\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 [8 x i8] c"*[1]Any\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"*Sizable\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 [9 x i8] c"**Widget\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 [19 x i8] c"*__Sizable__Vtable\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 +@str.815 = private unnamed_addr constant [5 x i8] c"null\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -709,85 +709,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -930,7 +852,7 @@ entry: br i1 %icmp, label %if.then.68, label %if.merge.69 if.then.68: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.69: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1057,7 +979,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.128, i64 4 }, %if.then.90 ], [ { ptr @str.129, i64 5 }, %if.else.91 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.90 ], [ { ptr @str.131, i64 5 }, %if.else.91 ] ret { ptr, i64 } %bp } @@ -1391,7 +1313,7 @@ entry: br i1 %icmp, label %if.then.411, label %if.merge.412 if.then.411: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.412: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1541,7 +1463,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1568,12 +1490,12 @@ entry: i64 19, label %match.arm.55 i64 20, 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 24, label %match.arm.55 + i64 26, label %match.arm.55 + i64 28, label %match.arm.55 i64 30, label %match.arm.55 - i64 32, label %match.arm.55 - i64 34, label %match.arm.55 + i64 33, label %match.arm.55 + i64 35, label %match.arm.55 i64 39, label %match.arm.55 i64 43, label %match.arm.55 i64 45, label %match.arm.55 @@ -1602,25 +1524,25 @@ entry: i64 51, label %match.arm.57 i64 64, label %match.arm.57 i64 75, label %match.arm.57 - i64 35, label %match.arm.59 + i64 22, label %match.arm.59 i64 81, label %match.arm.59 i64 87, label %match.arm.59 i64 88, label %match.arm.59 i64 92, label %match.arm.59 i64 109, label %match.arm.59 - i64 36, label %match.arm.60 + i64 23, label %match.arm.60 i64 60, label %match.arm.60 i64 77, label %match.arm.60 i64 85, label %match.arm.60 i64 102, label %match.arm.60 i64 18, 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 25, label %match.arm.61 + i64 27, label %match.arm.61 i64 29, label %match.arm.61 i64 31, label %match.arm.61 - i64 33, label %match.arm.61 + i64 32, label %match.arm.61 + i64 34, label %match.arm.61 + i64 36, label %match.arm.61 i64 40, label %match.arm.61 i64 44, label %match.arm.61 i64 47, label %match.arm.61 @@ -1663,7 +1585,7 @@ match.merge.49: ; preds = %dispatch.merge.532, ret { ptr, i64 } %loadN match.arm.50: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1708,12 +1630,12 @@ match.arm.55: ; preds = %entry, %entry, %ent i64 19, label %dispatch.case.108 i64 20, label %dispatch.case.109 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 24, label %dispatch.case.111 + i64 26, label %dispatch.case.112 + i64 28, label %dispatch.case.113 i64 30, label %dispatch.case.114 - i64 32, label %dispatch.case.115 - i64 34, label %dispatch.case.116 + i64 33, label %dispatch.case.115 + i64 35, label %dispatch.case.116 i64 39, label %dispatch.case.117 i64 43, label %dispatch.case.118 i64 45, label %dispatch.case.119 @@ -1768,7 +1690,7 @@ match.arm.59: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.300 [ - i64 35, label %dispatch.case.301 + i64 22, label %dispatch.case.301 i64 81, label %dispatch.case.302 i64 87, label %dispatch.case.303 i64 88, label %dispatch.case.304 @@ -1781,7 +1703,7 @@ match.arm.60: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.338 [ - i64 36, label %dispatch.case.339 + i64 23, label %dispatch.case.339 i64 60, label %dispatch.case.340 i64 77, label %dispatch.case.341 i64 85, label %dispatch.case.342 @@ -1794,13 +1716,13 @@ 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 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 - i64 33, label %dispatch.case.378 + i64 25, label %dispatch.case.372 + i64 27, label %dispatch.case.373 + i64 29, label %dispatch.case.374 + i64 31, label %dispatch.case.375 + i64 32, label %dispatch.case.376 + i64 34, label %dispatch.case.377 + i64 36, label %dispatch.case.378 i64 40, label %dispatch.case.379 i64 44, label %dispatch.case.380 i64 47, label %dispatch.case.381 @@ -1901,7 +1823,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.322, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.324, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.108: ; preds = %match.arm.55 @@ -1923,56 +1845,56 @@ dispatch.case.109: ; preds = %match.arm.55 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 {}, ptr %ua.ptr69, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) + %ua.load70 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %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 { 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.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, 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.106 dispatch.case.113: ; preds = %match.arm.55 %ua.raw80 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr81 = inttoptr i64 %ua.raw80 to ptr - %ua.load82 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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.106 dispatch.case.114: ; preds = %match.arm.55 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.115: ; preds = %match.arm.55 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.116: ; preds = %match.arm.55 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 @@ -2142,7 +2064,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.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.56 @@ -2183,7 +2105,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.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.59 @@ -2240,7 +2162,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.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.60 @@ -2289,7 +2211,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.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.61 @@ -2557,7 +2479,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.327, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.329, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.532 dispatch.case.534: ; preds = %match.arm.62 @@ -2607,7 +2529,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 @@ -2703,7 +2625,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 @@ -2711,7 +2633,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 @@ -2721,13 +2643,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 @@ -2735,7 +2657,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 @@ -2749,7 +2671,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 @@ -2757,7 +2679,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 @@ -2768,7 +2690,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 @@ -2825,7 +2747,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 @@ -2833,7 +2755,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 @@ -2844,7 +2766,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 @@ -2864,7 +2786,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 @@ -2872,7 +2794,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 @@ -2883,7 +2805,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 @@ -2893,67 +2815,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3129,166 +3135,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3486,64 +3492,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3573,97 +3579,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3702,7 +3708,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal float @direct_size(ptr %0, { { float, i1 }, { float, i1 } } %1) #0 { @@ -3903,14 +3909,14 @@ entry: define internal void @print__ct_safaf8808e13137c9__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.343, i64 21 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.345, 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.344, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.346, 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) @@ -3926,7 +3932,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.345, i64 21 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.347, i64 21 }) ret { ptr, i64 } %call } @@ -3934,7 +3940,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.346, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.348, 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 @@ -3951,7 +3957,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 5) @@ -3980,7 +3986,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.348, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.350, i64 8 }) ret { ptr, i64 } %call } @@ -3988,7 +3994,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.349, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.351, 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 @@ -4005,7 +4011,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.350, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.352, 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) @@ -4034,7 +4040,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.351, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.353, i64 8 }) ret { ptr, i64 } %call } @@ -4042,7 +4048,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.352, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.354, 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 @@ -4059,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.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 5) @@ -4088,7 +4094,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.354, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.356, i64 8 }) ret { ptr, i64 } %call } @@ -4096,7 +4102,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.355, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.357, 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 @@ -4113,7 +4119,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 5) @@ -4142,7 +4148,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.357, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.359, i64 8 }) ret { ptr, i64 } %call } @@ -4150,14 +4156,14 @@ entry: define internal void @print__ct_s1982bb0332b7dace__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.358, i64 26 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.360, 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.359, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.361, 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) @@ -4173,7 +4179,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.360, i64 26 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.362, i64 26 }) ret { ptr, i64 } %call } @@ -4188,7 +4194,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.361, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.363, 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 @@ -4205,7 +4211,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 5) @@ -4234,7 +4240,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.363, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.365, i64 8 }) ret { ptr, i64 } %call } @@ -4242,7 +4248,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.364, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.366, 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 @@ -4259,7 +4265,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) @@ -4288,7 +4294,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.366, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.368, i64 8 }) ret { ptr, i64 } %call } @@ -4296,7 +4302,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.367, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.369, 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 @@ -4313,7 +4319,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 5) @@ -4342,7 +4348,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.369, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.371, i64 8 }) ret { ptr, i64 } %call } @@ -4350,7 +4356,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.370, i64 8 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.372, 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 @@ -4367,7 +4373,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 5) @@ -4396,7 +4402,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.372, i64 8 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.374, i64 8 }) ret { ptr, i64 } %call } @@ -4407,7 +4413,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.373, i64 15 }, { ptr, i64 } { ptr @str.374, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.375, i64 15 }, { 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 @@ -4426,12 +4432,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.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.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.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.141 @@ -4443,7 +4449,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.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 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4500,7 +4506,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.381, i64 9 }, { ptr, i64 } { ptr @str.382, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.383, i64 9 }, { 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 @@ -4519,24 +4525,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.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.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.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.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.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, ptr, ptr }, ptr %alloca, align 8 @@ -4580,20 +4586,21 @@ fv.case21: ; preds = %if.merge.146 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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.390, i64 10 }, { ptr, i64 } { ptr @str.391, i64 1 }) + %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.392, i64 7 }, { 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.147 -while.hdr.147: ; preds = %if.merge.151, %entry +while.hdr.147: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 2 br i1 %icmp, label %while.body.148, label %while.exit.149 while.body.148: ; preds = %while.hdr.147 @@ -4603,24 +4610,102 @@ 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.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.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 }) + %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.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.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.395, 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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.147 + +fv.default: ; preds = %if.merge.151 + br label %fv.merge + +fv.case: ; preds = %if.merge.151 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.151 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.400, i64 10 }, { 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.152 + +while.hdr.152: ; preds = %if.merge.156, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + 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.402, 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.403, 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 [0 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.405, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -4631,7 +4716,7 @@ if.merge.151: ; preds = %if.then.150, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.147 + br label %while.hdr.152 } ; Function Attrs: nounwind @@ -4639,43 +4724,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.406, i64 3 }, { 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 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.152 + br label %while.hdr.157 -while.hdr.152: ; preds = %fv.merge, %entry +while.hdr.157: ; 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 + br i1 %icmp, label %while.body.158, label %while.exit.159 -while.body.153: ; preds = %while.hdr.152 +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.155, label %if.merge.156 + br i1 %icmpN, label %if.then.160, label %if.merge.161 -while.exit.154: ; preds = %while.hdr.152 +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.398, 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.155: ; preds = %while.body.153 +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.399, 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.156 + br label %if.merge.161 -if.merge.156: ; preds = %if.then.155, %while.body.153 +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 [1 x { ptr, i64 }], ptr @field_names.401, 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.402, 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 { i64 }, ptr %alloca, align 8 @@ -4692,12 +4777,12 @@ 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.152 + br label %while.hdr.157 -fv.default: ; preds = %if.merge.156 +fv.default: ; preds = %if.merge.161 br label %fv.merge -fv.case: ; preds = %if.merge.156 +fv.case: ; preds = %if.merge.161 %fv.field = extractvalue { i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge @@ -4708,43 +4793,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %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 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.157 + br label %while.hdr.162 -while.hdr.157: ; preds = %fv.merge, %entry +while.hdr.162: ; 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 + br i1 %icmp, label %while.body.163, label %while.exit.164 -while.body.158: ; preds = %while.hdr.157 +while.body.163: ; preds = %while.hdr.162 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.160, label %if.merge.161 + br i1 %icmpN, label %if.then.165, label %if.merge.166 -while.exit.159: ; preds = %while.hdr.157 +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.405, 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.160: ; preds = %while.body.158 +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.406, 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.161 + br label %if.merge.166 -if.merge.161: ; preds = %if.then.160, %while.body.158 +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.409, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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.410, 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 { ptr, i64 }, ptr %alloca, align 8 @@ -4762,18 +4847,18 @@ 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.157 + br label %while.hdr.162 -fv.default: ; preds = %if.merge.161 +fv.default: ; preds = %if.merge.166 br label %fv.merge -fv.case: ; preds = %if.merge.161 +fv.case: ; preds = %if.merge.166 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.161 +fv.case17: ; preds = %if.merge.166 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -4785,91 +4870,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.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 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.162 - -while.hdr.162: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.163, label %while.exit.164 - -while.body.163: ; preds = %while.hdr.162 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.165, label %if.merge.166 - -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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.162 - -fv.default: ; preds = %if.merge.166 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.166 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.420, i64 8 }, { ptr, i64 } { ptr @str.421, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.421, i64 5 }, { 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 @@ -4888,27 +4889,27 @@ 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.422, 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.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.423, 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.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.427, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.428, 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, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4930,29 +4931,30 @@ fv.default: ; preds = %if.merge.171 br label %fv.merge fv.case: ; preds = %if.merge.171 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.171 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.171 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.429, i64 17 }, { ptr, i64 } { ptr @str.430, i64 1 }) + %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.430, i64 8 }, { 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 @@ -4961,7 +4963,7 @@ entry: while.hdr.172: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.173, label %while.exit.174 while.body.173: ; preds = %while.hdr.172 @@ -4971,19 +4973,19 @@ 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.431, 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.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.432, 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.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.437, 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 @@ -4991,17 +4993,16 @@ if.merge.176: ; preds = %if.then.175, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -5014,35 +5015,29 @@ fv.default: ; preds = %if.merge.176 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.176 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.176 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.176 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.439, i64 7 }, { ptr, i64 } { ptr @str.440, i64 1 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.439, i64 17 }, { 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 @@ -5051,7 +5046,7 @@ entry: while.hdr.177: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.178, label %while.exit.179 while.body.178: ; preds = %while.hdr.177 @@ -5073,23 +5068,25 @@ if.then.180: ; preds = %while.body.178 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.445, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -5102,16 +5099,25 @@ fv.default: ; preds = %if.merge.181 br label %fv.merge fv.case: ; preds = %if.merge.181 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.181 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.181 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.181 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -5120,7 +5126,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.447, i64 4 }, { ptr, i64 } { ptr @str.448, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.449, i64 4 }, { 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 @@ -5139,24 +5145,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.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.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.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.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.452, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i32 }, ptr %alloca, align 4 @@ -5193,7 +5199,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.454, i64 10 }, { ptr, i64 } { ptr @str.455, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.456, i64 10 }, { 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 @@ -5212,24 +5218,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.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.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.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.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.463, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5295,7 +5301,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.465, i64 13 }, { ptr, i64 } { ptr @str.466, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.467, i64 13 }, { 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 @@ -5314,24 +5320,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.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.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.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.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.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 { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5373,7 +5379,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.473, i64 8 }, { ptr, i64 } { ptr @str.474, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.475, i64 8 }, { 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 @@ -5392,24 +5398,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.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.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.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.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.482, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -5470,7 +5476,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.484, i64 5 }, { ptr, i64 } { ptr @str.485, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.486, i64 5 }, { 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 @@ -5489,24 +5495,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.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.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.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.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.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 %alloca, align 8 @@ -5552,7 +5558,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.493, i64 6 }, { ptr, i64 } { ptr @str.494, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.495, i64 6 }, { 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 @@ -5571,24 +5577,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.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.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.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.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.500, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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, i64, i64 }, ptr %alloca, align 8 @@ -5636,7 +5642,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.502, i64 6 }, { ptr, i64 } { ptr @str.503, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.504, i64 6 }, { 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 @@ -5655,24 +5661,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.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.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.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.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.508, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, [24 x i8] } }, ptr %alloca, align 8 @@ -5716,7 +5722,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.510, i64 4 }, { ptr, i64 } { ptr @str.511, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.512, i64 4 }, { 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 @@ -5735,24 +5741,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.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.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.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.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.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 }, ptr %alloca, align 8 @@ -5802,7 +5808,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.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 @@ -5821,24 +5827,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.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.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.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.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.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 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5887,7 +5893,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.528, i64 12 }, { ptr, i64 } { ptr @str.529, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.530, i64 12 }, { 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 @@ -5906,24 +5912,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.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.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.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.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.532, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 %alloca, align 1 @@ -5943,7 +5949,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.534, i64 8 }, { ptr, i64 } { ptr @str.535, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.536, i64 8 }, { 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 @@ -5962,24 +5968,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.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.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.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.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.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 }, i1, i1 }, ptr %alloca, align 8 @@ -6031,7 +6037,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.543, i64 7 }, { ptr, i64 } { ptr @str.544, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.545, i64 7 }, { 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 @@ -6050,24 +6056,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.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.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.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.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.550, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -6119,7 +6125,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.552, i64 9 }, { ptr, i64 } { ptr @str.553, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.554, i64 9 }, { 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 @@ -6138,24 +6144,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.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.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.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.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.558, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -6198,7 +6204,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.560, i64 4 }, { ptr, i64 } { ptr @str.561, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.562, i64 4 }, { 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 @@ -6217,24 +6223,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.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.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.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.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.566, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -6280,7 +6286,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.568, i64 6 }, { ptr, i64 } { ptr @str.569, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.570, i64 6 }, { 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 @@ -6299,24 +6305,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 [7 x { ptr, i64 }], ptr @field_names.579, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.581, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %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 @@ -6373,7 +6379,7 @@ fv.case28: ; preds = %if.merge.256 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.256 @@ -6398,7 +6404,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.581, i64 6 }, { ptr, i64 } { ptr @str.582, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.583, i64 6 }, { ptr, i64 } { ptr @str.584, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6417,24 +6423,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.583, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.585, 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.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 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.589, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.591, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.590, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.592, 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 @@ -6491,7 +6497,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.591, i64 12 }, { ptr, i64 } { ptr @str.592, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.593, i64 12 }, { ptr, i64 } { ptr @str.594, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6510,24 +6516,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.593, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.595, 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.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.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.597, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.599, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { float, i1 }, { float, i1 } }, ptr %alloca, align 4 @@ -6570,7 +6576,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.599, i64 7 }, { ptr, i64 } { ptr @str.600, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.601, i64 7 }, { ptr, i64 } { ptr @str.602, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6589,24 +6595,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.601, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.603, 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.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 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.605, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.607, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr }, ptr %alloca, align 8 @@ -6647,7 +6653,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.607, i64 17 }, { ptr, i64 } { ptr @str.608, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.609, i64 17 }, { ptr, i64 } { ptr @str.610, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6666,24 +6672,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.609, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.611, 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.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.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.612, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 }, ptr %alloca, align 8 @@ -6717,7 +6723,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.614, i64 6 }, { ptr, i64 } { ptr @str.615, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.616, i64 6 }, { 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 @@ -6736,24 +6742,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.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.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.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.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.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 @@ -6776,9 +6782,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.625, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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.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 @@ -6797,8 +6803,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.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.290 @@ -6817,9 +6823,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.632, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.634, 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, ptr %alloca, align 8 @@ -6838,8 +6844,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.292 @@ -6869,9 +6875,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.642, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 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.635, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, 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 @@ -6888,8 +6894,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.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.294 @@ -6967,9 +6973,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.653, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.655, 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, ptr %alloca, align 8 @@ -6988,8 +6994,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.296 @@ -7008,9 +7014,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.662, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.664, 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.656, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, 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 @@ -7029,8 +7035,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.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 } { ptr @str.666, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.665, 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 @@ -7047,7 +7053,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.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.307 @@ -7064,12 +7070,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.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.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.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.311 @@ -7098,7 +7104,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.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.312 @@ -7115,12 +7121,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.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.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.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.316 @@ -7150,7 +7156,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.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.317 @@ -7167,12 +7173,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.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.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.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.321 @@ -7200,7 +7206,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.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.322 @@ -7217,12 +7223,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.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.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.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.326 @@ -7251,7 +7257,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.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.327 @@ -7268,12 +7274,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.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.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.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.331 @@ -7302,7 +7308,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.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.332 @@ -7319,12 +7325,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.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.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.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.336 @@ -7354,7 +7360,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.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.344 @@ -7373,12 +7379,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.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.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.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.348 @@ -7407,7 +7413,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.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.349 @@ -7426,12 +7432,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.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.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.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.353 @@ -7460,7 +7466,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.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.354 @@ -7479,12 +7485,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.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.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.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.358 @@ -7514,7 +7520,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.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.359 @@ -7533,12 +7539,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.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.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.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.363 @@ -7568,7 +7574,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.364 @@ -7587,12 +7593,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.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.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.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.368 @@ -7634,12 +7640,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.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.410 if.merge.410: ; preds = %if.else.409, %if.then.408 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] ret { ptr, i64 } %bp } @@ -7662,12 +7668,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.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.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7690,12 +7696,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.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.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7718,12 +7724,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.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.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7746,12 +7752,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.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.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7773,12 +7779,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.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.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7801,12 +7807,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.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.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7829,12 +7835,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.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.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7857,12 +7863,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.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.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7885,12 +7891,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.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.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7913,12 +7919,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.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.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7941,12 +7947,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.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.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.733, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7969,12 +7975,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.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.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.734, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.736, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7996,12 +8002,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.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.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.737, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.739, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -8024,12 +8030,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.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.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.740, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.742, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -8051,12 +8057,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.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.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.743, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.745, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -8079,12 +8085,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.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.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.746, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.748, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -8107,12 +8113,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.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.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.749, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.751, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -8135,12 +8141,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.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.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.752, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.754, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -8163,12 +8169,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.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.480 if.merge.480: ; preds = %if.else.479, %if.then.478 - %bp = phi { ptr, i64 } [ { ptr @str.755, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] + %bp = phi { ptr, i64 } [ { ptr @str.757, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] ret { ptr, i64 } %bp } @@ -8191,12 +8197,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.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.483 if.merge.483: ; preds = %if.else.482, %if.then.481 - %bp = phi { ptr, i64 } [ { ptr @str.758, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] + %bp = phi { ptr, i64 } [ { ptr @str.760, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] ret { ptr, i64 } %bp } @@ -8219,12 +8225,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.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.486 if.merge.486: ; preds = %if.else.485, %if.then.484 - %bp = phi { ptr, i64 } [ { ptr @str.761, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] + %bp = phi { ptr, i64 } [ { ptr @str.763, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] ret { ptr, i64 } %bp } @@ -8247,12 +8253,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.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.489 if.merge.489: ; preds = %if.else.488, %if.then.487 - %bp = phi { ptr, i64 } [ { ptr @str.764, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] + %bp = phi { ptr, i64 } [ { ptr @str.766, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] ret { ptr, i64 } %bp } @@ -8275,12 +8281,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.769, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 7 }, { 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 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.767, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] + %bp = phi { ptr, i64 } [ { ptr @str.769, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] ret { ptr, i64 } %bp } @@ -8303,12 +8309,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.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.495 if.merge.495: ; preds = %if.else.494, %if.then.493 - %bp = phi { ptr, i64 } [ { ptr @str.770, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] + %bp = phi { ptr, i64 } [ { ptr @str.772, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] ret { ptr, i64 } %bp } @@ -8331,12 +8337,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.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.498 if.merge.498: ; preds = %if.else.497, %if.then.496 - %bp = phi { ptr, i64 } [ { ptr @str.773, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] + %bp = phi { ptr, i64 } [ { ptr @str.775, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] ret { ptr, i64 } %bp } @@ -8359,12 +8365,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.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.501 if.merge.501: ; preds = %if.else.500, %if.then.499 - %bp = phi { ptr, i64 } [ { ptr @str.776, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] + %bp = phi { ptr, i64 } [ { ptr @str.778, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] ret { ptr, i64 } %bp } @@ -8387,12 +8393,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.781, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.780, i64 4 }, { 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 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.779, i64 4 }, %if.then.502 ], [ %callN, %if.else.503 ] + %bp = phi { ptr, i64 } [ { ptr @str.781, i64 4 }, %if.then.502 ], [ %callN, %if.else.503 ] ret { ptr, i64 } %bp } @@ -8415,12 +8421,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.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.507 if.merge.507: ; preds = %if.else.506, %if.then.505 - %bp = phi { ptr, i64 } [ { ptr @str.782, i64 4 }, %if.then.505 ], [ %callN, %if.else.506 ] + %bp = phi { ptr, i64 } [ { ptr @str.784, i64 4 }, %if.then.505 ], [ %callN, %if.else.506 ] ret { ptr, i64 } %bp } @@ -8443,12 +8449,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.787, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 5 }, { 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 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.785, i64 4 }, %if.then.508 ], [ %callN, %if.else.509 ] + %bp = phi { ptr, i64 } [ { ptr @str.787, i64 4 }, %if.then.508 ], [ %callN, %if.else.509 ] ret { ptr, i64 } %bp } @@ -8471,12 +8477,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.790, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 13 }, { 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 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.788, i64 4 }, %if.then.511 ], [ %callN, %if.else.512 ] + %bp = phi { ptr, i64 } [ { ptr @str.790, i64 4 }, %if.then.511 ], [ %callN, %if.else.512 ] ret { ptr, i64 } %bp } @@ -8499,12 +8505,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.793, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 4 }, { 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 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.791, i64 4 }, %if.then.514 ], [ %callN, %if.else.515 ] + %bp = phi { ptr, i64 } [ { ptr @str.793, i64 4 }, %if.then.514 ], [ %callN, %if.else.515 ] ret { ptr, i64 } %bp } @@ -8527,12 +8533,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.796, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 4 }, { 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 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.794, i64 4 }, %if.then.517 ], [ %callN, %if.else.518 ] + %bp = phi { ptr, i64 } [ { ptr @str.796, i64 4 }, %if.then.517 ], [ %callN, %if.else.518 ] ret { ptr, i64 } %bp } @@ -8555,12 +8561,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.799, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 7 }, { 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 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.797, i64 4 }, %if.then.520 ], [ %callN, %if.else.521 ] + %bp = phi { ptr, i64 } [ { ptr @str.799, i64 4 }, %if.then.520 ], [ %callN, %if.else.521 ] ret { ptr, i64 } %bp } @@ -8583,12 +8589,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.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.525 if.merge.525: ; preds = %if.else.524, %if.then.523 - %bp = phi { ptr, i64 } [ { ptr @str.800, i64 4 }, %if.then.523 ], [ %callN, %if.else.524 ] + %bp = phi { ptr, i64 } [ { ptr @str.802, i64 4 }, %if.then.523 ], [ %callN, %if.else.524 ] ret { ptr, i64 } %bp } @@ -8611,12 +8617,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.805, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 8 }, { 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 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.803, i64 4 }, %if.then.526 ], [ %callN, %if.else.527 ] + %bp = phi { ptr, i64 } [ { ptr @str.805, i64 4 }, %if.then.526 ], [ %callN, %if.else.527 ] ret { ptr, i64 } %bp } @@ -8639,12 +8645,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.808, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.807, i64 18 }, { 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 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.806, i64 4 }, %if.then.529 ], [ %callN, %if.else.530 ] + %bp = phi { ptr, i64 } [ { ptr @str.808, i64 4 }, %if.then.529 ], [ %callN, %if.else.530 ] ret { ptr, i64 } %bp } @@ -8660,7 +8666,7 @@ entry: br i1 %lnot, label %if.then.539, label %if.merge.540 if.then.539: ; preds = %entry - ret { ptr, i64 } { ptr @str.809, i64 4 } + ret { ptr, i64 } { ptr @str.811, i64 4 } if.merge.540: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8684,7 +8690,7 @@ entry: br i1 %lnot, label %if.then.541, label %if.merge.542 if.then.541: ; preds = %entry - ret { ptr, i64 } { ptr @str.810, i64 4 } + ret { ptr, i64 } { ptr @str.812, i64 4 } if.merge.542: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8708,7 +8714,7 @@ entry: br i1 %lnot, label %if.then.543, label %if.merge.544 if.then.543: ; preds = %entry - ret { ptr, i64 } { ptr @str.811, i64 4 } + ret { ptr, i64 } { ptr @str.813, i64 4 } if.merge.544: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8732,7 +8738,7 @@ entry: br i1 %lnot, label %if.then.545, label %if.merge.546 if.then.545: ; preds = %entry - ret { ptr, i64 } { ptr @str.812, i64 4 } + ret { ptr, i64 } { ptr @str.814, i64 4 } if.merge.546: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 @@ -8755,7 +8761,7 @@ entry: br i1 %lnot, label %if.then.547, label %if.merge.548 if.then.547: ; preds = %entry - ret { ptr, i64 } { ptr @str.813, i64 4 } + ret { ptr, i64 } { ptr @str.815, 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 b525a40..de7bb0d 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }] @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 [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 +@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 [8 x i8] c"Context\00" +@tn.str.169 = private constant [7 x i8] c"[4]s64\00" +@tn.str.170 = private constant [9 x i8] c"[]string\00" +@tn.str.171 = private constant [11 x i8] c"CAllocator\00" +@tn.str.172 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.173 = private constant [4 x i8] c"GPA\00" +@tn.str.174 = private constant [5 x i8] c"*GPA\00" +@tn.str.175 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.176 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.177 = private constant [6 x i8] c"Arena\00" +@tn.str.178 = private constant [7 x i8] c"*Arena\00" +@tn.str.179 = private constant [6 x i8] c"[*]u8\00" +@tn.str.180 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.181 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.182 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.183 = private constant [19 x i8] c"*TrackingAllocator\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 [5 x i8] c"?s64\00" +@tn.str.241 = private constant [6 x i8] c"?bool\00" +@tn.str.242 = private constant [2 x i8] c"S\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"*S\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"**S\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" +@tn.str.311 = private constant [6 x i8] c"*?s64\00" +@tn.str.312 = 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.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 7 }, { ptr, i64 } { ptr @tn.str.169, i64 6 }, { ptr, i64 } { ptr @tn.str.170, i64 8 }, { ptr, i64 } { ptr @tn.str.171, i64 10 }, { ptr, i64 } { ptr @tn.str.172, i64 11 }, { ptr, i64 } { ptr @tn.str.173, i64 3 }, { ptr, i64 } { ptr @tn.str.174, i64 4 }, { ptr, i64 } { ptr @tn.str.175, i64 10 }, { ptr, i64 } { ptr @tn.str.176, i64 11 }, { ptr, i64 } { ptr @tn.str.177, i64 5 }, { ptr, i64 } { ptr @tn.str.178, i64 6 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 8 }, { ptr, i64 } { ptr @tn.str.181, i64 9 }, { ptr, i64 } { ptr @tn.str.182, i64 17 }, { ptr, i64 } { ptr @tn.str.183, i64 18 }, { 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 4 }, { ptr, i64 } { ptr @tn.str.241, i64 5 }, { 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 }, { ptr, i64 } { ptr @tn.str.311, i64 5 }, { ptr, i64 } { ptr @tn.str.312, i64 6 }] @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 [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 [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 [3 x i8] c"hi\00", 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 +@str.336 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.337 = private unnamed_addr constant [4 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 [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 }] +@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 [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.360 = private constant [5 x i8] c"data\00" +@field_names.361 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.359, i64 9 }, { ptr, i64 } { ptr @fld.str.360, i64 4 }] +@str.362 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.363 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.367 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.368 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.369 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.374 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.373, i64 11 }] +@str.375 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.376 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.381 = private constant [4 x i8] c"cap\00" +@field_names.382 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.380, i64 4 }, { ptr, i64 } { ptr @fld.str.381, i64 3 }] +@str.383 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.384 = private unnamed_addr constant [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.389 = private constant [10 x i8] c"end_index\00" +@fld.str.390 = private constant [7 x i8] c"parent\00" +@field_names.391 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.388, i64 5 }, { ptr, i64 } { ptr @fld.str.389, i64 9 }, { ptr, i64 } { ptr @fld.str.390, i64 6 }] +@str.392 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.393 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.398 = private constant [4 x i8] c"len\00" +@fld.str.399 = private constant [4 x i8] c"pos\00" +@field_names.400 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.397, i64 3 }, { ptr, i64 } { ptr @fld.str.398, i64 3 }, { ptr, i64 } { ptr @fld.str.399, i64 3 }] @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.402 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.406 = private constant [7 x i8] c"parent\00" +@fld.str.407 = private constant [12 x i8] c"alloc_count\00" +@fld.str.408 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.409 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.410 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.406, i64 6 }, { ptr, i64 } { ptr @fld.str.407, i64 11 }, { ptr, i64 } { ptr @fld.str.408, i64 13 }, { ptr, i64 } { ptr @fld.str.409, i64 17 }] +@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"S\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 +@str.559 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.560 = private constant [2 x i8] c"a\00" +@fld.str.561 = private constant [2 x i8] c"b\00" +@fld.str.562 = private constant [2 x i8] c"c\00" +@field_names.563 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.560, i64 1 }, { ptr, i64 } { ptr @fld.str.561, i64 1 }, { ptr, i64 } { ptr @fld.str.562, i64 1 }] +@str.564 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.565 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.566 = private constant [5 x i8] c"read\00" +@fld.str.567 = private constant [6 x i8] c"write\00" +@fld.str.568 = private constant [7 x i8] c"append\00" +@fld.str.569 = private constant [11 x i8] c"read_write\00" +@field_names.570 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.566, i64 4 }, { ptr, i64 } { ptr @fld.str.567, i64 5 }, { ptr, i64 } { ptr @fld.str.568, i64 6 }, { ptr, i64 } { ptr @fld.str.569, i64 10 }] +@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 [4 x i8] c"set\00" +@fld.str.575 = private constant [8 x i8] c"current\00" +@fld.str.576 = private constant [4 x i8] c"end\00" +@field_names.577 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.574, i64 3 }, { ptr, i64 } { ptr @fld.str.575, i64 7 }, { ptr, i64 } { ptr @fld.str.576, i64 3 }] +@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"null_\00" +@fld.str.582 = private constant [6 x i8] c"bool_\00" +@fld.str.583 = private constant [5 x i8] c"int_\00" +@fld.str.584 = private constant [4 x i8] c"str\00" +@fld.str.585 = private constant [6 x i8] c"array\00" +@fld.str.586 = private constant [7 x i8] c"object\00" +@field_names.587 = private constant [6 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 4 }, { ptr, i64 } { ptr @fld.str.584, i64 3 }, { ptr, i64 } { ptr @fld.str.585, i64 5 }, { ptr, i64 } { ptr @fld.str.586, i64 6 }] +@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 [6 x i8] c"macos\00" +@fld.str.592 = private constant [6 x i8] c"linux\00" +@fld.str.593 = private constant [8 x i8] c"windows\00" +@fld.str.594 = private constant [5 x i8] c"wasm\00" +@fld.str.595 = private constant [4 x i8] c"ios\00" +@fld.str.596 = private constant [8 x i8] c"android\00" +@fld.str.597 = private constant [8 x i8] c"unknown\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 5 }, { ptr, i64 } { ptr @fld.str.593, i64 7 }, { ptr, i64 } { ptr @fld.str.594, i64 4 }, { ptr, i64 } { ptr @fld.str.595, i64 3 }, { ptr, i64 } { ptr @fld.str.596, i64 7 }, { 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 +@fld.str.602 = private constant [8 x i8] c"aarch64\00" +@fld.str.603 = private constant [7 x i8] c"x86_64\00" +@fld.str.604 = private constant [7 x i8] c"wasm32\00" +@fld.str.605 = private constant [7 x i8] c"wasm64\00" +@fld.str.606 = private constant [8 x i8] c"unknown\00" +@field_names.607 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.602, i64 7 }, { ptr, i64 } { ptr @fld.str.603, i64 6 }, { ptr, i64 } { ptr @fld.str.604, i64 6 }, { ptr, i64 } { ptr @fld.str.605, i64 6 }, { ptr, i64 } { ptr @fld.str.606, i64 7 }] +@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 [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 [3 x i8] c"*S\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"*string\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"*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"*[1]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 [7 x i8] c"*[]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 [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 [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 +@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 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -634,85 +634,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -855,7 +777,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -982,7 +904,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.128, i64 4 }, %if.then.78 ], [ { ptr @str.129, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.78 ], [ { ptr @str.131, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1316,7 +1238,7 @@ entry: br i1 %icmp, label %if.then.375, label %if.merge.376 if.then.375: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.376: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1466,7 +1388,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1493,12 +1415,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1524,25 +1446,25 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 102, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 100, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1580,7 +1502,7 @@ match.merge.37: ; preds = %dispatch.merge.478, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1625,12 +1547,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1682,7 +1604,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.270 [ - i64 35, label %dispatch.case.271 + i64 22, label %dispatch.case.271 i64 81, label %dispatch.case.272 i64 87, label %dispatch.case.273 i64 88, label %dispatch.case.274 @@ -1695,7 +1617,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.308 [ - i64 36, label %dispatch.case.309 + i64 23, label %dispatch.case.309 i64 60, label %dispatch.case.310 i64 77, label %dispatch.case.311 i64 85, label %dispatch.case.312 @@ -1708,13 +1630,13 @@ 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 28, label %dispatch.case.345 - i64 29, label %dispatch.case.346 - i64 31, label %dispatch.case.347 - i64 33, label %dispatch.case.348 + i64 25, label %dispatch.case.342 + i64 27, label %dispatch.case.343 + i64 29, label %dispatch.case.344 + i64 31, label %dispatch.case.345 + i64 32, label %dispatch.case.346 + i64 34, label %dispatch.case.347 + i64 36, label %dispatch.case.348 i64 40, label %dispatch.case.349 i64 44, label %dispatch.case.350 i64 47, label %dispatch.case.351 @@ -1810,7 +1732,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.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 @@ -1832,56 +1754,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2027,7 +1949,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.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.252 dispatch.case.254: ; preds = %match.arm.44 @@ -2068,7 +1990,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.313, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.269 dispatch.case.271: ; preds = %match.arm.47 @@ -2125,7 +2047,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.314, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.316, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.307 dispatch.case.309: ; preds = %match.arm.48 @@ -2174,7 +2096,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.315, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.317, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.339 dispatch.case.341: ; preds = %match.arm.49 @@ -2400,7 +2322,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.316, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.318, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.478 dispatch.case.480: ; preds = %match.arm.50 @@ -2458,7 +2380,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 @@ -2554,7 +2476,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 @@ -2562,7 +2484,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 @@ -2572,13 +2494,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 @@ -2586,7 +2508,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 @@ -2600,7 +2522,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 @@ -2608,7 +2530,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 @@ -2619,7 +2541,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 @@ -2676,7 +2598,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 @@ -2684,7 +2606,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 @@ -2695,7 +2617,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 @@ -2715,7 +2637,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 @@ -2723,7 +2645,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 @@ -2734,7 +2656,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 @@ -2744,67 +2666,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2980,166 +2986,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3337,64 +3343,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3424,97 +3430,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3553,13 +3559,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.126(ptr, i1) #0 +declare void @assert.128(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.332, 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.334, 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 @@ -3587,7 +3593,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.333, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.335, 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 @@ -3605,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.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, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } }, ptr %allocaN, align 8 %ba.tmp9 = alloca { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } }, align 8 @@ -3630,7 +3636,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 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.337, i64 3 }) ret { ptr, i64 } %call } @@ -3641,7 +3647,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 @@ -3660,12 +3666,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.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.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.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.126 @@ -3677,7 +3683,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.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 @@ -3734,7 +3740,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.344, i64 9 }, { ptr, i64 } { ptr @str.345, i64 1 }) + %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 @@ -3753,24 +3759,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.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.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.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.131 if.merge.131: ; preds = %if.then.130, %while.body.128 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.351, 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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -3814,20 +3820,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.353, i64 10 }, { ptr, i64 } { ptr @str.354, i64 1 }) + %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.355, i64 7 }, { 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.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, 2 br i1 %icmp, label %while.body.133, label %while.exit.134 while.body.133: ; preds = %while.hdr.132 @@ -3837,24 +3844,102 @@ 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.355, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, 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 }) + %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.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.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.358, 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 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.132 + +fv.default: ; preds = %if.merge.136 + br label %fv.merge + +fv.case: ; preds = %if.merge.136 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.136 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.363, i64 10 }, { 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.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.365, 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.366, 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.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 %alloca, align 1 @@ -3865,7 +3950,7 @@ if.merge.136: ; preds = %if.then.135, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.132 + br label %while.hdr.137 } ; Function Attrs: nounwind @@ -3873,43 +3958,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.369, i64 3 }, { 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 + br label %while.hdr.142 -while.hdr.137: ; preds = %fv.merge, %entry +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.138, label %while.exit.139 + br i1 %icmp, label %while.body.143, label %while.exit.144 -while.body.138: ; preds = %while.hdr.137 +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.140, label %if.merge.141 + br i1 %icmpN, label %if.then.145, label %if.merge.146 -while.exit.139: ; preds = %while.hdr.137 +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.361, 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.140: ; preds = %while.body.138 +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.362, 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.141 + br label %if.merge.146 -if.merge.141: ; preds = %if.then.140, %while.body.138 +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.364, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.365, i64 2 }) + %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 { i64 }, ptr %alloca, align 8 @@ -3926,12 +4011,12 @@ 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 + br label %while.hdr.142 -fv.default: ; preds = %if.merge.141 +fv.default: ; preds = %if.merge.146 br label %fv.merge -fv.case: ; preds = %if.merge.141 +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 @@ -3942,43 +4027,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.376, i64 10 }, { 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.142 + br label %while.hdr.147 -while.hdr.142: ; preds = %fv.merge, %entry +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.143, label %while.exit.144 + br i1 %icmp, label %while.body.148, label %while.exit.149 -while.body.143: ; preds = %while.hdr.142 +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.145, label %if.merge.146 + br i1 %icmpN, label %if.then.150, label %if.merge.151 -while.exit.144: ; preds = %while.hdr.142 +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.368, 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.145: ; preds = %while.body.143 +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.369, 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.146 + br label %if.merge.151 -if.merge.146: ; preds = %if.then.145, %while.body.143 +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.372, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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.373, 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 %alloca, align 8 @@ -3996,18 +4081,18 @@ 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 + br label %while.hdr.147 -fv.default: ; preds = %if.merge.146 +fv.default: ; preds = %if.merge.151 br label %fv.merge -fv.case: ; preds = %if.merge.146 +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 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.146 +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 @@ -4019,91 +4104,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 }) - %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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.147 - -fv.default: ; preds = %if.merge.151 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.151 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.383, i64 8 }, { ptr, i64 } { ptr @str.384, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.384, i64 5 }, { 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 @@ -4122,27 +4123,27 @@ 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.385, 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.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.386, 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.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.390, 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.391, 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 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4164,29 +4165,30 @@ fv.default: ; preds = %if.merge.156 br label %fv.merge fv.case: ; preds = %if.merge.156 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.156 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.156 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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 }) + %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.393, i64 8 }, { 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 @@ -4195,7 +4197,7 @@ entry: while.hdr.157: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.158, label %while.exit.159 while.body.158: ; preds = %while.hdr.157 @@ -4205,19 +4207,19 @@ 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.394, 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.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.395, 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.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.400, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4225,17 +4227,16 @@ if.merge.161: ; preds = %if.then.160, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4248,35 +4249,29 @@ fv.default: ; preds = %if.merge.161 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.161 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.161 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.161 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.402, i64 17 }, { 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 @@ -4285,7 +4280,7 @@ entry: while.hdr.162: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.163, label %while.exit.164 while.body.163: ; preds = %while.hdr.162 @@ -4307,23 +4302,25 @@ if.then.165: ; preds = %while.body.163 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.408, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4336,16 +4333,25 @@ fv.default: ; preds = %if.merge.166 br label %fv.merge fv.case: ; preds = %if.merge.166 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.166 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.166 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.166 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4354,7 +4360,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 @@ -4373,24 +4379,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.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.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.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.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.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 @@ -4427,7 +4433,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 @@ -4446,24 +4452,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 [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 @@ -4529,7 +4535,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 @@ -4548,24 +4554,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.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.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.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.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.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 @@ -4607,7 +4613,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 @@ -4626,24 +4632,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.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.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.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.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.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 @@ -4704,7 +4710,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 @@ -4723,24 +4729,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.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.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.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.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.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 @@ -4786,7 +4792,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 @@ -4805,24 +4811,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.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.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.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.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.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 @@ -4870,7 +4876,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 @@ -4889,24 +4895,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.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.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.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.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.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 @@ -4950,7 +4956,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 @@ -4969,24 +4975,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.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.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.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.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.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 @@ -5036,7 +5042,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 @@ -5055,24 +5061,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.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.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.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.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.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 @@ -5121,7 +5127,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 @@ -5140,24 +5146,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.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.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.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.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.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 @@ -5177,7 +5183,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 @@ -5196,24 +5202,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.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.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.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.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.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 @@ -5265,7 +5271,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 @@ -5284,24 +5290,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.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.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.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.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.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 @@ -5353,7 +5359,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 @@ -5372,24 +5378,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.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.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.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.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.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 @@ -5432,7 +5438,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 @@ -5451,24 +5457,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.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.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.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.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.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 @@ -5514,7 +5520,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 @@ -5533,24 +5539,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.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.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.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.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.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 @@ -5607,7 +5613,7 @@ fv.case28: ; preds = %if.merge.241 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.241 @@ -5632,7 +5638,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 @@ -5651,24 +5657,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.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.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.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.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.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 @@ -5726,7 +5732,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.554, i64 1 }, { ptr, i64 } { ptr @str.555, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.556, i64 1 }, { ptr, i64 } { ptr @str.557, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5745,24 +5751,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.556, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.558, 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.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 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.561, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.563, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { i64, i1 }, { { ptr, i64 }, i1 }, { i1, i1 } }, ptr %alloca, align 8 @@ -5817,9 +5823,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.568, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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.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, ptr %alloca, align 8 @@ -5838,8 +5844,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.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.260 @@ -5858,9 +5864,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.575, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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, ptr %alloca, align 8 @@ -5879,8 +5885,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.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.262 @@ -5910,9 +5916,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.585, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.587, 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, [24 x i8] }, ptr %alloca, align 8 @@ -5929,8 +5935,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.264 @@ -6008,9 +6014,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.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 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, 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 @@ -6029,8 +6035,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.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.266 @@ -6049,9 +6055,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.605, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.607, 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.599, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.601, 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 @@ -6070,8 +6076,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.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 } { ptr @str.609, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.608, 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 @@ -6088,7 +6094,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.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.277 @@ -6105,12 +6111,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.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.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.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.281 @@ -6139,7 +6145,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.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.282 @@ -6156,12 +6162,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.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.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.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.286 @@ -6191,7 +6197,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.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.287 @@ -6208,12 +6214,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.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.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.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.291 @@ -6241,7 +6247,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.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.292 @@ -6258,12 +6264,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.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.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.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.296 @@ -6292,7 +6298,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.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.297 @@ -6309,12 +6315,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.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.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.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.301 @@ -6343,7 +6349,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.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.302 @@ -6360,12 +6366,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.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.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.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.306 @@ -6395,7 +6401,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.314 @@ -6414,12 +6420,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.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.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.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.318 @@ -6448,7 +6454,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.319 @@ -6467,12 +6473,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.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.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.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.323 @@ -6501,7 +6507,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.324 @@ -6520,12 +6526,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.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.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.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.328 @@ -6555,7 +6561,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.329 @@ -6574,12 +6580,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.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.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.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.333 @@ -6609,7 +6615,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.334 @@ -6628,12 +6634,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.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.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.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.338 @@ -6675,12 +6681,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.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.374 if.merge.374: ; preds = %if.else.373, %if.then.372 - %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] + %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.372 ], [ %callN, %if.else.373 ] ret { ptr, i64 } %bp } @@ -6703,12 +6709,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.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.390 if.merge.390: ; preds = %if.else.389, %if.then.388 - %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] + %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.388 ], [ %callN, %if.else.389 ] ret { ptr, i64 } %bp } @@ -6731,12 +6737,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.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.393 if.merge.393: ; preds = %if.else.392, %if.then.391 - %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] + %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.391 ], [ %callN, %if.else.392 ] ret { ptr, i64 } %bp } @@ -6759,12 +6765,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.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.396 if.merge.396: ; preds = %if.else.395, %if.then.394 - %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6787,12 +6793,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.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.399 if.merge.399: ; preds = %if.else.398, %if.then.397 - %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6814,12 +6820,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.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.402 if.merge.402: ; preds = %if.else.401, %if.then.400 - %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6842,12 +6848,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.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.405 if.merge.405: ; preds = %if.else.404, %if.then.403 - %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6870,12 +6876,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.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.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6898,12 +6904,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.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.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -6926,12 +6932,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.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.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -6954,12 +6960,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.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.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -6982,12 +6988,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.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.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -7010,12 +7016,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.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.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -7037,12 +7043,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.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.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -7065,12 +7071,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.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.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7092,12 +7098,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.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.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7120,12 +7126,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.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.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7148,12 +7154,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.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.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7176,12 +7182,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.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.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7204,12 +7210,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.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.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7232,12 +7238,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.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.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7260,12 +7266,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.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.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7288,12 +7294,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.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.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7316,12 +7322,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.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.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7344,12 +7350,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.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.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7372,12 +7378,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.718, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 2 }, { 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 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.716, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7400,12 +7406,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.721, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 7 }, { 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 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.719, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7428,12 +7434,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.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.468 if.merge.468: ; preds = %if.else.467, %if.then.466 - %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7456,12 +7462,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.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.471 if.merge.471: ; preds = %if.else.470, %if.then.469 - %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7484,12 +7490,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.730, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 6 }, { 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 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.728, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7512,12 +7518,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.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.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.733, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7533,7 +7539,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 { { i32 }, i1 }, ptr %alloca, align 4 @@ -7557,7 +7563,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 { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7581,7 +7587,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 { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7605,7 +7611,7 @@ entry: br i1 %lnot, label %if.then.492, label %if.merge.493 if.then.492: ; preds = %entry - ret { ptr, i64 } { ptr @str.737, i64 4 } + ret { ptr, i64 } { ptr @str.739, i64 4 } if.merge.493: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 @@ -7628,7 +7634,7 @@ entry: br i1 %lnot, label %if.then.494, label %if.merge.495 if.then.494: ; preds = %entry - ret { ptr, i64 } { ptr @str.738, i64 4 } + ret { ptr, i64 } { ptr @str.740, i64 4 } if.merge.495: ; preds = %entry %loadN = load { i64, i1 }, ptr %alloca, align 8 @@ -7649,7 +7655,7 @@ entry: br i1 %lnot, label %if.then.496, label %if.merge.497 if.then.496: ; preds = %entry - ret { ptr, i64 } { ptr @str.739, i64 4 } + ret { ptr, i64 } { ptr @str.741, 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 2c6b13f..793c90b 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = private constant [13 x i8] c"TooManyFlags\00" +@tag.str.148 = private constant [4 x i8] c"Bad\00" +@tag.str.149 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }, { ptr, i64 } { ptr @tag.str.148, i64 3 }, { ptr, i64 } { ptr @tag.str.149, i64 5 }] @tn.str = private constant [13 x i8] c"\00" -@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 +@tn.str.150 = private constant [5 x i8] c"bool\00" +@tn.str.151 = private constant [3 x i8] c"s8\00" +@tn.str.152 = private constant [4 x i8] c"s16\00" +@tn.str.153 = private constant [4 x i8] c"s32\00" +@tn.str.154 = private constant [4 x i8] c"s64\00" +@tn.str.155 = private constant [3 x i8] c"u8\00" +@tn.str.156 = private constant [4 x i8] c"u16\00" +@tn.str.157 = private constant [4 x i8] c"u32\00" +@tn.str.158 = private constant [4 x i8] c"u64\00" +@tn.str.159 = private constant [4 x i8] c"f32\00" +@tn.str.160 = private constant [4 x i8] c"f64\00" +@tn.str.161 = private constant [7 x i8] c"string\00" +@tn.str.162 = private constant [4 x i8] c"Any\00" +@tn.str.163 = private constant [9 x i8] c"noreturn\00" +@tn.str.164 = private constant [6 x i8] c"isize\00" +@tn.str.165 = private constant [6 x i8] c"usize\00" +@tn.str.166 = private constant [5 x i8] c"void\00" +@tn.str.167 = private constant [6 x i8] c"*void\00" +@tn.str.168 = private constant [16 x i8] c"Source_Location\00" +@tn.str.169 = private constant [10 x i8] c"Allocator\00" +@tn.str.170 = private constant [8 x i8] c"Context\00" +@tn.str.171 = private constant [7 x i8] c"[4]s64\00" +@tn.str.172 = private constant [9 x i8] c"[]string\00" +@tn.str.173 = private constant [11 x i8] c"CAllocator\00" +@tn.str.174 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.175 = private constant [4 x i8] c"GPA\00" +@tn.str.176 = private constant [5 x i8] c"*GPA\00" +@tn.str.177 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.178 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.179 = private constant [6 x i8] c"Arena\00" +@tn.str.180 = private constant [7 x i8] c"*Arena\00" +@tn.str.181 = private constant [6 x i8] c"[*]u8\00" +@tn.str.182 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.183 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.184 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.185 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.186 = private constant [9 x i8] c"OpenMode\00" +@tn.str.187 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.188 = private constant [5 x i8] c"File\00" +@tn.str.189 = private constant [6 x i8] c"*File\00" +@tn.str.190 = private constant [6 x i8] c"?File\00" +@tn.str.191 = private constant [8 x i8] c"?string\00" +@tn.str.192 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.193 = private constant [4 x i8] c"*u8\00" +@tn.str.194 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.195 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.196 = private constant [5 x i8] c"*s32\00" +@tn.str.197 = private constant [9 x i8] c"SockAddr\00" +@tn.str.198 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.199 = private constant [5 x i8] c"*u32\00" +@tn.str.200 = private constant [10 x i8] c"JsonError\00" +@tn.str.201 = private constant [6 x i8] c"Array\00" +@tn.str.202 = private constant [7 x i8] c"Object\00" +@tn.str.203 = private constant [6 x i8] c"Value\00" +@tn.str.204 = private constant [7 x i8] c"Member\00" +@tn.str.205 = private constant [9 x i8] c"[*]Value\00" +@tn.str.206 = private constant [7 x i8] c"*Array\00" +@tn.str.207 = private constant [10 x i8] c"[*]Member\00" +@tn.str.208 = private constant [8 x i8] c"*Object\00" +@tn.str.209 = private constant [5 x i8] c"[]u8\00" +@tn.str.210 = private constant [5 x i8] c"Sink\00" +@tn.str.211 = private constant [6 x i8] c"*Sink\00" +@tn.str.212 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.213 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.214 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.215 = private constant [7 x i8] c"Parser\00" +@tn.str.216 = private constant [8 x i8] c"*Parser\00" +@tn.str.217 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.218 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.219 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.220 = private constant [13 x i8] c"Architecture\00" +@tn.str.221 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.222 = private constant [11 x i8] c"() -> bool\00" +@tn.str.223 = private constant [5 x i8] c"*s64\00" +@tn.str.224 = private constant [9 x i8] c"CliError\00" +@tn.str.225 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.226 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.227 = private constant [8 x i8] c"Command\00" +@tn.str.228 = private constant [10 x i8] c"FlagValue\00" +@tn.str.229 = private constant [5 x i8] c"Diag\00" +@tn.str.230 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.231 = private constant [7 x i8] c"Parsed\00" +@tn.str.232 = private constant [8 x i8] c"*Parsed\00" +@tn.str.233 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.234 = private constant [10 x i8] c"[]Command\00" +@tn.str.235 = private constant [6 x i8] c"*Diag\00" +@tn.str.236 = private constant [7 x i8] c"[8]s64\00" +@tn.str.237 = private constant [7 x i8] c"[64]u8\00" +@tn.str.238 = private constant [7 x i8] c"Sha256\00" +@tn.str.239 = private constant [8 x i8] c"*Sha256\00" +@tn.str.240 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.241 = private constant [8 x i8] c"[64]s64\00" +@tn.str.242 = private constant [2 x i8] c"E\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"*E\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"**E\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 [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.150, i64 4 }, { 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 2 }, { 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 3 }, { ptr, i64 } { ptr @tn.str.161, i64 6 }, { ptr, i64 } { ptr @tn.str.162, i64 3 }, { ptr, i64 } { ptr @tn.str.163, i64 8 }, { ptr, i64 } { ptr @tn.str.164, i64 5 }, { ptr, i64 } { ptr @tn.str.165, i64 5 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 5 }, { ptr, i64 } { ptr @tn.str.168, i64 15 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 7 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 8 }, { ptr, i64 } { ptr @tn.str.173, i64 10 }, { ptr, i64 } { ptr @tn.str.174, i64 11 }, { ptr, i64 } { ptr @tn.str.175, i64 3 }, { ptr, i64 } { ptr @tn.str.176, i64 4 }, { ptr, i64 } { ptr @tn.str.177, i64 10 }, { ptr, i64 } { ptr @tn.str.178, i64 11 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 5 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 9 }, { ptr, i64 } { ptr @tn.str.184, i64 17 }, { ptr, i64 } { ptr @tn.str.185, i64 18 }, { ptr, i64 } { ptr @tn.str.186, i64 8 }, { ptr, i64 } { ptr @tn.str.187, i64 8 }, { ptr, i64 } { ptr @tn.str.188, i64 4 }, { ptr, i64 } { ptr @tn.str.189, i64 5 }, { ptr, i64 } { ptr @tn.str.190, i64 5 }, { ptr, i64 } { ptr @tn.str.191, i64 7 }, { ptr, i64 } { ptr @tn.str.192, i64 10 }, { ptr, i64 } { ptr @tn.str.193, i64 3 }, { ptr, i64 } { ptr @tn.str.194, i64 13 }, { ptr, i64 } { ptr @tn.str.195, i64 14 }, { ptr, i64 } { ptr @tn.str.196, i64 4 }, { ptr, i64 } { ptr @tn.str.197, i64 8 }, { ptr, i64 } { ptr @tn.str.198, i64 9 }, { ptr, i64 } { ptr @tn.str.199, i64 4 }, { ptr, i64 } { ptr @tn.str.200, i64 9 }, { ptr, i64 } { ptr @tn.str.201, i64 5 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 5 }, { ptr, i64 } { ptr @tn.str.204, i64 6 }, { ptr, i64 } { ptr @tn.str.205, i64 8 }, { ptr, i64 } { ptr @tn.str.206, i64 6 }, { ptr, i64 } { ptr @tn.str.207, i64 9 }, { ptr, i64 } { ptr @tn.str.208, i64 7 }, { ptr, i64 } { ptr @tn.str.209, i64 4 }, { ptr, i64 } { ptr @tn.str.210, i64 4 }, { ptr, i64 } { ptr @tn.str.211, i64 5 }, { ptr, i64 } { ptr @tn.str.212, i64 16 }, { ptr, i64 } { ptr @tn.str.213, i64 14 }, { ptr, i64 } { ptr @tn.str.214, i64 21 }, { ptr, i64 } { ptr @tn.str.215, i64 6 }, { ptr, i64 } { ptr @tn.str.216, i64 7 }, { ptr, i64 } { ptr @tn.str.217, i64 24 }, { ptr, i64 } { ptr @tn.str.218, i64 23 }, { ptr, i64 } { ptr @tn.str.219, i64 15 }, { ptr, i64 } { ptr @tn.str.220, i64 12 }, { ptr, i64 } { ptr @tn.str.221, i64 12 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 8 }, { ptr, i64 } { ptr @tn.str.225, i64 8 }, { ptr, i64 } { ptr @tn.str.226, i64 10 }, { ptr, i64 } { ptr @tn.str.227, i64 7 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 4 }, { ptr, i64 } { ptr @tn.str.230, i64 13 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 7 }, { ptr, i64 } { ptr @tn.str.233, i64 18 }, { ptr, i64 } { ptr @tn.str.234, i64 9 }, { ptr, i64 } { ptr @tn.str.235, i64 5 }, { ptr, i64 } { ptr @tn.str.236, i64 6 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 6 }, { ptr, i64 } { ptr @tn.str.239, i64 7 }, { ptr, i64 } { ptr @tn.str.240, i64 7 }, { ptr, i64 } { ptr @tn.str.241, i64 7 }, { 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 [19 x i8] c"1004-errors-try.sx\00" -@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 [1 x i8] zeroinitializer, align 1 +@frame.str.332 = private unnamed_addr constant [6 x i8] c"inner\00" +@frame.str.333 = 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.332, i64 5 }, { ptr, i64 } { ptr @frame.str.333, i64 33 } } +@frame.str.334 = private unnamed_addr constant [6 x i8] c"outer\00" +@frame.str.335 = private unnamed_addr constant [18 x i8] c" try inner(n);\00" +@trace.frame.336 = 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.334, i64 5 }, { ptr, i64 } { ptr @frame.str.335, i64 17 } } @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 +@str.338 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.339 = private unnamed_addr constant [16 x i8] c"try 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 [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 }] +@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 [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.362 = private constant [5 x i8] c"data\00" +@field_names.363 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.361, i64 9 }, { ptr, i64 } { ptr @fld.str.362, i64 4 }] +@str.364 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.365 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.369 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.370 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.371 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.376 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.375, i64 11 }] +@str.377 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.378 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.383 = private constant [4 x i8] c"cap\00" +@field_names.384 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.382, i64 4 }, { 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.391 = private constant [10 x i8] c"end_index\00" +@fld.str.392 = private constant [7 x i8] c"parent\00" +@field_names.393 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.390, i64 5 }, { ptr, i64 } { ptr @fld.str.391, i64 9 }, { ptr, i64 } { ptr @fld.str.392, i64 6 }] +@str.394 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.395 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.400 = private constant [4 x i8] c"len\00" +@fld.str.401 = private constant [4 x i8] c"pos\00" +@field_names.402 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.399, i64 3 }, { ptr, i64 } { ptr @fld.str.400, i64 3 }, { ptr, i64 } { ptr @fld.str.401, i64 3 }] @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.404 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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.408 = private constant [7 x i8] c"parent\00" +@fld.str.409 = private constant [12 x i8] c"alloc_count\00" +@fld.str.410 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.411 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.412 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.408, i64 6 }, { ptr, i64 } { ptr @fld.str.409, i64 11 }, { ptr, i64 } { ptr @fld.str.410, i64 13 }, { ptr, i64 } { ptr @fld.str.411, i64 17 }] +@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 @@ -627,85 +627,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -848,7 +770,7 @@ entry: br i1 %icmp, label %if.then.66, label %if.merge.67 if.then.66: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.67: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -975,7 +897,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.128, i64 4 }, %if.then.88 ], [ { ptr @str.129, i64 5 }, %if.else.89 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.88 ], [ { ptr @str.131, i64 5 }, %if.else.89 ] ret { ptr, i64 } %bp } @@ -1309,7 +1231,7 @@ entry: br i1 %icmp, label %if.then.379, label %if.merge.380 if.then.379: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.380: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1459,7 +1381,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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 @@ -1486,12 +1408,12 @@ entry: i64 19, label %match.arm.53 i64 20, 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 24, label %match.arm.53 + i64 26, label %match.arm.53 + i64 28, label %match.arm.53 i64 30, label %match.arm.53 - i64 32, label %match.arm.53 - i64 34, label %match.arm.53 + i64 33, label %match.arm.53 + i64 35, label %match.arm.53 i64 39, label %match.arm.53 i64 43, label %match.arm.53 i64 45, label %match.arm.53 @@ -1517,25 +1439,25 @@ entry: i64 64, label %match.arm.55 i64 75, label %match.arm.55 i64 93, label %match.arm.55 - i64 35, label %match.arm.57 + i64 22, label %match.arm.57 i64 81, label %match.arm.57 i64 87, label %match.arm.57 i64 88, label %match.arm.57 i64 92, label %match.arm.57 i64 100, label %match.arm.57 - i64 36, label %match.arm.58 + i64 23, label %match.arm.58 i64 60, label %match.arm.58 i64 77, label %match.arm.58 i64 85, label %match.arm.58 i64 98, label %match.arm.58 i64 18, 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 25, label %match.arm.59 + i64 27, label %match.arm.59 i64 29, label %match.arm.59 i64 31, label %match.arm.59 - i64 33, label %match.arm.59 + i64 32, label %match.arm.59 + i64 34, label %match.arm.59 + i64 36, label %match.arm.59 i64 40, label %match.arm.59 i64 44, label %match.arm.59 i64 47, label %match.arm.59 @@ -1571,7 +1493,7 @@ match.merge.47: ; preds = %dispatch.merge.482, ret { ptr, i64 } %loadN match.arm.48: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1616,12 +1538,12 @@ match.arm.53: ; preds = %entry, %entry, %ent i64 19, label %dispatch.case.106 i64 20, label %dispatch.case.107 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 24, label %dispatch.case.109 + i64 26, label %dispatch.case.110 + i64 28, label %dispatch.case.111 i64 30, label %dispatch.case.112 - i64 32, label %dispatch.case.113 - i64 34, label %dispatch.case.114 + i64 33, label %dispatch.case.113 + i64 35, label %dispatch.case.114 i64 39, label %dispatch.case.115 i64 43, label %dispatch.case.116 i64 45, label %dispatch.case.117 @@ -1672,7 +1594,7 @@ match.arm.57: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.274 [ - i64 35, label %dispatch.case.275 + i64 22, label %dispatch.case.275 i64 81, label %dispatch.case.276 i64 87, label %dispatch.case.277 i64 88, label %dispatch.case.278 @@ -1685,7 +1607,7 @@ match.arm.58: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.312 [ - i64 36, label %dispatch.case.313 + i64 23, label %dispatch.case.313 i64 60, label %dispatch.case.314 i64 77, label %dispatch.case.315 i64 85, label %dispatch.case.316 @@ -1698,13 +1620,13 @@ 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 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 - i64 33, label %dispatch.case.352 + i64 25, label %dispatch.case.346 + i64 27, label %dispatch.case.347 + i64 29, label %dispatch.case.348 + i64 31, label %dispatch.case.349 + i64 32, label %dispatch.case.350 + i64 34, label %dispatch.case.351 + i64 36, label %dispatch.case.352 i64 40, label %dispatch.case.353 i64 44, label %dispatch.case.354 i64 47, label %dispatch.case.355 @@ -1798,7 +1720,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.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.104 dispatch.case.106: ; preds = %match.arm.53 @@ -1820,56 +1742,56 @@ dispatch.case.107: ; preds = %match.arm.53 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 {}, ptr %ua.ptr69, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) + %ua.load70 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %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 { 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.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, 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.104 dispatch.case.111: ; preds = %match.arm.53 %ua.raw80 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr81 = inttoptr i64 %ua.raw80 to ptr - %ua.load82 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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.104 dispatch.case.112: ; preds = %match.arm.53 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.104 dispatch.case.113: ; preds = %match.arm.53 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.104 dispatch.case.114: ; preds = %match.arm.53 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.104 @@ -2007,7 +1929,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.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.256 dispatch.case.258: ; preds = %match.arm.54 @@ -2048,7 +1970,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.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.273 dispatch.case.275: ; preds = %match.arm.57 @@ -2105,7 +2027,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.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.311 dispatch.case.313: ; preds = %match.arm.58 @@ -2154,7 +2076,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.313, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.343 dispatch.case.345: ; preds = %match.arm.59 @@ -2380,7 +2302,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.314, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.316, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.482 dispatch.case.484: ; preds = %match.arm.60 @@ -2422,7 +2344,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 @@ -2518,7 +2440,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.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 @@ -2526,7 +2448,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.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 @@ -2536,13 +2458,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.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.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.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 @@ -2550,7 +2472,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.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 @@ -2564,7 +2486,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.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 @@ -2572,7 +2494,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.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 @@ -2583,7 +2505,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.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 @@ -2640,7 +2562,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.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 @@ -2648,7 +2570,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.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 @@ -2659,7 +2581,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.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 @@ -2679,7 +2601,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.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 @@ -2687,7 +2609,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.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 @@ -2698,7 +2620,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.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.46 @@ -2708,67 +2630,151 @@ if.merge.46: ; preds = %if.then.45, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2944,166 +2950,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3301,64 +3307,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3388,97 +3394,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3517,7 +3523,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @inner(ptr %0, i32 %1) #0 { @@ -3621,7 +3627,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.335, i64 15 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.337, 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 @@ -3637,7 +3643,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 12) @@ -3665,7 +3671,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 15 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.339, i64 15 }) ret { ptr, i64 } %call } @@ -3676,7 +3682,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 @@ -3695,12 +3701,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.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.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.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.135 @@ -3712,7 +3718,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.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 @@ -3769,7 +3775,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.346, i64 9 }, { ptr, i64 } { ptr @str.347, i64 1 }) + %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 @@ -3788,24 +3794,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.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.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.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.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 [3 x { ptr, i64 }], ptr @field_names.353, 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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -3849,20 +3855,21 @@ fv.case21: ; preds = %if.merge.140 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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.355, i64 10 }, { ptr, i64 } { ptr @str.356, i64 1 }) + %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.357, i64 7 }, { 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.141 -while.hdr.141: ; preds = %if.merge.145, %entry +while.hdr.141: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 2 br i1 %icmp, label %while.body.142, label %while.exit.143 while.body.142: ; preds = %while.hdr.141 @@ -3872,24 +3879,102 @@ while.body.142: ; preds = %while.hdr.141 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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.359, 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 }) + %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.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.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.360, 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 { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.141 + +fv.default: ; preds = %if.merge.145 + br label %fv.merge + +fv.case: ; preds = %if.merge.145 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.145 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.365, i64 10 }, { 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.146 + +while.hdr.146: ; preds = %if.merge.150, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + 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.367, 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.368, 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 [0 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 {}, ptr %alloca, align 1 @@ -3900,7 +3985,7 @@ if.merge.145: ; preds = %if.then.144, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.141 + br label %while.hdr.146 } ; Function Attrs: nounwind @@ -3908,43 +3993,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.371, i64 3 }, { 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.146 + br label %while.hdr.151 -while.hdr.146: ; preds = %fv.merge, %entry +while.hdr.151: ; 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 + br i1 %icmp, label %while.body.152, label %while.exit.153 -while.body.147: ; preds = %while.hdr.146 +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.149, label %if.merge.150 + br i1 %icmpN, label %if.then.154, label %if.merge.155 -while.exit.148: ; preds = %while.hdr.146 +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.363, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 1 }) ret { ptr, i64 } %callN -if.then.149: ; preds = %while.body.147 +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.364, i64 2 }) + %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.150 + br label %if.merge.155 -if.merge.150: ; preds = %if.then.149, %while.body.147 +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 [1 x { ptr, i64 }], ptr @field_names.366, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.367, 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 { i64 }, ptr %alloca, align 8 @@ -3961,12 +4046,12 @@ 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.146 + br label %while.hdr.151 -fv.default: ; preds = %if.merge.150 +fv.default: ; preds = %if.merge.155 br label %fv.merge -fv.case: ; preds = %if.merge.150 +fv.case: ; preds = %if.merge.155 %fv.field = extractvalue { i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge @@ -3977,43 +4062,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 10 }, { 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.151 + br label %while.hdr.156 -while.hdr.151: ; preds = %fv.merge, %entry +while.hdr.156: ; 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 + br i1 %icmp, label %while.body.157, label %while.exit.158 -while.body.152: ; preds = %while.hdr.151 +while.body.157: ; preds = %while.hdr.156 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.154, label %if.merge.155 + br i1 %icmpN, label %if.then.159, label %if.merge.160 -while.exit.153: ; preds = %while.hdr.151 +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.370, 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 +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.371, 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 + br label %if.merge.160 -if.merge.155: ; preds = %if.then.154, %while.body.152 +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 [2 x { ptr, i64 }], ptr @field_names.374, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.384, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.385, 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 @@ -4031,18 +4116,18 @@ 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.151 + br label %while.hdr.156 -fv.default: ; preds = %if.merge.155 +fv.default: ; preds = %if.merge.160 br label %fv.merge -fv.case: ; preds = %if.merge.155 +fv.case: ; preds = %if.merge.160 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.155 +fv.case17: ; preds = %if.merge.160 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -4054,91 +4139,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 }) - %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 = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.157, label %while.exit.158 - -while.body.157: ; preds = %while.hdr.156 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.159, label %if.merge.160 - -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 }) - 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 }) - 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.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) - store { ptr, i64 } %callN, ptr %allocaN, 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, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.156 - -fv.default: ; preds = %if.merge.160 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.160 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 8 }, { ptr, i64 } { ptr @str.386, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.386, i64 5 }, { ptr, i64 } { ptr @str.387, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4157,27 +4158,27 @@ 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.388, 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.389, 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.392, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.393, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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.394, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4199,29 +4200,30 @@ fv.default: ; preds = %if.merge.165 br label %fv.merge fv.case: ; preds = %if.merge.165 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.165 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.165 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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 }) + %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.395, i64 8 }, { ptr, i64 } { ptr @str.396, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4230,7 +4232,7 @@ entry: while.hdr.166: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.167, label %while.exit.168 while.body.167: ; preds = %while.hdr.166 @@ -4240,19 +4242,19 @@ 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.396, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.397, 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.397, 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 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.402, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4260,17 +4262,16 @@ if.merge.170: ; preds = %if.then.169, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4283,35 +4284,29 @@ fv.default: ; preds = %if.merge.170 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.170 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.170 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.170 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.404, i64 17 }, { 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 @@ -4320,7 +4315,7 @@ entry: while.hdr.171: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.172, label %while.exit.173 while.body.172: ; preds = %while.hdr.171 @@ -4342,23 +4337,25 @@ if.then.174: ; preds = %while.body.172 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.410, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4371,16 +4368,25 @@ fv.default: ; preds = %if.merge.175 br label %fv.merge fv.case: ; preds = %if.merge.175 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.175 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.175 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.175 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4389,7 +4395,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 @@ -4408,24 +4414,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.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.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.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.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.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 @@ -4462,7 +4468,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 @@ -4481,24 +4487,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.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.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.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.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.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 @@ -4564,7 +4570,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 @@ -4583,24 +4589,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.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.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.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.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.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 @@ -4642,7 +4648,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 @@ -4661,24 +4667,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.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.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.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.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.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 @@ -4739,7 +4745,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 @@ -4758,24 +4764,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 @@ -4821,7 +4827,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 @@ -4840,24 +4846,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 [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 @@ -4905,7 +4911,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 @@ -4924,24 +4930,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.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.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.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.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.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 @@ -4985,7 +4991,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 @@ -5004,24 +5010,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 %alloca, align 8 @@ -5071,7 +5077,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 @@ -5090,24 +5096,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 [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 @@ -5156,7 +5162,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 @@ -5175,24 +5181,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.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.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.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.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.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 @@ -5212,7 +5218,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 @@ -5231,24 +5237,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 }, i1, i1 }, ptr %alloca, align 8 @@ -5300,7 +5306,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 @@ -5319,24 +5325,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 [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 @@ -5388,7 +5394,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 @@ -5407,24 +5413,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.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.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.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.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.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 @@ -5467,7 +5473,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 @@ -5486,24 +5492,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.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.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.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.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.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 @@ -5549,7 +5555,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 @@ -5568,24 +5574,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.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.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.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.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.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 @@ -5642,7 +5648,7 @@ fv.case28: ; preds = %if.merge.250 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.250 @@ -5667,7 +5673,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 @@ -5686,24 +5692,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.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.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.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.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.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 @@ -5762,9 +5768,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 @@ -5783,8 +5789,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.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.264 @@ -5803,9 +5809,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 @@ -5824,8 +5830,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.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.266 @@ -5855,9 +5861,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 @@ -5874,8 +5880,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.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.268 @@ -5953,9 +5959,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 @@ -5974,8 +5980,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.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.270 @@ -5994,9 +6000,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 @@ -6015,8 +6021,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.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.272 @@ -6033,7 +6039,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.281 @@ -6050,12 +6056,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.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.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.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.285 @@ -6084,7 +6090,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.286 @@ -6101,12 +6107,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.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.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.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.290 @@ -6136,7 +6142,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.291 @@ -6153,12 +6159,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.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.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.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.295 @@ -6186,7 +6192,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.296 @@ -6203,12 +6209,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.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.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.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.300 @@ -6237,7 +6243,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.301 @@ -6254,12 +6260,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.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.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.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.305 @@ -6288,7 +6294,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.306 @@ -6305,12 +6311,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.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.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.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.310 @@ -6340,7 +6346,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.318 @@ -6359,12 +6365,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.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.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.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.322 @@ -6393,7 +6399,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.323 @@ -6412,12 +6418,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.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.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.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.327 @@ -6446,7 +6452,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.328 @@ -6465,12 +6471,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.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.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.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.332 @@ -6500,7 +6506,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.333 @@ -6519,12 +6525,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.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.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.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.337 @@ -6554,7 +6560,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.338 @@ -6573,12 +6579,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.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.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.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.342 @@ -6620,12 +6626,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.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.378 if.merge.378: ; preds = %if.else.377, %if.then.376 - %bp = phi { ptr, i64 } [ { ptr @str.634, i64 4 }, %if.then.376 ], [ %callN, %if.else.377 ] + %bp = phi { ptr, i64 } [ { ptr @str.636, i64 4 }, %if.then.376 ], [ %callN, %if.else.377 ] ret { ptr, i64 } %bp } @@ -6648,12 +6654,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.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.394 if.merge.394: ; preds = %if.else.393, %if.then.392 - %bp = phi { ptr, i64 } [ { ptr @str.637, i64 4 }, %if.then.392 ], [ %callN, %if.else.393 ] + %bp = phi { ptr, i64 } [ { ptr @str.639, i64 4 }, %if.then.392 ], [ %callN, %if.else.393 ] ret { ptr, i64 } %bp } @@ -6676,12 +6682,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.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.397 if.merge.397: ; preds = %if.else.396, %if.then.395 - %bp = phi { ptr, i64 } [ { ptr @str.640, i64 4 }, %if.then.395 ], [ %callN, %if.else.396 ] + %bp = phi { ptr, i64 } [ { ptr @str.642, i64 4 }, %if.then.395 ], [ %callN, %if.else.396 ] ret { ptr, i64 } %bp } @@ -6704,12 +6710,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.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.400 if.merge.400: ; preds = %if.else.399, %if.then.398 - %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.398 ], [ %callN, %if.else.399 ] + %bp = phi { ptr, i64 } [ { ptr @str.645, i64 4 }, %if.then.398 ], [ %callN, %if.else.399 ] ret { ptr, i64 } %bp } @@ -6732,12 +6738,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.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.403 if.merge.403: ; preds = %if.else.402, %if.then.401 - %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.401 ], [ %callN, %if.else.402 ] + %bp = phi { ptr, i64 } [ { ptr @str.648, i64 4 }, %if.then.401 ], [ %callN, %if.else.402 ] ret { ptr, i64 } %bp } @@ -6759,12 +6765,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.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.406 if.merge.406: ; preds = %if.else.405, %if.then.404 - %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.404 ], [ %callN, %if.else.405 ] + %bp = phi { ptr, i64 } [ { ptr @str.651, i64 4 }, %if.then.404 ], [ %callN, %if.else.405 ] ret { ptr, i64 } %bp } @@ -6787,12 +6793,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.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.409 if.merge.409: ; preds = %if.else.408, %if.then.407 - %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.407 ], [ %callN, %if.else.408 ] + %bp = phi { ptr, i64 } [ { ptr @str.654, i64 4 }, %if.then.407 ], [ %callN, %if.else.408 ] ret { ptr, i64 } %bp } @@ -6815,12 +6821,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.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.412 if.merge.412: ; preds = %if.else.411, %if.then.410 - %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.410 ], [ %callN, %if.else.411 ] + %bp = phi { ptr, i64 } [ { ptr @str.657, i64 4 }, %if.then.410 ], [ %callN, %if.else.411 ] ret { ptr, i64 } %bp } @@ -6843,12 +6849,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.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.415 if.merge.415: ; preds = %if.else.414, %if.then.413 - %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.413 ], [ %callN, %if.else.414 ] + %bp = phi { ptr, i64 } [ { ptr @str.660, i64 4 }, %if.then.413 ], [ %callN, %if.else.414 ] ret { ptr, i64 } %bp } @@ -6871,12 +6877,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.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.418 if.merge.418: ; preds = %if.else.417, %if.then.416 - %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.416 ], [ %callN, %if.else.417 ] + %bp = phi { ptr, i64 } [ { ptr @str.663, i64 4 }, %if.then.416 ], [ %callN, %if.else.417 ] ret { ptr, i64 } %bp } @@ -6899,12 +6905,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.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.421 if.merge.421: ; preds = %if.else.420, %if.then.419 - %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.419 ], [ %callN, %if.else.420 ] + %bp = phi { ptr, i64 } [ { ptr @str.666, i64 4 }, %if.then.419 ], [ %callN, %if.else.420 ] ret { ptr, i64 } %bp } @@ -6927,12 +6933,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.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.424 if.merge.424: ; preds = %if.else.423, %if.then.422 - %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.422 ], [ %callN, %if.else.423 ] + %bp = phi { ptr, i64 } [ { ptr @str.669, i64 4 }, %if.then.422 ], [ %callN, %if.else.423 ] ret { ptr, i64 } %bp } @@ -6955,12 +6961,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.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.427 if.merge.427: ; preds = %if.else.426, %if.then.425 - %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] + %bp = phi { ptr, i64 } [ { ptr @str.672, i64 4 }, %if.then.425 ], [ %callN, %if.else.426 ] ret { ptr, i64 } %bp } @@ -6982,12 +6988,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.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.430 if.merge.430: ; preds = %if.else.429, %if.then.428 - %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] + %bp = phi { ptr, i64 } [ { ptr @str.675, i64 4 }, %if.then.428 ], [ %callN, %if.else.429 ] ret { ptr, i64 } %bp } @@ -7010,12 +7016,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.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.433 if.merge.433: ; preds = %if.else.432, %if.then.431 - %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] + %bp = phi { ptr, i64 } [ { ptr @str.678, i64 4 }, %if.then.431 ], [ %callN, %if.else.432 ] ret { ptr, i64 } %bp } @@ -7037,12 +7043,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.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.436 if.merge.436: ; preds = %if.else.435, %if.then.434 - %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] + %bp = phi { ptr, i64 } [ { ptr @str.681, i64 4 }, %if.then.434 ], [ %callN, %if.else.435 ] ret { ptr, i64 } %bp } @@ -7065,12 +7071,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.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.439 if.merge.439: ; preds = %if.else.438, %if.then.437 - %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] + %bp = phi { ptr, i64 } [ { ptr @str.684, i64 4 }, %if.then.437 ], [ %callN, %if.else.438 ] ret { ptr, i64 } %bp } @@ -7093,12 +7099,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.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.442 if.merge.442: ; preds = %if.else.441, %if.then.440 - %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] + %bp = phi { ptr, i64 } [ { ptr @str.687, i64 4 }, %if.then.440 ], [ %callN, %if.else.441 ] ret { ptr, i64 } %bp } @@ -7121,12 +7127,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.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.445 if.merge.445: ; preds = %if.else.444, %if.then.443 - %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] + %bp = phi { ptr, i64 } [ { ptr @str.690, i64 4 }, %if.then.443 ], [ %callN, %if.else.444 ] ret { ptr, i64 } %bp } @@ -7149,12 +7155,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.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.448 if.merge.448: ; preds = %if.else.447, %if.then.446 - %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] + %bp = phi { ptr, i64 } [ { ptr @str.693, i64 4 }, %if.then.446 ], [ %callN, %if.else.447 ] ret { ptr, i64 } %bp } @@ -7177,12 +7183,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.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.451 if.merge.451: ; preds = %if.else.450, %if.then.449 - %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] + %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.449 ], [ %callN, %if.else.450 ] ret { ptr, i64 } %bp } @@ -7205,12 +7211,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.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.454 if.merge.454: ; preds = %if.else.453, %if.then.452 - %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] + %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.452 ], [ %callN, %if.else.453 ] ret { ptr, i64 } %bp } @@ -7233,12 +7239,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.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.457 if.merge.457: ; preds = %if.else.456, %if.then.455 - %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] + %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.455 ], [ %callN, %if.else.456 ] ret { ptr, i64 } %bp } @@ -7261,12 +7267,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.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.460 if.merge.460: ; preds = %if.else.459, %if.then.458 - %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] + %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.458 ], [ %callN, %if.else.459 ] ret { ptr, i64 } %bp } @@ -7289,12 +7295,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.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.463 if.merge.463: ; preds = %if.else.462, %if.then.461 - %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] + %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.461 ], [ %callN, %if.else.462 ] ret { ptr, i64 } %bp } @@ -7317,12 +7323,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.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.466 if.merge.466: ; preds = %if.else.465, %if.then.464 - %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] + %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.464 ], [ %callN, %if.else.465 ] ret { ptr, i64 } %bp } @@ -7345,12 +7351,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.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.469 if.merge.469: ; preds = %if.else.468, %if.then.467 - %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] + %bp = phi { ptr, i64 } [ { ptr @str.714, i64 4 }, %if.then.467 ], [ %callN, %if.else.468 ] ret { ptr, i64 } %bp } @@ -7373,12 +7379,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.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.472 if.merge.472: ; preds = %if.else.471, %if.then.470 - %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] + %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.470 ], [ %callN, %if.else.471 ] ret { ptr, i64 } %bp } @@ -7401,12 +7407,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.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.475 if.merge.475: ; preds = %if.else.474, %if.then.473 - %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] + %bp = phi { ptr, i64 } [ { ptr @str.720, i64 4 }, %if.then.473 ], [ %callN, %if.else.474 ] ret { ptr, i64 } %bp } @@ -7429,12 +7435,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.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.478 if.merge.478: ; preds = %if.else.477, %if.then.476 - %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] + %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.476 ], [ %callN, %if.else.477 ] ret { ptr, i64 } %bp } @@ -7457,12 +7463,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.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.481 if.merge.481: ; preds = %if.else.480, %if.then.479 - %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] + %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.479 ], [ %callN, %if.else.480 ] ret { ptr, i64 } %bp } @@ -7478,7 +7484,7 @@ entry: br i1 %lnot, label %if.then.488, label %if.merge.489 if.then.488: ; preds = %entry - ret { ptr, i64 } { ptr @str.727, i64 4 } + ret { ptr, i64 } { ptr @str.729, i64 4 } if.merge.489: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7502,7 +7508,7 @@ entry: br i1 %lnot, label %if.then.490, label %if.merge.491 if.then.490: ; preds = %entry - ret { ptr, i64 } { ptr @str.728, i64 4 } + ret { ptr, i64 } { ptr @str.730, i64 4 } if.merge.491: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7526,7 +7532,7 @@ entry: br i1 %lnot, label %if.then.492, label %if.merge.493 if.then.492: ; preds = %entry - ret { ptr, i64 } { ptr @str.729, i64 4 } + ret { ptr, i64 } { ptr @str.731, i64 4 } if.merge.493: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7550,7 +7556,7 @@ entry: br i1 %lnot, label %if.then.494, label %if.merge.495 if.then.494: ; preds = %entry - ret { ptr, i64 } { ptr @str.730, i64 4 } + ret { ptr, i64 } { ptr @str.732, 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 d3a4ffc..43dde49 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.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 +@str.130 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.131 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.132 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.133 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.134 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.135 = 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.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 }] +@tag.str.136 = private constant [9 x i8] c"Overflow\00" +@tag.str.137 = private constant [3 x i8] c"Io\00" +@tag.str.138 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.139 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.140 = private constant [10 x i8] c"BadEscape\00" +@tag.str.141 = private constant [10 x i8] c"BadNumber\00" +@tag.str.142 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.143 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.144 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.145 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.146 = private constant [13 x i8] c"MissingValue\00" +@tag.str.147 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.148 = private constant [13 x i8] c"TooManyFlags\00" +@tag.str.149 = private constant [4 x i8] c"Foo\00" +@tag.str.150 = 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.136, i64 8 }, { ptr, i64 } { ptr @tag.str.137, i64 2 }, { ptr, i64 } { ptr @tag.str.138, i64 15 }, { ptr, i64 } { ptr @tag.str.139, i64 13 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 9 }, { ptr, i64 } { ptr @tag.str.142, i64 15 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 14 }, { ptr, i64 } { ptr @tag.str.145, i64 11 }, { ptr, i64 } { ptr @tag.str.146, i64 12 }, { ptr, i64 } { ptr @tag.str.147, i64 15 }, { ptr, i64 } { ptr @tag.str.148, i64 12 }, { ptr, i64 } { ptr @tag.str.149, i64 3 }, { ptr, i64 } { ptr @tag.str.150, i64 3 }] @tn.str = private constant [13 x i8] c"\00" -@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 +@tn.str.151 = private constant [5 x i8] c"bool\00" +@tn.str.152 = private constant [3 x i8] c"s8\00" +@tn.str.153 = private constant [4 x i8] c"s16\00" +@tn.str.154 = private constant [4 x i8] c"s32\00" +@tn.str.155 = private constant [4 x i8] c"s64\00" +@tn.str.156 = private constant [3 x i8] c"u8\00" +@tn.str.157 = private constant [4 x i8] c"u16\00" +@tn.str.158 = private constant [4 x i8] c"u32\00" +@tn.str.159 = private constant [4 x i8] c"u64\00" +@tn.str.160 = private constant [4 x i8] c"f32\00" +@tn.str.161 = private constant [4 x i8] c"f64\00" +@tn.str.162 = private constant [7 x i8] c"string\00" +@tn.str.163 = private constant [4 x i8] c"Any\00" +@tn.str.164 = private constant [9 x i8] c"noreturn\00" +@tn.str.165 = private constant [6 x i8] c"isize\00" +@tn.str.166 = private constant [6 x i8] c"usize\00" +@tn.str.167 = private constant [5 x i8] c"void\00" +@tn.str.168 = private constant [6 x i8] c"*void\00" +@tn.str.169 = private constant [16 x i8] c"Source_Location\00" +@tn.str.170 = private constant [10 x i8] c"Allocator\00" +@tn.str.171 = private constant [8 x i8] c"Context\00" +@tn.str.172 = private constant [7 x i8] c"[4]s64\00" +@tn.str.173 = private constant [9 x i8] c"[]string\00" +@tn.str.174 = private constant [11 x i8] c"CAllocator\00" +@tn.str.175 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.176 = private constant [4 x i8] c"GPA\00" +@tn.str.177 = private constant [5 x i8] c"*GPA\00" +@tn.str.178 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.179 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.180 = private constant [6 x i8] c"Arena\00" +@tn.str.181 = private constant [7 x i8] c"*Arena\00" +@tn.str.182 = private constant [6 x i8] c"[*]u8\00" +@tn.str.183 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.184 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.185 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.186 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.187 = private constant [9 x i8] c"OpenMode\00" +@tn.str.188 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.189 = private constant [5 x i8] c"File\00" +@tn.str.190 = private constant [6 x i8] c"*File\00" +@tn.str.191 = private constant [6 x i8] c"?File\00" +@tn.str.192 = private constant [8 x i8] c"?string\00" +@tn.str.193 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.194 = private constant [4 x i8] c"*u8\00" +@tn.str.195 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.196 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.197 = private constant [5 x i8] c"*s32\00" +@tn.str.198 = private constant [9 x i8] c"SockAddr\00" +@tn.str.199 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.200 = private constant [5 x i8] c"*u32\00" +@tn.str.201 = private constant [10 x i8] c"JsonError\00" +@tn.str.202 = private constant [6 x i8] c"Array\00" +@tn.str.203 = private constant [7 x i8] c"Object\00" +@tn.str.204 = private constant [6 x i8] c"Value\00" +@tn.str.205 = private constant [7 x i8] c"Member\00" +@tn.str.206 = private constant [9 x i8] c"[*]Value\00" +@tn.str.207 = private constant [7 x i8] c"*Array\00" +@tn.str.208 = private constant [10 x i8] c"[*]Member\00" +@tn.str.209 = private constant [8 x i8] c"*Object\00" +@tn.str.210 = private constant [5 x i8] c"[]u8\00" +@tn.str.211 = private constant [5 x i8] c"Sink\00" +@tn.str.212 = private constant [6 x i8] c"*Sink\00" +@tn.str.213 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.214 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.215 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.216 = private constant [7 x i8] c"Parser\00" +@tn.str.217 = private constant [8 x i8] c"*Parser\00" +@tn.str.218 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.219 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.220 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.221 = private constant [13 x i8] c"Architecture\00" +@tn.str.222 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.223 = private constant [11 x i8] c"() -> bool\00" +@tn.str.224 = private constant [5 x i8] c"*s64\00" +@tn.str.225 = private constant [9 x i8] c"CliError\00" +@tn.str.226 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.227 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.228 = private constant [8 x i8] c"Command\00" +@tn.str.229 = private constant [10 x i8] c"FlagValue\00" +@tn.str.230 = private constant [5 x i8] c"Diag\00" +@tn.str.231 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.232 = private constant [7 x i8] c"Parsed\00" +@tn.str.233 = private constant [8 x i8] c"*Parsed\00" +@tn.str.234 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.235 = private constant [10 x i8] c"[]Command\00" +@tn.str.236 = private constant [6 x i8] c"*Diag\00" +@tn.str.237 = private constant [7 x i8] c"[8]s64\00" +@tn.str.238 = private constant [7 x i8] c"[64]u8\00" +@tn.str.239 = private constant [7 x i8] c"Sha256\00" +@tn.str.240 = private constant [8 x i8] c"*Sha256\00" +@tn.str.241 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.242 = private constant [8 x i8] c"[64]s64\00" +@tn.str.243 = private constant [2 x i8] c"A\00" +@tn.str.244 = private constant [2 x i8] c"!\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 [3 x i8] c"*A\00" +@tn.str.248 = private constant [8 x i8] c"*string\00" +@tn.str.249 = private constant [6 x i8] c"[]Any\00" +@tn.str.250 = private constant [5 x i8] c"*Any\00" +@tn.str.251 = private constant [7 x i8] c"[1]Any\00" +@tn.str.252 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.253 = private constant [7 x i8] c"*[]Any\00" +@tn.str.254 = private constant [6 x i8] c"*bool\00" +@tn.str.255 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.256 = private constant [5 x i8] c"*f64\00" +@tn.str.257 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.258 = private constant [11 x i8] c"*Allocator\00" +@tn.str.259 = private constant [9 x i8] c"*Context\00" +@tn.str.260 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.261 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.262 = private constant [8 x i8] c"*Member\00" +@tn.str.263 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.264 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.265 = private constant [9 x i8] c"*Command\00" +@tn.str.266 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.267 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.268 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.269 = private constant [7 x i8] c"*Value\00" +@tn.str.270 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.271 = private constant [14 x i8] c"*Architecture\00" +@tn.str.272 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.273 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.274 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.275 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.276 = private constant [10 x i8] c"*[]string\00" +@tn.str.277 = private constant [6 x i8] c"*[]u8\00" +@tn.str.278 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.279 = private constant [11 x i8] c"*[]Command\00" +@tn.str.280 = private constant [6 x i8] c"**GPA\00" +@tn.str.281 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.282 = private constant [8 x i8] c"**Arena\00" +@tn.str.283 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.284 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.285 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.286 = private constant [7 x i8] c"**File\00" +@tn.str.287 = private constant [5 x i8] c"**u8\00" +@tn.str.288 = private constant [6 x i8] c"**s32\00" +@tn.str.289 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.290 = private constant [6 x i8] c"**u32\00" +@tn.str.291 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.292 = private constant [8 x i8] c"**Array\00" +@tn.str.293 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.294 = private constant [9 x i8] c"**Object\00" +@tn.str.295 = private constant [7 x i8] c"**Sink\00" +@tn.str.296 = private constant [9 x i8] c"**Parser\00" +@tn.str.297 = private constant [6 x i8] c"**s64\00" +@tn.str.298 = private constant [9 x i8] c"**Parsed\00" +@tn.str.299 = private constant [7 x i8] c"**Diag\00" +@tn.str.300 = private constant [9 x i8] c"**Sha256\00" +@tn.str.301 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.302 = private constant [8 x i8] c"***void\00" +@tn.str.303 = private constant [4 x i8] c"**A\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 [9 x i8] c"**[1]Any\00" +@tn.str.307 = private constant [8 x i8] c"**[]Any\00" +@tn.str.308 = private constant [7 x i8] c"**bool\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 [163 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.151, i64 4 }, { 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 2 }, { 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 3 }, { ptr, i64 } { ptr @tn.str.161, i64 3 }, { ptr, i64 } { ptr @tn.str.162, i64 6 }, { ptr, i64 } { ptr @tn.str.163, i64 3 }, { ptr, i64 } { ptr @tn.str.164, i64 8 }, { ptr, i64 } { ptr @tn.str.165, i64 5 }, { ptr, i64 } { ptr @tn.str.166, i64 5 }, { ptr, i64 } { ptr @tn.str.167, i64 4 }, { ptr, i64 } { ptr @tn.str.168, i64 5 }, { ptr, i64 } { ptr @tn.str.169, i64 15 }, { ptr, i64 } { ptr @tn.str.170, i64 9 }, { ptr, i64 } { ptr @tn.str.171, i64 7 }, { ptr, i64 } { ptr @tn.str.172, i64 6 }, { ptr, i64 } { ptr @tn.str.173, i64 8 }, { ptr, i64 } { ptr @tn.str.174, i64 10 }, { ptr, i64 } { ptr @tn.str.175, i64 11 }, { ptr, i64 } { ptr @tn.str.176, i64 3 }, { ptr, i64 } { ptr @tn.str.177, i64 4 }, { ptr, i64 } { ptr @tn.str.178, i64 10 }, { ptr, i64 } { ptr @tn.str.179, i64 11 }, { ptr, i64 } { ptr @tn.str.180, i64 5 }, { ptr, i64 } { ptr @tn.str.181, i64 6 }, { ptr, i64 } { ptr @tn.str.182, i64 5 }, { ptr, i64 } { ptr @tn.str.183, i64 8 }, { ptr, i64 } { ptr @tn.str.184, i64 9 }, { ptr, i64 } { ptr @tn.str.185, i64 17 }, { ptr, i64 } { ptr @tn.str.186, i64 18 }, { ptr, i64 } { ptr @tn.str.187, i64 8 }, { ptr, i64 } { ptr @tn.str.188, i64 8 }, { ptr, i64 } { ptr @tn.str.189, i64 4 }, { ptr, i64 } { ptr @tn.str.190, i64 5 }, { ptr, i64 } { ptr @tn.str.191, i64 5 }, { ptr, i64 } { ptr @tn.str.192, i64 7 }, { ptr, i64 } { ptr @tn.str.193, i64 10 }, { ptr, i64 } { ptr @tn.str.194, i64 3 }, { ptr, i64 } { ptr @tn.str.195, i64 13 }, { ptr, i64 } { ptr @tn.str.196, i64 14 }, { ptr, i64 } { ptr @tn.str.197, i64 4 }, { ptr, i64 } { ptr @tn.str.198, i64 8 }, { ptr, i64 } { ptr @tn.str.199, i64 9 }, { ptr, i64 } { ptr @tn.str.200, i64 4 }, { ptr, i64 } { ptr @tn.str.201, i64 9 }, { ptr, i64 } { ptr @tn.str.202, i64 5 }, { ptr, i64 } { ptr @tn.str.203, i64 6 }, { ptr, i64 } { ptr @tn.str.204, i64 5 }, { ptr, i64 } { ptr @tn.str.205, i64 6 }, { ptr, i64 } { ptr @tn.str.206, i64 8 }, { ptr, i64 } { ptr @tn.str.207, i64 6 }, { ptr, i64 } { ptr @tn.str.208, i64 9 }, { ptr, i64 } { ptr @tn.str.209, i64 7 }, { ptr, i64 } { ptr @tn.str.210, i64 4 }, { ptr, i64 } { ptr @tn.str.211, i64 4 }, { ptr, i64 } { ptr @tn.str.212, i64 5 }, { ptr, i64 } { ptr @tn.str.213, i64 16 }, { ptr, i64 } { ptr @tn.str.214, i64 14 }, { ptr, i64 } { ptr @tn.str.215, i64 21 }, { ptr, i64 } { ptr @tn.str.216, i64 6 }, { ptr, i64 } { ptr @tn.str.217, i64 7 }, { ptr, i64 } { ptr @tn.str.218, i64 24 }, { ptr, i64 } { ptr @tn.str.219, i64 23 }, { ptr, i64 } { ptr @tn.str.220, i64 15 }, { ptr, i64 } { ptr @tn.str.221, i64 12 }, { ptr, i64 } { ptr @tn.str.222, i64 12 }, { ptr, i64 } { ptr @tn.str.223, i64 10 }, { ptr, i64 } { ptr @tn.str.224, i64 4 }, { ptr, i64 } { ptr @tn.str.225, i64 8 }, { ptr, i64 } { ptr @tn.str.226, i64 8 }, { ptr, i64 } { ptr @tn.str.227, i64 10 }, { ptr, i64 } { ptr @tn.str.228, i64 7 }, { ptr, i64 } { ptr @tn.str.229, i64 9 }, { ptr, i64 } { ptr @tn.str.230, i64 4 }, { ptr, i64 } { ptr @tn.str.231, i64 13 }, { ptr, i64 } { ptr @tn.str.232, i64 6 }, { ptr, i64 } { ptr @tn.str.233, i64 7 }, { ptr, i64 } { ptr @tn.str.234, i64 18 }, { ptr, i64 } { ptr @tn.str.235, i64 9 }, { ptr, i64 } { ptr @tn.str.236, i64 5 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 6 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 7 }, { ptr, i64 } { ptr @tn.str.241, i64 7 }, { ptr, i64 } { ptr @tn.str.242, i64 7 }, { ptr, i64 } { ptr @tn.str.243, i64 1 }, { ptr, i64 } { ptr @tn.str.244, i64 1 }, { ptr, i64 } { ptr @tn.str.245, i64 12 }, { ptr, i64 } { ptr @tn.str.246, i64 6 }, { ptr, i64 } { ptr @tn.str.247, i64 2 }, { ptr, i64 } { ptr @tn.str.248, i64 7 }, { ptr, i64 } { ptr @tn.str.249, i64 5 }, { ptr, i64 } { ptr @tn.str.250, i64 4 }, { ptr, i64 } { ptr @tn.str.251, i64 6 }, { ptr, i64 } { ptr @tn.str.252, i64 7 }, { ptr, i64 } { ptr @tn.str.253, i64 6 }, { ptr, i64 } { ptr @tn.str.254, i64 5 }, { ptr, i64 } { ptr @tn.str.255, i64 7 }, { ptr, i64 } { ptr @tn.str.256, i64 4 }, { ptr, i64 } { ptr @tn.str.257, i64 16 }, { ptr, i64 } { ptr @tn.str.258, i64 10 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 11 }, { ptr, i64 } { ptr @tn.str.261, i64 14 }, { ptr, i64 } { ptr @tn.str.262, i64 7 }, { ptr, i64 } { ptr @tn.str.263, i64 13 }, { ptr, i64 } { ptr @tn.str.264, i64 9 }, { ptr, i64 } { ptr @tn.str.265, i64 8 }, { ptr, i64 } { ptr @tn.str.266, i64 10 }, { ptr, i64 } { ptr @tn.str.267, i64 9 }, { ptr, i64 } { ptr @tn.str.268, i64 9 }, { ptr, i64 } { ptr @tn.str.269, i64 6 }, { ptr, i64 } { ptr @tn.str.270, i64 16 }, { ptr, i64 } { ptr @tn.str.271, i64 13 }, { ptr, i64 } { ptr @tn.str.272, i64 14 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.278, i64 11 }, { ptr, i64 } { ptr @tn.str.279, i64 10 }, { ptr, i64 } { ptr @tn.str.280, i64 5 }, { ptr, i64 } { ptr @tn.str.281, i64 12 }, { ptr, i64 } { ptr @tn.str.282, i64 7 }, { ptr, i64 } { ptr @tn.str.283, i64 6 }, { ptr, i64 } { ptr @tn.str.284, i64 10 }, { ptr, i64 } { ptr @tn.str.285, i64 19 }, { ptr, i64 } { ptr @tn.str.286, i64 6 }, { ptr, i64 } { ptr @tn.str.287, i64 4 }, { ptr, i64 } { ptr @tn.str.288, i64 5 }, { ptr, i64 } { ptr @tn.str.289, i64 10 }, { ptr, i64 } { ptr @tn.str.290, i64 5 }, { ptr, i64 } { ptr @tn.str.291, i64 9 }, { ptr, i64 } { ptr @tn.str.292, i64 7 }, { ptr, i64 } { ptr @tn.str.293, i64 10 }, { 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 5 }, { 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 13 }, { ptr, i64 } { ptr @tn.str.302, i64 7 }, { ptr, i64 } { ptr @tn.str.303, i64 3 }, { ptr, i64 } { ptr @tn.str.304, i64 8 }, { ptr, i64 } { ptr @tn.str.305, i64 5 }, { ptr, i64 } { ptr @tn.str.306, i64 8 }, { ptr, i64 } { ptr @tn.str.307, i64 7 }, { ptr, i64 } { ptr @tn.str.308, i64 6 }, { 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.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 @frame.str = private unnamed_addr constant [35 x i8] c"1006-errors-inferred-error-sets.sx\00" -@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 [1 x i8] zeroinitializer, align 1 +@frame.str.334 = private unnamed_addr constant [5 x i8] c"leaf\00" +@frame.str.335 = 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.334, i64 4 }, { ptr, i64 } { ptr @frame.str.335, i64 33 } } +@frame.str.336 = private unnamed_addr constant [4 x i8] c"mid\00" +@frame.str.337 = private unnamed_addr constant [17 x i8] c" try leaf(n);\00" +@trace.frame.338 = 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.336, i64 3 }, { ptr, i64 } { ptr @frame.str.337, i64 16 } } +@frame.str.339 = private unnamed_addr constant [37 x i8] c" if n == 100 { raise error.Bar; }\00" +@trace.frame.340 = 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.336, i64 3 }, { ptr, i64 } { ptr @frame.str.339, i64 36 } } +@frame.str.341 = private unnamed_addr constant [4 x i8] c"run\00" +@frame.str.342 = private unnamed_addr constant [16 x i8] c" try mid(n);\00" +@trace.frame.343 = 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.341, i64 3 }, { ptr, i64 } { ptr @frame.str.342, i64 15 } } @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 +@str.345 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.346 = private unnamed_addr constant [21 x i8] c"inferred result: {}\0A\00", align 1 +@str.347 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1 +@str.348 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.349 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.350 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [5 x i8] c"file\00" -@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 }] +@fld.str.351 = private constant [5 x i8] c"line\00" +@fld.str.352 = private constant [4 x i8] c"col\00" +@fld.str.353 = 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.351, i64 4 }, { ptr, i64 } { ptr @fld.str.352, i64 3 }, { ptr, i64 } { ptr @fld.str.353, i64 4 }] +@str.354 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.355 = private unnamed_addr constant [10 x i8] c"Allocator\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 [4 x i8] c"ctx\00" +@fld.str.360 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.361 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.362 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.359, i64 3 }, { ptr, i64 } { ptr @fld.str.360, i64 11 }, { ptr, i64 } { ptr @fld.str.361, i64 13 }] +@str.363 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.364 = private unnamed_addr constant [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.369 = private constant [5 x i8] c"data\00" +@field_names.370 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.368, i64 9 }, { ptr, i64 } { ptr @fld.str.369, i64 4 }] +@str.371 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.372 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.376 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.377 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.378 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.383 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.382, i64 11 }] +@str.384 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.385 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.390 = private constant [4 x i8] c"cap\00" +@field_names.391 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.389, i64 4 }, { 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 [6 x i8] c"Arena\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 [6 x i8] c"first\00" +@fld.str.398 = private constant [10 x i8] c"end_index\00" +@fld.str.399 = private constant [7 x i8] c"parent\00" +@field_names.400 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.397, i64 5 }, { ptr, i64 } { ptr @fld.str.398, i64 9 }, { ptr, i64 } { ptr @fld.str.399, i64 6 }] +@str.401 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.402 = private unnamed_addr constant [9 x i8] c"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.407 = private constant [4 x i8] c"len\00" +@fld.str.408 = private constant [4 x i8] c"pos\00" +@field_names.409 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.406, i64 3 }, { ptr, i64 } { ptr @fld.str.407, i64 3 }, { 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 [8 x i8] c"Context\00", align 1 +@str.411 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.415 = private constant [7 x i8] c"parent\00" +@fld.str.416 = private constant [12 x i8] c"alloc_count\00" +@fld.str.417 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.418 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.419 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.415, i64 6 }, { ptr, i64 } { ptr @fld.str.416, i64 11 }, { ptr, i64 } { ptr @fld.str.417, i64 13 }, { ptr, i64 } { ptr @fld.str.418, i64 17 }] +@str.420 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.421 = private unnamed_addr constant [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.426 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.425, i64 2 }] +@str.427 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.428 = private unnamed_addr constant [11 x i8] c"TraceFrame\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 [5 x i8] c"file\00" +@fld.str.433 = private constant [5 x i8] c"line\00" +@fld.str.434 = private constant [4 x i8] c"col\00" +@fld.str.435 = private constant [5 x i8] c"func\00" +@fld.str.436 = private constant [10 x i8] c"line_text\00" +@field_names.437 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.432, i64 4 }, { ptr, i64 } { ptr @fld.str.433, i64 4 }, { ptr, i64 } { ptr @fld.str.434, i64 3 }, { ptr, i64 } { ptr @fld.str.435, i64 4 }, { ptr, i64 } { ptr @fld.str.436, i64 9 }] +@str.438 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.439 = private unnamed_addr constant [14 x i8] c"ProcessResult\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"exit_code\00" +@fld.str.444 = private constant [7 x i8] c"stdout\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 6 }] +@str.446 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.447 = private unnamed_addr constant [9 x i8] c"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.452 = private constant [11 x i8] c"sin_family\00" +@fld.str.453 = private constant [9 x i8] c"sin_port\00" +@fld.str.454 = private constant [9 x i8] c"sin_addr\00" +@fld.str.455 = private constant [9 x i8] c"sin_zero\00" +@field_names.456 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.451, i64 7 }, { ptr, i64 } { ptr @fld.str.452, i64 10 }, { ptr, i64 } { ptr @fld.str.453, i64 8 }, { ptr, i64 } { ptr @fld.str.454, i64 8 }, { ptr, i64 } { ptr @fld.str.455, i64 8 }] +@str.457 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.458 = private unnamed_addr constant [6 x i8] c"Array\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"Object\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 [6 x i8] c"items\00" +@fld.str.472 = private constant [4 x i8] c"len\00" +@fld.str.473 = private constant [4 x i8] c"cap\00" +@field_names.474 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.471, i64 5 }, { ptr, i64 } { ptr @fld.str.472, i64 3 }, { ptr, i64 } { ptr @fld.str.473, i64 3 }] +@str.475 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.476 = private unnamed_addr constant [7 x i8] c"Member\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"key\00" +@fld.str.481 = private constant [4 x i8] c"val\00" +@field_names.482 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.480, i64 3 }, { ptr, i64 } { ptr @fld.str.481, i64 3 }] +@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.484 = private unnamed_addr constant [5 x i8] c"Sink\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"dst\00" +@fld.str.489 = private constant [4 x i8] c"pos\00" +@fld.str.490 = private constant [5 x i8] c"file\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 4 }] +@str.492 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.493 = private unnamed_addr constant [7 x i8] c"Parser\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 [4 x i8] c"src\00" +@fld.str.498 = private constant [4 x i8] c"pos\00" +@fld.str.499 = private constant [6 x i8] c"alloc\00" +@field_names.500 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.497, i64 3 }, { ptr, i64 } { ptr @fld.str.498, i64 3 }, { ptr, i64 } { ptr @fld.str.499, i64 5 }] +@str.501 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.502 = private unnamed_addr constant [13 x i8] c"BuildOptions\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 +@field_names.506 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.507 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.508 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.513 = private constant [12 x i8] c"takes_value\00" +@fld.str.514 = private constant [9 x i8] c"required\00" +@field_names.515 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.512, i64 4 }, { ptr, i64 } { ptr @fld.str.513, i64 11 }, { ptr, i64 } { ptr @fld.str.514, i64 8 }] +@str.516 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.517 = private unnamed_addr constant [8 x i8] c"Command\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"group\00" +@fld.str.522 = private constant [8 x i8] c"command\00" +@fld.str.523 = private constant [6 x i8] c"flags\00" +@field_names.524 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.521, i64 5 }, { ptr, i64 } { ptr @fld.str.522, i64 7 }, { 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 [10 x i8] c"FlagValue\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"set\00" +@fld.str.531 = private constant [6 x i8] c"value\00" +@field_names.532 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.530, i64 3 }, { ptr, i64 } { ptr @fld.str.531, i64 5 }] +@str.533 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.534 = private unnamed_addr constant [5 x i8] c"Diag\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 [6 x i8] c"index\00" +@fld.str.539 = private constant [6 x i8] c"token\00" +@field_names.540 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.538, i64 5 }, { ptr, i64 } { ptr @fld.str.539, i64 5 }] +@str.541 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.542 = private unnamed_addr constant [7 x i8] c"Parsed\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 [6 x i8] c"group\00" +@fld.str.547 = private constant [8 x i8] c"command\00" +@fld.str.548 = private constant [10 x i8] c"cmd_index\00" +@fld.str.549 = private constant [5 x i8] c"json\00" +@fld.str.550 = private constant [5 x i8] c"rest\00" +@fld.str.551 = private constant [5 x i8] c"spec\00" +@fld.str.552 = private constant [7 x i8] c"values\00" +@field_names.553 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.546, i64 5 }, { ptr, i64 } { ptr @fld.str.547, i64 7 }, { ptr, i64 } { ptr @fld.str.548, i64 9 }, { ptr, i64 } { ptr @fld.str.549, i64 4 }, { ptr, i64 } { ptr @fld.str.550, i64 4 }, { ptr, i64 } { ptr @fld.str.551, i64 4 }, { ptr, i64 } { ptr @fld.str.552, i64 6 }] +@str.554 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.555 = private unnamed_addr constant [7 x i8] c"Sha256\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 +@str.558 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.559 = private constant [2 x i8] c"h\00" +@fld.str.560 = private constant [4 x i8] c"buf\00" +@fld.str.561 = private constant [8 x i8] c"buf_len\00" +@fld.str.562 = private constant [10 x i8] c"total_len\00" +@field_names.563 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.559, i64 1 }, { ptr, i64 } { ptr @fld.str.560, i64 3 }, { ptr, i64 } { ptr @fld.str.561, i64 7 }, { ptr, i64 } { ptr @fld.str.562, i64 9 }] +@str.564 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.565 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.566 = private constant [5 x i8] c"read\00" +@fld.str.567 = private constant [6 x i8] c"write\00" +@fld.str.568 = private constant [7 x i8] c"append\00" +@fld.str.569 = private constant [11 x i8] c"read_write\00" +@field_names.570 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.566, i64 4 }, { ptr, i64 } { ptr @fld.str.567, i64 5 }, { ptr, i64 } { ptr @fld.str.568, i64 6 }, { ptr, i64 } { ptr @fld.str.569, i64 10 }] +@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 [4 x i8] c"set\00" +@fld.str.575 = private constant [8 x i8] c"current\00" +@fld.str.576 = private constant [4 x i8] c"end\00" +@field_names.577 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.574, i64 3 }, { ptr, i64 } { ptr @fld.str.575, i64 7 }, { ptr, i64 } { ptr @fld.str.576, i64 3 }] +@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"null_\00" +@fld.str.582 = private constant [6 x i8] c"bool_\00" +@fld.str.583 = private constant [5 x i8] c"int_\00" +@fld.str.584 = private constant [4 x i8] c"str\00" +@fld.str.585 = private constant [6 x i8] c"array\00" +@fld.str.586 = private constant [7 x i8] c"object\00" +@field_names.587 = private constant [6 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 4 }, { ptr, i64 } { ptr @fld.str.584, i64 3 }, { ptr, i64 } { ptr @fld.str.585, i64 5 }, { ptr, i64 } { ptr @fld.str.586, i64 6 }] +@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 [6 x i8] c"macos\00" +@fld.str.592 = private constant [6 x i8] c"linux\00" +@fld.str.593 = private constant [8 x i8] c"windows\00" +@fld.str.594 = private constant [5 x i8] c"wasm\00" +@fld.str.595 = private constant [4 x i8] c"ios\00" +@fld.str.596 = private constant [8 x i8] c"android\00" +@fld.str.597 = private constant [8 x i8] c"unknown\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 5 }, { ptr, i64 } { ptr @fld.str.593, i64 7 }, { ptr, i64 } { ptr @fld.str.594, i64 4 }, { ptr, i64 } { ptr @fld.str.595, i64 3 }, { ptr, i64 } { ptr @fld.str.596, i64 7 }, { 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 +@fld.str.602 = private constant [8 x i8] c"aarch64\00" +@fld.str.603 = private constant [7 x i8] c"x86_64\00" +@fld.str.604 = private constant [7 x i8] c"wasm32\00" +@fld.str.605 = private constant [7 x i8] c"wasm64\00" +@fld.str.606 = private constant [8 x i8] c"unknown\00" +@field_names.607 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.602, i64 7 }, { ptr, i64 } { ptr @fld.str.603, i64 6 }, { ptr, i64 } { ptr @fld.str.604, i64 6 }, { ptr, i64 } { ptr @fld.str.605, i64 6 }, { ptr, i64 } { ptr @fld.str.606, i64 7 }] +@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 [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 [11 x i8] c"*error_set\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"*string\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"*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"*[1]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 [7 x i8] c"*[]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 [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 [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,85 +633,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -854,7 +776,7 @@ entry: br i1 %icmp, label %if.then.68, label %if.merge.69 if.then.68: ; preds = %entry - ret { ptr, i64 } { ptr @str.128, i64 1 } + ret { ptr, i64 } { ptr @str.130, i64 1 } if.merge.69: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -981,7 +903,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.129, i64 4 }, %if.then.90 ], [ { ptr @str.130, i64 5 }, %if.else.91 ] + %bp = phi { ptr, i64 } [ { ptr @str.131, i64 4 }, %if.then.90 ], [ { ptr @str.132, i64 5 }, %if.else.91 ] ret { ptr, i64 } %bp } @@ -1315,7 +1237,7 @@ entry: br i1 %icmp, label %if.then.381, label %if.merge.382 if.then.381: ; preds = %entry - ret { ptr, i64 } { ptr @str.131, i64 1 } + ret { ptr, i64 } { ptr @str.133, i64 1 } if.merge.382: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1465,7 +1387,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.132, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1492,12 +1414,12 @@ entry: i64 19, label %match.arm.55 i64 20, 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 24, label %match.arm.55 + i64 26, label %match.arm.55 + i64 28, label %match.arm.55 i64 30, label %match.arm.55 - i64 32, label %match.arm.55 - i64 34, label %match.arm.55 + i64 33, label %match.arm.55 + i64 35, label %match.arm.55 i64 39, label %match.arm.55 i64 43, label %match.arm.55 i64 45, label %match.arm.55 @@ -1524,25 +1446,25 @@ entry: i64 75, label %match.arm.57 i64 93, label %match.arm.57 i64 94, label %match.arm.57 - i64 35, label %match.arm.59 + i64 22, label %match.arm.59 i64 81, label %match.arm.59 i64 87, label %match.arm.59 i64 88, label %match.arm.59 i64 92, label %match.arm.59 i64 101, label %match.arm.59 - i64 36, label %match.arm.60 + i64 23, label %match.arm.60 i64 60, label %match.arm.60 i64 77, label %match.arm.60 i64 85, label %match.arm.60 i64 99, label %match.arm.60 i64 18, 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 25, label %match.arm.61 + i64 27, label %match.arm.61 i64 29, label %match.arm.61 i64 31, label %match.arm.61 - i64 33, label %match.arm.61 + i64 32, label %match.arm.61 + i64 34, label %match.arm.61 + i64 36, label %match.arm.61 i64 40, label %match.arm.61 i64 44, label %match.arm.61 i64 47, label %match.arm.61 @@ -1578,7 +1500,7 @@ match.merge.49: ; preds = %dispatch.merge.484, ret { ptr, i64 } %loadN match.arm.50: ; preds = %entry - store { ptr, i64 } { ptr @str.133, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.135, 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 @@ -1623,12 +1545,12 @@ match.arm.55: ; preds = %entry, %entry, %ent i64 19, label %dispatch.case.108 i64 20, label %dispatch.case.109 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 24, label %dispatch.case.111 + i64 26, label %dispatch.case.112 + i64 28, label %dispatch.case.113 i64 30, label %dispatch.case.114 - i64 32, label %dispatch.case.115 - i64 34, label %dispatch.case.116 + i64 33, label %dispatch.case.115 + i64 35, label %dispatch.case.116 i64 39, label %dispatch.case.117 i64 43, label %dispatch.case.118 i64 45, label %dispatch.case.119 @@ -1679,7 +1601,7 @@ match.arm.59: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.276 [ - i64 35, label %dispatch.case.277 + i64 22, label %dispatch.case.277 i64 81, label %dispatch.case.278 i64 87, label %dispatch.case.279 i64 88, label %dispatch.case.280 @@ -1692,7 +1614,7 @@ match.arm.60: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.314 [ - i64 36, label %dispatch.case.315 + i64 23, label %dispatch.case.315 i64 60, label %dispatch.case.316 i64 77, label %dispatch.case.317 i64 85, label %dispatch.case.318 @@ -1705,13 +1627,13 @@ 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 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 - i64 33, label %dispatch.case.354 + i64 25, label %dispatch.case.348 + i64 27, label %dispatch.case.349 + i64 29, label %dispatch.case.350 + i64 31, label %dispatch.case.351 + i64 32, label %dispatch.case.352 + i64 34, label %dispatch.case.353 + i64 36, label %dispatch.case.354 i64 40, label %dispatch.case.355 i64 44, label %dispatch.case.356 i64 47, label %dispatch.case.357 @@ -1805,7 +1727,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.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.108: ; preds = %match.arm.55 @@ -1827,56 +1749,56 @@ dispatch.case.109: ; preds = %match.arm.55 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 {}, ptr %ua.ptr69, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) + %ua.load70 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %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 { 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.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, 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.106 dispatch.case.113: ; preds = %match.arm.55 %ua.raw80 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr81 = inttoptr i64 %ua.raw80 to ptr - %ua.load82 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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.106 dispatch.case.114: ; preds = %match.arm.55 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.115: ; preds = %match.arm.55 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 dispatch.case.116: ; preds = %match.arm.55 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.106 @@ -2014,7 +1936,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.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.258 dispatch.case.260: ; preds = %match.arm.56 @@ -2055,7 +1977,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.313, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.275 dispatch.case.277: ; preds = %match.arm.59 @@ -2112,7 +2034,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.314, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.316, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.313 dispatch.case.315: ; preds = %match.arm.60 @@ -2161,7 +2083,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.315, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.317, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.345 dispatch.case.347: ; preds = %match.arm.61 @@ -2387,7 +2309,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.316, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.318, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.484 dispatch.case.486: ; preds = %match.arm.62 @@ -2429,7 +2351,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 @@ -2525,7 +2447,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.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 @@ -2533,7 +2455,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.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 @@ -2543,13 +2465,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.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.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.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 @@ -2557,7 +2479,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.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 @@ -2571,7 +2493,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.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 @@ -2579,7 +2501,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.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 @@ -2590,7 +2512,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.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 @@ -2647,7 +2569,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.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 @@ -2655,7 +2577,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.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 @@ -2666,7 +2588,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.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 @@ -2686,7 +2608,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.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 @@ -2694,7 +2616,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.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 @@ -2705,7 +2627,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.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.48 @@ -2715,67 +2637,151 @@ if.merge.48: ; preds = %if.then.47, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2951,166 +2957,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3308,64 +3314,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3395,97 +3401,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3524,7 +3530,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @leaf(ptr %0, i32 %1) #0 { @@ -3570,7 +3576,7 @@ if.merge.5: ; preds = %try.ok.3 } ; Function Attrs: nounwind -define internal i32 @run.127(ptr %0, i32 %1) #0 { +define internal i32 @run.129(ptr %0, i32 %1) #0 { entry: %alloca = alloca i32, align 4 store i32 %1, ptr %alloca, align 4 @@ -3589,7 +3595,7 @@ try.ok.7: ; preds = %entry ; Function Attrs: nounwind define i32 @main() #0 { entry: - %call = call i32 @run.127(ptr @__sx_default_context, i32 -1) + %call = call i32 @run.129(ptr @__sx_default_context, i32 -1) %alloca = alloca i32, align 4 store i32 %call, ptr %alloca, align 4 %allocaN = alloca i32, align 4 @@ -3640,7 +3646,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.342, i64 20 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.344, 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 @@ -3656,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.343, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.345, 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) @@ -3684,7 +3690,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.344, i64 20 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.346, i64 20 }) ret { ptr, i64 } %call } @@ -3695,7 +3701,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.345, i64 15 }, { ptr, i64 } { ptr @str.346, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.347, i64 15 }, { ptr, i64 } { ptr @str.348, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3714,12 +3720,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.347, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.349, 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.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 br label %if.merge.137 @@ -3731,7 +3737,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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3788,7 +3794,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.353, i64 9 }, { ptr, i64 } { ptr @str.354, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.355, i64 9 }, { 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 @@ -3807,24 +3813,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.355, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.357, 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.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 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 [3 x { ptr, i64 }], ptr @field_names.360, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -3868,20 +3874,21 @@ fv.case21: ; preds = %if.merge.142 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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.362, i64 10 }, { ptr, i64 } { ptr @str.363, i64 1 }) + %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.364, i64 7 }, { 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.143 -while.hdr.143: ; preds = %if.merge.147, %entry +while.hdr.143: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 2 br i1 %icmp, label %while.body.144, label %while.exit.145 while.body.144: ; preds = %while.hdr.143 @@ -3891,24 +3898,102 @@ while.body.144: ; preds = %while.hdr.143 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 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, 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 }) + %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.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.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.367, i64 2 }) + %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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.143 + +fv.default: ; preds = %if.merge.147 + br label %fv.merge + +fv.case: ; preds = %if.merge.147 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.147 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.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.148 + +while.hdr.148: ; preds = %if.merge.152, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + 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.374, 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.375, 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 [0 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 %alloca, align 1 @@ -3919,7 +4004,7 @@ if.merge.147: ; preds = %if.then.146, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.143 + br label %while.hdr.148 } ; Function Attrs: nounwind @@ -3927,43 +4012,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.378, i64 3 }, { 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.148 + br label %while.hdr.153 -while.hdr.148: ; preds = %fv.merge, %entry +while.hdr.153: ; 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 + br i1 %icmp, label %while.body.154, label %while.exit.155 -while.body.149: ; preds = %while.hdr.148 +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.151, label %if.merge.152 + br i1 %icmpN, label %if.then.156, label %if.merge.157 -while.exit.150: ; preds = %while.hdr.148 +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.370, 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.151: ; preds = %while.body.149 +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.371, 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.152 + br label %if.merge.157 -if.merge.152: ; preds = %if.then.151, %while.body.149 +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 [1 x { ptr, i64 }], ptr @field_names.373, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.374, 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 { i64 }, ptr %alloca, align 8 @@ -3980,12 +4065,12 @@ 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.148 + br label %while.hdr.153 -fv.default: ; preds = %if.merge.152 +fv.default: ; preds = %if.merge.157 br label %fv.merge -fv.case: ; preds = %if.merge.152 +fv.case: ; preds = %if.merge.157 %fv.field = extractvalue { i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge @@ -3996,43 +4081,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.385, i64 10 }, { 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.153 + br label %while.hdr.158 -while.hdr.153: ; preds = %fv.merge, %entry +while.hdr.158: ; 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 + br i1 %icmp, label %while.body.159, label %while.exit.160 -while.body.154: ; preds = %while.hdr.153 +while.body.159: ; preds = %while.hdr.158 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.156, label %if.merge.157 + br i1 %icmpN, label %if.then.161, label %if.merge.162 -while.exit.155: ; preds = %while.hdr.153 +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.377, 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.156: ; preds = %while.body.154 +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.378, 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.157 + br label %if.merge.162 -if.merge.157: ; preds = %if.then.156, %while.body.154 +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 [2 x { ptr, i64 }], ptr @field_names.381, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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.382, 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 }, ptr %alloca, align 8 @@ -4050,18 +4135,18 @@ 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.153 + br label %while.hdr.158 -fv.default: ; preds = %if.merge.157 +fv.default: ; preds = %if.merge.162 br label %fv.merge -fv.case: ; preds = %if.merge.157 +fv.case: ; preds = %if.merge.162 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.157 +fv.case17: ; preds = %if.merge.162 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -4073,91 +4158,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.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 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.158 - -while.hdr.158: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.159, label %while.exit.160 - -while.body.159: ; preds = %while.hdr.158 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.161, label %if.merge.162 - -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.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.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.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 { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.158 - -fv.default: ; preds = %if.merge.162 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.162 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 8 }, { ptr, i64 } { ptr @str.393, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.393, i64 5 }, { 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 @@ -4176,27 +4177,27 @@ 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.394, 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.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.395, 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.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.399, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.400, 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, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4218,29 +4219,30 @@ fv.default: ; preds = %if.merge.167 br label %fv.merge fv.case: ; preds = %if.merge.167 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.167 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.167 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.401, i64 17 }, { ptr, i64 } { ptr @str.402, i64 1 }) + %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.402, i64 8 }, { 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 @@ -4249,7 +4251,7 @@ entry: while.hdr.168: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.169, label %while.exit.170 while.body.169: ; preds = %while.hdr.168 @@ -4259,19 +4261,19 @@ 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.403, 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.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.404, 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.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.409, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4279,17 +4281,16 @@ if.merge.172: ; preds = %if.then.171, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4302,35 +4303,29 @@ fv.default: ; preds = %if.merge.172 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.172 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.172 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.172 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.411, i64 7 }, { ptr, i64 } { ptr @str.412, i64 1 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.411, i64 17 }, { 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 @@ -4339,7 +4334,7 @@ entry: while.hdr.173: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.174, label %while.exit.175 while.body.174: ; preds = %while.hdr.173 @@ -4361,23 +4356,25 @@ if.then.176: ; preds = %while.body.174 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.417, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4390,16 +4387,25 @@ fv.default: ; preds = %if.merge.177 br label %fv.merge fv.case: ; preds = %if.merge.177 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.177 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.177 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.177 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4408,7 +4414,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.419, i64 4 }, { ptr, i64 } { ptr @str.420, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.421, i64 4 }, { 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 @@ -4427,24 +4433,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.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.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.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.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.424, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i32 }, ptr %alloca, align 4 @@ -4481,7 +4487,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.426, i64 10 }, { ptr, i64 } { ptr @str.427, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.428, i64 10 }, { 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 @@ -4500,24 +4506,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.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.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.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.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.435, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4583,7 +4589,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.437, i64 13 }, { ptr, i64 } { ptr @str.438, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.439, i64 13 }, { 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 @@ -4602,24 +4608,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.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.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.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.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.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 { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4661,7 +4667,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.445, i64 8 }, { ptr, i64 } { ptr @str.446, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.447, i64 8 }, { 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 @@ -4680,24 +4686,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.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.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.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.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.454, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4758,7 +4764,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.456, i64 5 }, { ptr, i64 } { ptr @str.457, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 5 }, { 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 @@ -4777,24 +4783,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.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.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.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.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.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 @@ -4840,7 +4846,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.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 @@ -4859,24 +4865,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.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.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.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.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.472, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.474, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 @@ -4924,7 +4930,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.474, i64 6 }, { ptr, i64 } { ptr @str.475, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.476, i64 6 }, { ptr, i64 } { ptr @str.477, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4943,24 +4949,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.476, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, 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.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 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.480, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, [24 x i8] } }, ptr %alloca, align 8 @@ -5004,7 +5010,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.482, i64 4 }, { ptr, i64 } { ptr @str.483, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 4 }, { 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 @@ -5023,24 +5029,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.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.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.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.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.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 %alloca, align 8 @@ -5090,7 +5096,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.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 @@ -5109,24 +5115,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.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.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.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.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.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, ptr, ptr } }, ptr %alloca, align 8 @@ -5175,7 +5181,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.500, i64 12 }, { ptr, i64 } { ptr @str.501, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.502, i64 12 }, { 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 @@ -5194,24 +5200,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.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.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.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.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.504, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 %alloca, align 1 @@ -5231,7 +5237,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.506, i64 8 }, { ptr, i64 } { ptr @str.507, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.508, i64 8 }, { 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 @@ -5250,24 +5256,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.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.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.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.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.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 }, i1, i1 }, ptr %alloca, align 8 @@ -5319,7 +5325,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.515, i64 7 }, { ptr, i64 } { ptr @str.516, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.517, i64 7 }, { 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 @@ -5338,24 +5344,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.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.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.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.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.522, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5407,7 +5413,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.524, i64 9 }, { ptr, i64 } { ptr @str.525, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.526, i64 9 }, { 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 @@ -5426,24 +5432,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.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.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.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.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.530, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5486,7 +5492,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.532, i64 4 }, { ptr, i64 } { ptr @str.533, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.534, i64 4 }, { 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 @@ -5505,24 +5511,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.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.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.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.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.538, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.540, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5568,7 +5574,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.540, i64 6 }, { ptr, i64 } { ptr @str.541, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.542, i64 6 }, { ptr, i64 } { ptr @str.543, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5587,24 +5593,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.542, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.544, 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.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 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.551, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 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 { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5661,7 +5667,7 @@ fv.case28: ; preds = %if.merge.252 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.252 @@ -5686,7 +5692,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.553, i64 6 }, { ptr, i64 } { ptr @str.554, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.555, i64 6 }, { ptr, i64 } { ptr @str.556, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5705,24 +5711,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.555, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.557, 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.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 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.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 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5781,9 +5787,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.568, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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.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, ptr %alloca, align 8 @@ -5802,8 +5808,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.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.266 @@ -5822,9 +5828,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.575, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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, ptr %alloca, align 8 @@ -5843,8 +5849,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.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.268 @@ -5874,9 +5880,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.585, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.587, 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, [24 x i8] }, ptr %alloca, align 8 @@ -5893,8 +5899,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.270 @@ -5972,9 +5978,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.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 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.588, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.590, 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 @@ -5993,8 +5999,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 @@ -6013,9 +6019,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.605, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.607, 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.599, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.601, 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 @@ -6034,8 +6040,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.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 } { ptr @str.609, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.608, 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 @@ -6052,7 +6058,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.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.283 @@ -6069,12 +6075,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.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.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.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.287 @@ -6103,7 +6109,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.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.288 @@ -6120,12 +6126,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.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.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.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.292 @@ -6155,7 +6161,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.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.293 @@ -6172,12 +6178,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.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.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.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.297 @@ -6205,7 +6211,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.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.298 @@ -6222,12 +6228,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.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.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.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.302 @@ -6256,7 +6262,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.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.303 @@ -6273,12 +6279,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.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.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.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.307 @@ -6307,7 +6313,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.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.308 @@ -6324,12 +6330,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.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.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.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.312 @@ -6359,7 +6365,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.320 @@ -6378,12 +6384,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.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.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.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.324 @@ -6412,7 +6418,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.325 @@ -6431,12 +6437,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.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.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.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.329 @@ -6465,7 +6471,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.330 @@ -6484,12 +6490,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.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.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.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.334 @@ -6519,7 +6525,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.335 @@ -6538,12 +6544,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.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.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.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.339 @@ -6573,7 +6579,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.340 @@ -6592,12 +6598,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.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.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.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.344 @@ -6639,12 +6645,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.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.380 if.merge.380: ; preds = %if.else.379, %if.then.378 - %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.378 ], [ %callN, %if.else.379 ] + %bp = phi { ptr, i64 } [ { ptr @str.643, i64 4 }, %if.then.378 ], [ %callN, %if.else.379 ] ret { ptr, i64 } %bp } @@ -6667,12 +6673,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.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.396 if.merge.396: ; preds = %if.else.395, %if.then.394 - %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] + %bp = phi { ptr, i64 } [ { ptr @str.646, i64 4 }, %if.then.394 ], [ %callN, %if.else.395 ] ret { ptr, i64 } %bp } @@ -6695,12 +6701,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.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.399 if.merge.399: ; preds = %if.else.398, %if.then.397 - %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] + %bp = phi { ptr, i64 } [ { ptr @str.649, i64 4 }, %if.then.397 ], [ %callN, %if.else.398 ] ret { ptr, i64 } %bp } @@ -6723,12 +6729,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.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.402 if.merge.402: ; preds = %if.else.401, %if.then.400 - %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] + %bp = phi { ptr, i64 } [ { ptr @str.652, i64 4 }, %if.then.400 ], [ %callN, %if.else.401 ] ret { ptr, i64 } %bp } @@ -6751,12 +6757,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.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.405 if.merge.405: ; preds = %if.else.404, %if.then.403 - %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] + %bp = phi { ptr, i64 } [ { ptr @str.655, i64 4 }, %if.then.403 ], [ %callN, %if.else.404 ] ret { ptr, i64 } %bp } @@ -6778,12 +6784,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.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.408 if.merge.408: ; preds = %if.else.407, %if.then.406 - %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] + %bp = phi { ptr, i64 } [ { ptr @str.658, i64 4 }, %if.then.406 ], [ %callN, %if.else.407 ] ret { ptr, i64 } %bp } @@ -6806,12 +6812,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.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.411 if.merge.411: ; preds = %if.else.410, %if.then.409 - %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] + %bp = phi { ptr, i64 } [ { ptr @str.661, i64 4 }, %if.then.409 ], [ %callN, %if.else.410 ] ret { ptr, i64 } %bp } @@ -6834,12 +6840,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.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.414 if.merge.414: ; preds = %if.else.413, %if.then.412 - %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.664, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -6862,12 +6868,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.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.417 if.merge.417: ; preds = %if.else.416, %if.then.415 - %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.667, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -6890,12 +6896,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.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.420 if.merge.420: ; preds = %if.else.419, %if.then.418 - %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.670, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -6918,12 +6924,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.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.423 if.merge.423: ; preds = %if.else.422, %if.then.421 - %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.673, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -6946,12 +6952,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.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.426 if.merge.426: ; preds = %if.else.425, %if.then.424 - %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.676, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -6974,12 +6980,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.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.429 if.merge.429: ; preds = %if.else.428, %if.then.427 - %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.679, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -7001,12 +7007,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.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.432 if.merge.432: ; preds = %if.else.431, %if.then.430 - %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.682, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -7029,12 +7035,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.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.435 if.merge.435: ; preds = %if.else.434, %if.then.433 - %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.685, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -7056,12 +7062,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.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.438 if.merge.438: ; preds = %if.else.437, %if.then.436 - %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.688, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7084,12 +7090,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.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.441 if.merge.441: ; preds = %if.else.440, %if.then.439 - %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.691, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7112,12 +7118,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.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.444 if.merge.444: ; preds = %if.else.443, %if.then.442 - %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.694, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7140,12 +7146,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.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.447 if.merge.447: ; preds = %if.else.446, %if.then.445 - %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.697, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7168,12 +7174,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.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.450 if.merge.450: ; preds = %if.else.449, %if.then.448 - %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.700, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7196,12 +7202,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.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.453 if.merge.453: ; preds = %if.else.452, %if.then.451 - %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.703, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7224,12 +7230,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.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.456 if.merge.456: ; preds = %if.else.455, %if.then.454 - %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.706, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7252,12 +7258,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.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.459 if.merge.459: ; preds = %if.else.458, %if.then.457 - %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.709, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7280,12 +7286,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.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.462 if.merge.462: ; preds = %if.else.461, %if.then.460 - %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.712, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7308,12 +7314,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.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.465 if.merge.465: ; preds = %if.else.464, %if.then.463 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7336,12 +7342,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.718, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 10 }, { 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 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.716, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7364,12 +7370,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.721, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 7 }, { 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 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.719, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7392,12 +7398,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.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.474 if.merge.474: ; preds = %if.else.473, %if.then.472 - %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7420,12 +7426,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.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.477 if.merge.477: ; preds = %if.else.476, %if.then.475 - %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7448,12 +7454,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.730, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 6 }, { 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 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.728, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] + %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] ret { ptr, i64 } %bp } @@ -7476,12 +7482,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.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.483 if.merge.483: ; preds = %if.else.482, %if.then.481 - %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] + %bp = phi { ptr, i64 } [ { ptr @str.733, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] ret { ptr, i64 } %bp } @@ -7497,7 +7503,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 }, i1 }, ptr %alloca, align 4 @@ -7521,7 +7527,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 { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7545,7 +7551,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 { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7569,7 +7575,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 { [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 9d10ec5..7c8f48d 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.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 +@str.129 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.130 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.131 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.133 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.134 = 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.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 }] +@tag.str.135 = private constant [9 x i8] c"Overflow\00" +@tag.str.136 = private constant [3 x i8] c"Io\00" +@tag.str.137 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.138 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.139 = private constant [10 x i8] c"BadEscape\00" +@tag.str.140 = private constant [10 x i8] c"BadNumber\00" +@tag.str.141 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.142 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.143 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.144 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.145 = private constant [13 x i8] c"MissingValue\00" +@tag.str.146 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.147 = private constant [13 x i8] c"TooManyFlags\00" +@tag.str.148 = private constant [4 x i8] c"Bad\00" +@tag.str.149 = 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.135, i64 8 }, { ptr, i64 } { ptr @tag.str.136, i64 2 }, { ptr, i64 } { ptr @tag.str.137, i64 15 }, { ptr, i64 } { ptr @tag.str.138, i64 13 }, { ptr, i64 } { ptr @tag.str.139, i64 9 }, { ptr, i64 } { ptr @tag.str.140, i64 9 }, { ptr, i64 } { ptr @tag.str.141, i64 15 }, { ptr, i64 } { ptr @tag.str.142, i64 14 }, { ptr, i64 } { ptr @tag.str.143, i64 14 }, { ptr, i64 } { ptr @tag.str.144, i64 11 }, { ptr, i64 } { ptr @tag.str.145, i64 12 }, { ptr, i64 } { ptr @tag.str.146, i64 15 }, { ptr, i64 } { ptr @tag.str.147, i64 12 }, { ptr, i64 } { ptr @tag.str.148, i64 3 }, { ptr, i64 } { ptr @tag.str.149, i64 5 }] @tn.str = private constant [13 x i8] c"\00" -@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 +@tn.str.150 = private constant [5 x i8] c"bool\00" +@tn.str.151 = private constant [3 x i8] c"s8\00" +@tn.str.152 = private constant [4 x i8] c"s16\00" +@tn.str.153 = private constant [4 x i8] c"s32\00" +@tn.str.154 = private constant [4 x i8] c"s64\00" +@tn.str.155 = private constant [3 x i8] c"u8\00" +@tn.str.156 = private constant [4 x i8] c"u16\00" +@tn.str.157 = private constant [4 x i8] c"u32\00" +@tn.str.158 = private constant [4 x i8] c"u64\00" +@tn.str.159 = private constant [4 x i8] c"f32\00" +@tn.str.160 = private constant [4 x i8] c"f64\00" +@tn.str.161 = private constant [7 x i8] c"string\00" +@tn.str.162 = private constant [4 x i8] c"Any\00" +@tn.str.163 = private constant [9 x i8] c"noreturn\00" +@tn.str.164 = private constant [6 x i8] c"isize\00" +@tn.str.165 = private constant [6 x i8] c"usize\00" +@tn.str.166 = private constant [5 x i8] c"void\00" +@tn.str.167 = private constant [6 x i8] c"*void\00" +@tn.str.168 = private constant [16 x i8] c"Source_Location\00" +@tn.str.169 = private constant [10 x i8] c"Allocator\00" +@tn.str.170 = private constant [8 x i8] c"Context\00" +@tn.str.171 = private constant [7 x i8] c"[4]s64\00" +@tn.str.172 = private constant [9 x i8] c"[]string\00" +@tn.str.173 = private constant [11 x i8] c"CAllocator\00" +@tn.str.174 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.175 = private constant [4 x i8] c"GPA\00" +@tn.str.176 = private constant [5 x i8] c"*GPA\00" +@tn.str.177 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.178 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.179 = private constant [6 x i8] c"Arena\00" +@tn.str.180 = private constant [7 x i8] c"*Arena\00" +@tn.str.181 = private constant [6 x i8] c"[*]u8\00" +@tn.str.182 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.183 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.184 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.185 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.186 = private constant [9 x i8] c"OpenMode\00" +@tn.str.187 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.188 = private constant [5 x i8] c"File\00" +@tn.str.189 = private constant [6 x i8] c"*File\00" +@tn.str.190 = private constant [6 x i8] c"?File\00" +@tn.str.191 = private constant [8 x i8] c"?string\00" +@tn.str.192 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.193 = private constant [4 x i8] c"*u8\00" +@tn.str.194 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.195 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.196 = private constant [5 x i8] c"*s32\00" +@tn.str.197 = private constant [9 x i8] c"SockAddr\00" +@tn.str.198 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.199 = private constant [5 x i8] c"*u32\00" +@tn.str.200 = private constant [10 x i8] c"JsonError\00" +@tn.str.201 = private constant [6 x i8] c"Array\00" +@tn.str.202 = private constant [7 x i8] c"Object\00" +@tn.str.203 = private constant [6 x i8] c"Value\00" +@tn.str.204 = private constant [7 x i8] c"Member\00" +@tn.str.205 = private constant [9 x i8] c"[*]Value\00" +@tn.str.206 = private constant [7 x i8] c"*Array\00" +@tn.str.207 = private constant [10 x i8] c"[*]Member\00" +@tn.str.208 = private constant [8 x i8] c"*Object\00" +@tn.str.209 = private constant [5 x i8] c"[]u8\00" +@tn.str.210 = private constant [5 x i8] c"Sink\00" +@tn.str.211 = private constant [6 x i8] c"*Sink\00" +@tn.str.212 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.213 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.214 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.215 = private constant [7 x i8] c"Parser\00" +@tn.str.216 = private constant [8 x i8] c"*Parser\00" +@tn.str.217 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.218 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.219 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.220 = private constant [13 x i8] c"Architecture\00" +@tn.str.221 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.222 = private constant [11 x i8] c"() -> bool\00" +@tn.str.223 = private constant [5 x i8] c"*s64\00" +@tn.str.224 = private constant [9 x i8] c"CliError\00" +@tn.str.225 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.226 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.227 = private constant [8 x i8] c"Command\00" +@tn.str.228 = private constant [10 x i8] c"FlagValue\00" +@tn.str.229 = private constant [5 x i8] c"Diag\00" +@tn.str.230 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.231 = private constant [7 x i8] c"Parsed\00" +@tn.str.232 = private constant [8 x i8] c"*Parsed\00" +@tn.str.233 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.234 = private constant [10 x i8] c"[]Command\00" +@tn.str.235 = private constant [6 x i8] c"*Diag\00" +@tn.str.236 = private constant [7 x i8] c"[8]s64\00" +@tn.str.237 = private constant [7 x i8] c"[64]u8\00" +@tn.str.238 = private constant [7 x i8] c"Sha256\00" +@tn.str.239 = private constant [8 x i8] c"*Sha256\00" +@tn.str.240 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.241 = private constant [8 x i8] c"[64]s64\00" +@tn.str.242 = private constant [2 x i8] c"E\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"*E\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"**E\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 [162 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.150, i64 4 }, { 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 2 }, { 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 3 }, { ptr, i64 } { ptr @tn.str.161, i64 6 }, { ptr, i64 } { ptr @tn.str.162, i64 3 }, { ptr, i64 } { ptr @tn.str.163, i64 8 }, { ptr, i64 } { ptr @tn.str.164, i64 5 }, { ptr, i64 } { ptr @tn.str.165, i64 5 }, { ptr, i64 } { ptr @tn.str.166, i64 4 }, { ptr, i64 } { ptr @tn.str.167, i64 5 }, { ptr, i64 } { ptr @tn.str.168, i64 15 }, { ptr, i64 } { ptr @tn.str.169, i64 9 }, { ptr, i64 } { ptr @tn.str.170, i64 7 }, { ptr, i64 } { ptr @tn.str.171, i64 6 }, { ptr, i64 } { ptr @tn.str.172, i64 8 }, { ptr, i64 } { ptr @tn.str.173, i64 10 }, { ptr, i64 } { ptr @tn.str.174, i64 11 }, { ptr, i64 } { ptr @tn.str.175, i64 3 }, { ptr, i64 } { ptr @tn.str.176, i64 4 }, { ptr, i64 } { ptr @tn.str.177, i64 10 }, { ptr, i64 } { ptr @tn.str.178, i64 11 }, { ptr, i64 } { ptr @tn.str.179, i64 5 }, { ptr, i64 } { ptr @tn.str.180, i64 6 }, { ptr, i64 } { ptr @tn.str.181, i64 5 }, { ptr, i64 } { ptr @tn.str.182, i64 8 }, { ptr, i64 } { ptr @tn.str.183, i64 9 }, { ptr, i64 } { ptr @tn.str.184, i64 17 }, { ptr, i64 } { ptr @tn.str.185, i64 18 }, { ptr, i64 } { ptr @tn.str.186, i64 8 }, { ptr, i64 } { ptr @tn.str.187, i64 8 }, { ptr, i64 } { ptr @tn.str.188, i64 4 }, { ptr, i64 } { ptr @tn.str.189, i64 5 }, { ptr, i64 } { ptr @tn.str.190, i64 5 }, { ptr, i64 } { ptr @tn.str.191, i64 7 }, { ptr, i64 } { ptr @tn.str.192, i64 10 }, { ptr, i64 } { ptr @tn.str.193, i64 3 }, { ptr, i64 } { ptr @tn.str.194, i64 13 }, { ptr, i64 } { ptr @tn.str.195, i64 14 }, { ptr, i64 } { ptr @tn.str.196, i64 4 }, { ptr, i64 } { ptr @tn.str.197, i64 8 }, { ptr, i64 } { ptr @tn.str.198, i64 9 }, { ptr, i64 } { ptr @tn.str.199, i64 4 }, { ptr, i64 } { ptr @tn.str.200, i64 9 }, { ptr, i64 } { ptr @tn.str.201, i64 5 }, { ptr, i64 } { ptr @tn.str.202, i64 6 }, { ptr, i64 } { ptr @tn.str.203, i64 5 }, { ptr, i64 } { ptr @tn.str.204, i64 6 }, { ptr, i64 } { ptr @tn.str.205, i64 8 }, { ptr, i64 } { ptr @tn.str.206, i64 6 }, { ptr, i64 } { ptr @tn.str.207, i64 9 }, { ptr, i64 } { ptr @tn.str.208, i64 7 }, { ptr, i64 } { ptr @tn.str.209, i64 4 }, { ptr, i64 } { ptr @tn.str.210, i64 4 }, { ptr, i64 } { ptr @tn.str.211, i64 5 }, { ptr, i64 } { ptr @tn.str.212, i64 16 }, { ptr, i64 } { ptr @tn.str.213, i64 14 }, { ptr, i64 } { ptr @tn.str.214, i64 21 }, { ptr, i64 } { ptr @tn.str.215, i64 6 }, { ptr, i64 } { ptr @tn.str.216, i64 7 }, { ptr, i64 } { ptr @tn.str.217, i64 24 }, { ptr, i64 } { ptr @tn.str.218, i64 23 }, { ptr, i64 } { ptr @tn.str.219, i64 15 }, { ptr, i64 } { ptr @tn.str.220, i64 12 }, { ptr, i64 } { ptr @tn.str.221, i64 12 }, { ptr, i64 } { ptr @tn.str.222, i64 10 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 8 }, { ptr, i64 } { ptr @tn.str.225, i64 8 }, { ptr, i64 } { ptr @tn.str.226, i64 10 }, { ptr, i64 } { ptr @tn.str.227, i64 7 }, { ptr, i64 } { ptr @tn.str.228, i64 9 }, { ptr, i64 } { ptr @tn.str.229, i64 4 }, { ptr, i64 } { ptr @tn.str.230, i64 13 }, { ptr, i64 } { ptr @tn.str.231, i64 6 }, { ptr, i64 } { ptr @tn.str.232, i64 7 }, { ptr, i64 } { ptr @tn.str.233, i64 18 }, { ptr, i64 } { ptr @tn.str.234, i64 9 }, { ptr, i64 } { ptr @tn.str.235, i64 5 }, { ptr, i64 } { ptr @tn.str.236, i64 6 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 6 }, { ptr, i64 } { ptr @tn.str.239, i64 7 }, { ptr, i64 } { ptr @tn.str.240, i64 7 }, { ptr, i64 } { ptr @tn.str.241, i64 7 }, { 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 [21 x i8] c"1009-errors-catch.sx\00" -@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 [1 x i8] zeroinitializer, align 1 +@frame.str.332 = private unnamed_addr constant [5 x i8] c"must\00" +@frame.str.333 = 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.332, i64 4 }, { ptr, i64 } { ptr @frame.str.333, i64 34 } } +@frame.str.334 = private unnamed_addr constant [37 x i8] c" if n == 0 { raise error.Empty; }\00" +@trace.frame.335 = 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.332, i64 4 }, { ptr, i64 } { ptr @frame.str.334, i64 36 } } +@frame.str.336 = private unnamed_addr constant [12 x i8] c"handle_some\00" +@frame.str.337 = private unnamed_addr constant [65 x i8] c" raise e; // re-raise the rest\00" +@trace.frame.338 = 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.336, i64 11 }, { ptr, i64 } { ptr @frame.str.337, i64 64 } } @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 +@str.340 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.341 = private unnamed_addr constant [18 x i8] c"catch result: {}\0A\00", align 1 +@str.342 = private unnamed_addr constant [16 x i8] c"Source_Location\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 @fld.str = private constant [5 x i8] c"file\00" -@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 }] +@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 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, 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.349 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.350 = private unnamed_addr constant [10 x i8] c"Allocator\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 [4 x i8] c"ctx\00" +@fld.str.355 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.356 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.357 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.354, i64 3 }, { ptr, i64 } { ptr @fld.str.355, i64 11 }, { ptr, i64 } { ptr @fld.str.356, i64 13 }] +@str.358 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.359 = private unnamed_addr constant [8 x i8] c"Context\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 [10 x i8] c"allocator\00" +@fld.str.364 = private constant [5 x i8] c"data\00" +@field_names.365 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.363, i64 9 }, { ptr, i64 } { ptr @fld.str.364, i64 4 }] +@str.366 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.367 = private unnamed_addr constant [11 x i8] c"CAllocator\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 +@field_names.371 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.372 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.373 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.378 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.377, i64 11 }] +@str.379 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.380 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00" +@fld.str.385 = private constant [4 x i8] c"cap\00" +@field_names.386 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.384, i64 4 }, { 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 [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 [8 x i8] c"Context\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 [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 +@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 [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.421 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.420, i64 2 }] +@str.422 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.423 = private unnamed_addr constant [11 x i8] c"TraceFrame\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 [5 x i8] c"file\00" +@fld.str.428 = private constant [5 x i8] c"line\00" +@fld.str.429 = private constant [4 x i8] c"col\00" +@fld.str.430 = private constant [5 x i8] c"func\00" +@fld.str.431 = private constant [10 x i8] c"line_text\00" +@field_names.432 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.427, i64 4 }, { ptr, i64 } { ptr @fld.str.428, i64 4 }, { ptr, i64 } { ptr @fld.str.429, i64 3 }, { ptr, i64 } { ptr @fld.str.430, i64 4 }, { ptr, i64 } { ptr @fld.str.431, i64 9 }] +@str.433 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.434 = private unnamed_addr constant [14 x i8] c"ProcessResult\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 [10 x i8] c"exit_code\00" +@fld.str.439 = private constant [7 x i8] c"stdout\00" +@field_names.440 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.438, i64 9 }, { ptr, i64 } { ptr @fld.str.439, i64 6 }] +@str.441 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.442 = private unnamed_addr constant [9 x i8] c"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.447 = private constant [11 x i8] c"sin_family\00" +@fld.str.448 = private constant [9 x i8] c"sin_port\00" +@fld.str.449 = private constant [9 x i8] c"sin_addr\00" +@fld.str.450 = private constant [9 x i8] c"sin_zero\00" +@field_names.451 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.446, i64 7 }, { ptr, i64 } { ptr @fld.str.447, i64 10 }, { ptr, i64 } { ptr @fld.str.448, i64 8 }, { ptr, i64 } { ptr @fld.str.449, i64 8 }, { ptr, i64 } { ptr @fld.str.450, i64 8 }] +@str.452 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.453 = private unnamed_addr constant [6 x i8] c"Array\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 [6 x i8] c"items\00" +@fld.str.458 = private constant [4 x i8] c"len\00" +@fld.str.459 = private constant [4 x i8] c"cap\00" +@field_names.460 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.457, i64 5 }, { ptr, i64 } { ptr @fld.str.458, i64 3 }, { ptr, i64 } { ptr @fld.str.459, i64 3 }] +@str.461 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.462 = private unnamed_addr constant [7 x i8] c"Object\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"Member\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"key\00" +@fld.str.476 = private constant [4 x i8] c"val\00" +@field_names.477 = private constant [2 x { ptr, i64 }] [{ 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 [5 x i8] c"Sink\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"dst\00" +@fld.str.484 = private constant [4 x i8] c"pos\00" +@fld.str.485 = private constant [5 x i8] c"file\00" +@field_names.486 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.483, i64 3 }, { ptr, i64 } { ptr @fld.str.484, i64 3 }, { ptr, i64 } { ptr @fld.str.485, i64 4 }] +@str.487 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.488 = private unnamed_addr constant [7 x i8] c"Parser\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"src\00" +@fld.str.493 = private constant [4 x i8] c"pos\00" +@fld.str.494 = private constant [6 x i8] c"alloc\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 5 }] +@str.496 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.497 = private unnamed_addr constant [13 x i8] c"BuildOptions\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 +@field_names.501 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.502 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.503 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.508 = private constant [12 x i8] c"takes_value\00" +@fld.str.509 = private constant [9 x i8] c"required\00" +@field_names.510 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.507, i64 4 }, { ptr, i64 } { ptr @fld.str.508, i64 11 }, { ptr, i64 } { ptr @fld.str.509, i64 8 }] +@str.511 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.512 = private unnamed_addr constant [8 x i8] c"Command\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"group\00" +@fld.str.517 = private constant [8 x i8] c"command\00" +@fld.str.518 = private constant [6 x i8] c"flags\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 7 }, { 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 [10 x i8] c"FlagValue\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"set\00" +@fld.str.526 = private constant [6 x i8] c"value\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 5 }] +@str.528 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.529 = private unnamed_addr constant [5 x i8] c"Diag\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"index\00" +@fld.str.534 = private constant [6 x i8] c"token\00" +@field_names.535 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.533, i64 5 }, { 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 [7 x i8] c"Parsed\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"group\00" +@fld.str.542 = private constant [8 x i8] c"command\00" +@fld.str.543 = private constant [10 x i8] c"cmd_index\00" +@fld.str.544 = private constant [5 x i8] c"json\00" +@fld.str.545 = private constant [5 x i8] c"rest\00" +@fld.str.546 = private constant [5 x i8] c"spec\00" +@fld.str.547 = private constant [7 x i8] c"values\00" +@field_names.548 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.541, i64 5 }, { ptr, i64 } { ptr @fld.str.542, i64 7 }, { ptr, i64 } { ptr @fld.str.543, i64 9 }, { ptr, i64 } { ptr @fld.str.544, i64 4 }, { ptr, i64 } { ptr @fld.str.545, i64 4 }, { ptr, i64 } { ptr @fld.str.546, i64 4 }, { ptr, i64 } { ptr @fld.str.547, i64 6 }] +@str.549 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.550 = private unnamed_addr constant [7 x i8] c"Sha256\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 [2 x i8] c"h\00" +@fld.str.555 = private constant [4 x i8] c"buf\00" +@fld.str.556 = private constant [8 x i8] c"buf_len\00" +@fld.str.557 = private constant [10 x i8] c"total_len\00" +@field_names.558 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.554, i64 1 }, { ptr, i64 } { ptr @fld.str.555, i64 3 }, { ptr, i64 } { ptr @fld.str.556, i64 7 }, { ptr, i64 } { ptr @fld.str.557, i64 9 }] +@str.559 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.560 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.561 = private constant [5 x i8] c"read\00" +@fld.str.562 = private constant [6 x i8] c"write\00" +@fld.str.563 = private constant [7 x i8] c"append\00" +@fld.str.564 = private constant [11 x i8] c"read_write\00" +@field_names.565 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.561, i64 4 }, { ptr, i64 } { ptr @fld.str.562, i64 5 }, { ptr, i64 } { ptr @fld.str.563, i64 6 }, { ptr, i64 } { ptr @fld.str.564, i64 10 }] +@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 [4 x i8] c"set\00" +@fld.str.570 = private constant [8 x i8] c"current\00" +@fld.str.571 = private constant [4 x i8] c"end\00" +@field_names.572 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.569, i64 3 }, { ptr, i64 } { ptr @fld.str.570, i64 7 }, { ptr, i64 } { ptr @fld.str.571, i64 3 }] +@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"null_\00" +@fld.str.577 = private constant [6 x i8] c"bool_\00" +@fld.str.578 = private constant [5 x i8] c"int_\00" +@fld.str.579 = private constant [4 x i8] c"str\00" +@fld.str.580 = private constant [6 x i8] c"array\00" +@fld.str.581 = private constant [7 x i8] c"object\00" +@field_names.582 = private constant [6 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 4 }, { ptr, i64 } { ptr @fld.str.579, i64 3 }, { ptr, i64 } { ptr @fld.str.580, i64 5 }, { ptr, i64 } { ptr @fld.str.581, i64 6 }] +@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 [6 x i8] c"macos\00" +@fld.str.587 = private constant [6 x i8] c"linux\00" +@fld.str.588 = private constant [8 x i8] c"windows\00" +@fld.str.589 = private constant [5 x i8] c"wasm\00" +@fld.str.590 = private constant [4 x i8] c"ios\00" +@fld.str.591 = private constant [8 x i8] c"android\00" +@fld.str.592 = private constant [8 x i8] c"unknown\00" +@field_names.593 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.586, i64 5 }, { ptr, i64 } { ptr @fld.str.587, i64 5 }, { ptr, i64 } { ptr @fld.str.588, i64 7 }, { ptr, i64 } { ptr @fld.str.589, i64 4 }, { ptr, i64 } { ptr @fld.str.590, i64 3 }, { ptr, i64 } { ptr @fld.str.591, i64 7 }, { ptr, i64 } { ptr @fld.str.592, i64 7 }] +@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 +@fld.str.597 = private constant [8 x i8] c"aarch64\00" +@fld.str.598 = private constant [7 x i8] c"x86_64\00" +@fld.str.599 = private constant [7 x i8] c"wasm32\00" +@fld.str.600 = private constant [7 x i8] c"wasm64\00" +@fld.str.601 = private constant [8 x i8] c"unknown\00" +@field_names.602 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.597, i64 7 }, { ptr, i64 } { ptr @fld.str.598, i64 6 }, { ptr, i64 } { ptr @fld.str.599, i64 6 }, { ptr, i64 } { ptr @fld.str.600, i64 6 }, { ptr, i64 } { ptr @fld.str.601, i64 7 }] +@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 [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 [5 x i8] c"null\00", align 1 +@str.639 = private unnamed_addr constant [6 x i8] c"*void\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"*CAllocator\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 [5 x i8] c"*GPA\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 [12 x i8] c"*ArenaChunk\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 [7 x i8] c"*Arena\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 [6 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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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 [6 x i8] c"*File\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 [4 x i8] c"*u8\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"*s32\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"*SockAddr\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 [5 x i8] c"*u32\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 [9 x i8] c"[*]Value\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 [7 x i8] c"*Array\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 [10 x i8] c"[*]Member\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"*Object\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"*Sink\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"*Parser\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 [5 x i8] c"*s64\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"*Parsed\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 [6 x i8] c"*Diag\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 [8 x i8] c"*Sha256\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 [13 x i8] c"**CAllocator\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"**void\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 [11 x i8] c"*error_set\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 [5 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 [7 x i8] c"*[]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 [6 x i8] c"*bool\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 [5 x i8] c"null\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 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -629,85 +629,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -850,7 +772,7 @@ entry: br i1 %icmp, label %if.then.86, label %if.merge.87 if.then.86: ; preds = %entry - ret { ptr, i64 } { ptr @str.127, i64 1 } + ret { ptr, i64 } { ptr @str.129, i64 1 } if.merge.87: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -977,7 +899,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.128, i64 4 }, %if.then.108 ], [ { ptr @str.129, i64 5 }, %if.else.109 ] + %bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.108 ], [ { ptr @str.131, i64 5 }, %if.else.109 ] ret { ptr, i64 } %bp } @@ -1311,7 +1233,7 @@ entry: br i1 %icmp, label %if.then.399, label %if.merge.400 if.then.399: ; preds = %entry - ret { ptr, i64 } { ptr @str.130, i64 1 } + ret { ptr, i64 } { ptr @str.132, i64 1 } if.merge.400: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1461,7 +1383,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.131, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.133, 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,12 +1410,12 @@ entry: i64 19, label %match.arm.73 i64 20, 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 24, label %match.arm.73 + i64 26, label %match.arm.73 + i64 28, label %match.arm.73 i64 30, label %match.arm.73 - i64 32, label %match.arm.73 - i64 34, label %match.arm.73 + i64 33, label %match.arm.73 + i64 35, label %match.arm.73 i64 39, label %match.arm.73 i64 43, label %match.arm.73 i64 45, label %match.arm.73 @@ -1519,25 +1441,25 @@ entry: i64 64, label %match.arm.75 i64 75, label %match.arm.75 i64 93, label %match.arm.75 - i64 35, label %match.arm.77 + i64 22, label %match.arm.77 i64 81, label %match.arm.77 i64 87, label %match.arm.77 i64 88, label %match.arm.77 i64 92, label %match.arm.77 i64 100, label %match.arm.77 - i64 36, label %match.arm.78 + i64 23, label %match.arm.78 i64 60, label %match.arm.78 i64 77, label %match.arm.78 i64 85, label %match.arm.78 i64 98, label %match.arm.78 i64 18, 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 25, label %match.arm.79 + i64 27, label %match.arm.79 i64 29, label %match.arm.79 i64 31, label %match.arm.79 - i64 33, label %match.arm.79 + i64 32, label %match.arm.79 + i64 34, label %match.arm.79 + i64 36, label %match.arm.79 i64 40, label %match.arm.79 i64 44, label %match.arm.79 i64 47, label %match.arm.79 @@ -1573,7 +1495,7 @@ match.merge.67: ; preds = %dispatch.merge.502, ret { ptr, i64 } %loadN match.arm.68: ; preds = %entry - store { ptr, i64 } { ptr @str.132, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.134, 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 @@ -1618,12 +1540,12 @@ match.arm.73: ; preds = %entry, %entry, %ent i64 19, label %dispatch.case.126 i64 20, label %dispatch.case.127 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 24, label %dispatch.case.129 + i64 26, label %dispatch.case.130 + i64 28, label %dispatch.case.131 i64 30, label %dispatch.case.132 - i64 32, label %dispatch.case.133 - i64 34, label %dispatch.case.134 + i64 33, label %dispatch.case.133 + i64 35, label %dispatch.case.134 i64 39, label %dispatch.case.135 i64 43, label %dispatch.case.136 i64 45, label %dispatch.case.137 @@ -1674,7 +1596,7 @@ match.arm.77: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.294 [ - i64 35, label %dispatch.case.295 + i64 22, label %dispatch.case.295 i64 81, label %dispatch.case.296 i64 87, label %dispatch.case.297 i64 88, label %dispatch.case.298 @@ -1687,7 +1609,7 @@ match.arm.78: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.332 [ - i64 36, label %dispatch.case.333 + i64 23, label %dispatch.case.333 i64 60, label %dispatch.case.334 i64 77, label %dispatch.case.335 i64 85, label %dispatch.case.336 @@ -1700,13 +1622,13 @@ 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 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 - i64 33, label %dispatch.case.372 + i64 25, label %dispatch.case.366 + i64 27, label %dispatch.case.367 + i64 29, label %dispatch.case.368 + i64 31, label %dispatch.case.369 + i64 32, label %dispatch.case.370 + i64 34, label %dispatch.case.371 + i64 36, label %dispatch.case.372 i64 40, label %dispatch.case.373 i64 44, label %dispatch.case.374 i64 47, label %dispatch.case.375 @@ -1800,7 +1722,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.309, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.311, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.124 dispatch.case.126: ; preds = %match.arm.73 @@ -1822,56 +1744,56 @@ dispatch.case.127: ; preds = %match.arm.73 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 {}, ptr %ua.ptr69, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) + %ua.load70 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %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 { 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.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, 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.124 dispatch.case.131: ; preds = %match.arm.73 %ua.raw80 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr81 = inttoptr i64 %ua.raw80 to ptr - %ua.load82 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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.124 dispatch.case.132: ; preds = %match.arm.73 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.124 dispatch.case.133: ; preds = %match.arm.73 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.124 dispatch.case.134: ; preds = %match.arm.73 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.124 @@ -2009,7 +1931,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.310, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.312, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.276 dispatch.case.278: ; preds = %match.arm.74 @@ -2050,7 +1972,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.311, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.313, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.293 dispatch.case.295: ; preds = %match.arm.77 @@ -2107,7 +2029,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.312, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.314, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.331 dispatch.case.333: ; preds = %match.arm.78 @@ -2156,7 +2078,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.313, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.315, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.363 dispatch.case.365: ; preds = %match.arm.79 @@ -2382,7 +2304,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.314, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.316, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.502 dispatch.case.504: ; preds = %match.arm.80 @@ -2424,7 +2346,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 @@ -2520,7 +2442,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.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 @@ -2528,7 +2450,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.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 @@ -2538,13 +2460,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.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.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.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 @@ -2552,7 +2474,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.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 @@ -2566,7 +2488,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.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 @@ -2574,7 +2496,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.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 @@ -2585,7 +2507,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.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 @@ -2642,7 +2564,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.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 @@ -2650,7 +2572,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.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 @@ -2661,7 +2583,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.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 @@ -2681,7 +2603,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.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 @@ -2689,7 +2611,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.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 @@ -2700,7 +2622,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.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.66 @@ -2710,67 +2632,151 @@ if.merge.66: ; preds = %if.then.65, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -2946,166 +2952,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3303,64 +3309,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3390,97 +3396,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3519,7 +3525,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @must(ptr %0, i32 %1) #0 { @@ -3732,7 +3738,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.337, i64 17 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.339, 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 @@ -3748,7 +3754,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.338, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.340, 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) @@ -3776,7 +3782,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.339, i64 17 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.341, i64 17 }) ret { ptr, i64 } %call } @@ -3787,7 +3793,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.340, i64 15 }, { ptr, i64 } { ptr @str.341, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.342, i64 15 }, { ptr, i64 } { ptr @str.343, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3806,12 +3812,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.342, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.344, 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.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 br label %if.merge.155 @@ -3823,7 +3829,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.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 { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -3880,7 +3886,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.348, i64 9 }, { ptr, i64 } { ptr @str.349, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.350, i64 9 }, { 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 @@ -3899,24 +3905,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.350, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.352, 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.351, 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 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.355, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.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, ptr, ptr }, ptr %alloca, align 8 @@ -3960,20 +3966,21 @@ fv.case21: ; preds = %if.merge.160 } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { +define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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 }, 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.359, i64 7 }, { 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.161 -while.hdr.161: ; preds = %if.merge.165, %entry +while.hdr.161: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 0 + %icmp = icmp slt i64 %load, 2 br i1 %icmp, label %while.body.162, label %while.exit.163 while.body.162: ; preds = %while.hdr.161 @@ -3983,24 +3990,102 @@ 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.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.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 }) + %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.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.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.362, i64 2 }) + %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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load i64, ptr %allocaN, align 8 + switch i64 %loadN, label %fv.default [ + i64 0, label %fv.case + i64 1, label %fv.case17 + ] + +fv.merge: ; preds = %fv.default, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.161 + +fv.default: ; preds = %if.merge.165 + br label %fv.merge + +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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.165 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.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.166 + +while.hdr.166: ; preds = %if.merge.170, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + 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.369, 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.370, 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 [0 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 {}, ptr %alloca, align 1 @@ -4011,7 +4096,7 @@ if.merge.165: ; preds = %if.then.164, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.161 + br label %while.hdr.166 } ; Function Attrs: nounwind @@ -4019,43 +4104,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.373, i64 3 }, { 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.166 + br label %while.hdr.171 -while.hdr.166: ; preds = %fv.merge, %entry +while.hdr.171: ; 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 + br i1 %icmp, label %while.body.172, label %while.exit.173 -while.body.167: ; preds = %while.hdr.166 +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.169, label %if.merge.170 + br i1 %icmpN, label %if.then.174, label %if.merge.175 -while.exit.168: ; preds = %while.hdr.166 +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.365, 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.169: ; preds = %while.body.167 +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.366, 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.170 + br label %if.merge.175 -if.merge.170: ; preds = %if.then.169, %while.body.167 +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.368, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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.369, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64 }, ptr %alloca, align 8 @@ -4072,12 +4157,12 @@ 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.166 + br label %while.hdr.171 -fv.default: ; preds = %if.merge.170 +fv.default: ; preds = %if.merge.175 br label %fv.merge -fv.case: ; preds = %if.merge.170 +fv.case: ; preds = %if.merge.175 %fv.field = extractvalue { i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge @@ -4088,43 +4173,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.380, i64 10 }, { 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.171 + br label %while.hdr.176 -while.hdr.171: ; preds = %fv.merge, %entry +while.hdr.176: ; 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 + br i1 %icmp, label %while.body.177, label %while.exit.178 -while.body.172: ; preds = %while.hdr.171 +while.body.177: ; preds = %while.hdr.176 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.174, label %if.merge.175 + br i1 %icmpN, label %if.then.179, label %if.merge.180 -while.exit.173: ; preds = %while.hdr.171 +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.372, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.382, i64 1 }) ret { ptr, i64 } %callN -if.then.174: ; preds = %while.body.172 +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.373, 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 - br label %if.merge.175 + br label %if.merge.180 -if.merge.175: ; preds = %if.then.174, %while.body.172 +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.376, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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.377, 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 }, ptr %alloca, align 8 @@ -4142,18 +4227,18 @@ 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.171 + br label %while.hdr.176 -fv.default: ; preds = %if.merge.175 +fv.default: ; preds = %if.merge.180 br label %fv.merge -fv.case: ; preds = %if.merge.175 +fv.case: ; preds = %if.merge.180 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.175 +fv.case17: ; preds = %if.merge.180 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -4165,91 +4250,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.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 - store i64 0, ptr %allocaN, align 8 - br label %while.hdr.176 - -while.hdr.176: ; preds = %fv.merge, %entry - %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.177, label %while.exit.178 - -while.body.177: ; preds = %while.hdr.176 - %loadN = load i64, ptr %allocaN, align 8 - %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.179, label %if.merge.180 - -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.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.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.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 }) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.176 - -fv.default: ; preds = %if.merge.180 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.180 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.387, i64 8 }, { ptr, i64 } { ptr @str.388, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.388, i64 5 }, { 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 @@ -4268,27 +4269,27 @@ 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.389, 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.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.390, 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.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.394, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.395, 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, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4310,29 +4311,30 @@ fv.default: ; preds = %if.merge.185 br label %fv.merge fv.case: ; preds = %if.merge.185 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.185 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.185 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.396, i64 17 }, { ptr, i64 } { ptr @str.397, i64 1 }) + %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 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4341,7 +4343,7 @@ entry: while.hdr.186: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.187, label %while.exit.188 while.body.187: ; preds = %while.hdr.186 @@ -4351,19 +4353,19 @@ 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.398, 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.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.399, 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.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.404, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 @@ -4371,17 +4373,16 @@ if.merge.190: ; preds = %if.then.189, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4394,35 +4395,29 @@ fv.default: ; preds = %if.merge.190 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.190 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.190 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.190 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.406, i64 7 }, { ptr, i64 } { ptr @str.407, i64 1 }) + 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 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4431,7 +4426,7 @@ entry: while.hdr.191: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.192, label %while.exit.193 while.body.192: ; preds = %while.hdr.191 @@ -4453,23 +4448,25 @@ if.then.194: ; preds = %while.body.192 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.412, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.414, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %loadN = load { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4482,16 +4479,25 @@ fv.default: ; preds = %if.merge.195 br label %fv.merge fv.case: ; preds = %if.merge.195 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.195 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.195 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.195 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4500,7 +4506,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.414, i64 4 }, { ptr, i64 } { ptr @str.415, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.416, i64 4 }, { ptr, i64 } { ptr @str.417, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4519,24 +4525,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.416, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.418, 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.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 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.419, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i32 }, ptr %alloca, align 4 @@ -4573,7 +4579,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.421, i64 10 }, { ptr, i64 } { ptr @str.422, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.423, i64 10 }, { 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 @@ -4592,24 +4598,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.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.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.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.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.430, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4675,7 +4681,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.432, i64 13 }, { ptr, i64 } { ptr @str.433, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.434, i64 13 }, { 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 @@ -4694,24 +4700,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.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.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.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.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.438, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4753,7 +4759,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.440, i64 8 }, { ptr, i64 } { ptr @str.441, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.442, i64 8 }, { 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 @@ -4772,24 +4778,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.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.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.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.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.449, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -4850,7 +4856,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.451, i64 5 }, { ptr, i64 } { ptr @str.452, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.453, i64 5 }, { 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 @@ -4869,24 +4875,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.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.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.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.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.458, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { ptr, i64, i64 }, ptr %alloca, align 8 @@ -4932,7 +4938,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.460, i64 6 }, { ptr, i64 } { ptr @str.461, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.462, i64 6 }, { 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 @@ -4951,24 +4957,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.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.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.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.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.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 @@ -5016,7 +5022,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.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 @@ -5035,24 +5041,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.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.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.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.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.475, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.477, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5096,7 +5102,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.477, i64 4 }, { ptr, i64 } { ptr @str.478, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.479, i64 4 }, { ptr, i64 } { ptr @str.480, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5115,24 +5121,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.479, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.481, 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.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 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.484, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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, ptr }, ptr %alloca, align 8 @@ -5182,7 +5188,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.486, i64 6 }, { ptr, i64 } { ptr @str.487, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.488, i64 6 }, { 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 @@ -5201,24 +5207,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.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.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.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.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.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, ptr } }, ptr %alloca, align 8 @@ -5267,7 +5273,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.495, i64 12 }, { ptr, i64 } { ptr @str.496, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.497, i64 12 }, { 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 @@ -5286,24 +5292,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.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.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.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.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.499, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 {}, ptr %alloca, align 1 @@ -5323,7 +5329,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.501, i64 8 }, { ptr, i64 } { ptr @str.502, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.503, i64 8 }, { 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 @@ -5342,24 +5348,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.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.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.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.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.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 }, i1, i1 }, ptr %alloca, align 8 @@ -5411,7 +5417,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.510, i64 7 }, { ptr, i64 } { ptr @str.511, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.512, i64 7 }, { 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 @@ -5430,24 +5436,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.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.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.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.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.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 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5499,7 +5505,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.519, i64 9 }, { ptr, i64 } { ptr @str.520, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.521, i64 9 }, { 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 @@ -5518,24 +5524,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.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.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.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.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.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 { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5578,7 +5584,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.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 @@ -5597,24 +5603,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.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.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.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.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.533, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5660,7 +5666,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.535, i64 6 }, { ptr, i64 } { ptr @str.536, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.537, i64 6 }, { 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 @@ -5679,24 +5685,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.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.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.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.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.546, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 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 { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5753,7 +5759,7 @@ fv.case28: ; preds = %if.merge.270 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.270 @@ -5778,7 +5784,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.548, i64 6 }, { ptr, i64 } { ptr @str.549, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.550, i64 6 }, { ptr, i64 } { ptr @str.551, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5797,24 +5803,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.550, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.552, 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.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 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.556, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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 { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -5873,9 +5879,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.563, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.565, 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.558, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.560, 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 @@ -5894,8 +5900,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.284 @@ -5914,9 +5920,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.570, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.566, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.568, 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 @@ -5935,8 +5941,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.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.286 @@ -5966,9 +5972,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.580, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 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.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, [24 x i8] }, ptr %alloca, align 8 @@ -5985,8 +5991,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.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.288 @@ -6064,9 +6070,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.591, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.593, 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 @@ -6085,8 +6091,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.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 } { ptr @str.595, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.594, 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 @@ -6105,9 +6111,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.600, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.602, 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.594, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.596, 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 @@ -6126,8 +6132,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.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 } { ptr @str.604, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.603, 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 @@ -6144,7 +6150,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.603, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.605, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.301 @@ -6161,12 +6167,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.604, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.606, 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.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 br label %if.merge.305 @@ -6195,7 +6201,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.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.306 @@ -6212,12 +6218,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.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.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.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.310 @@ -6247,7 +6253,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.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.311 @@ -6264,12 +6270,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.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.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.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.315 @@ -6297,7 +6303,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.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.316 @@ -6314,12 +6320,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.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.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.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.320 @@ -6348,7 +6354,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.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.321 @@ -6365,12 +6371,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.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.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.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.325 @@ -6399,7 +6405,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.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.326 @@ -6416,12 +6422,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.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.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.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.330 @@ -6451,7 +6457,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.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.338 @@ -6470,12 +6476,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.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.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.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.342 @@ -6504,7 +6510,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.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.343 @@ -6523,12 +6529,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.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.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.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.347 @@ -6557,7 +6563,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.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.348 @@ -6576,12 +6582,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.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.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.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.352 @@ -6611,7 +6617,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.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.353 @@ -6630,12 +6636,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.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.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.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.357 @@ -6665,7 +6671,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.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.358 @@ -6684,12 +6690,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.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.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.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.362 @@ -6731,12 +6737,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.638, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.637, i64 5 }, { ptr, i64 } %callN) + %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 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.636, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] + %bp = phi { ptr, i64 } [ { ptr @str.638, i64 4 }, %if.then.396 ], [ %callN, %if.else.397 ] ret { ptr, i64 } %bp } @@ -6759,12 +6765,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.641, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.640, i64 11 }, { 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 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.639, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] + %bp = phi { ptr, i64 } [ { ptr @str.641, i64 4 }, %if.then.412 ], [ %callN, %if.else.413 ] ret { ptr, i64 } %bp } @@ -6787,12 +6793,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.644, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.643, i64 4 }, { 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 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.642, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] + %bp = phi { ptr, i64 } [ { ptr @str.644, i64 4 }, %if.then.415 ], [ %callN, %if.else.416 ] ret { ptr, i64 } %bp } @@ -6815,12 +6821,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.647, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.646, i64 11 }, { 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 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.645, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] + %bp = phi { ptr, i64 } [ { ptr @str.647, i64 4 }, %if.then.418 ], [ %callN, %if.else.419 ] ret { ptr, i64 } %bp } @@ -6843,12 +6849,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.650, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, i64 6 }, { 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 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.648, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] + %bp = phi { ptr, i64 } [ { ptr @str.650, i64 4 }, %if.then.421 ], [ %callN, %if.else.422 ] ret { ptr, i64 } %bp } @@ -6870,12 +6876,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.653, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.652, i64 5 }, { 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 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.651, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] + %bp = phi { ptr, i64 } [ { ptr @str.653, i64 4 }, %if.then.424 ], [ %callN, %if.else.425 ] ret { ptr, i64 } %bp } @@ -6898,12 +6904,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.656, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.655, i64 9 }, { 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 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.654, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] + %bp = phi { ptr, i64 } [ { ptr @str.656, i64 4 }, %if.then.427 ], [ %callN, %if.else.428 ] ret { ptr, i64 } %bp } @@ -6926,12 +6932,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.659, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.658, i64 18 }, { 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 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.657, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] + %bp = phi { ptr, i64 } [ { ptr @str.659, i64 4 }, %if.then.430 ], [ %callN, %if.else.431 ] ret { ptr, i64 } %bp } @@ -6954,12 +6960,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.662, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.661, i64 5 }, { 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 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.660, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] + %bp = phi { ptr, i64 } [ { ptr @str.662, i64 4 }, %if.then.433 ], [ %callN, %if.else.434 ] ret { ptr, i64 } %bp } @@ -6982,12 +6988,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.665, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.664, i64 3 }, { 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 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.663, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] + %bp = phi { ptr, i64 } [ { ptr @str.665, i64 4 }, %if.then.436 ], [ %callN, %if.else.437 ] ret { ptr, i64 } %bp } @@ -7010,12 +7016,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.668, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.667, i64 4 }, { 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 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.666, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] + %bp = phi { ptr, i64 } [ { ptr @str.668, i64 4 }, %if.then.439 ], [ %callN, %if.else.440 ] ret { ptr, i64 } %bp } @@ -7038,12 +7044,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.671, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, i64 9 }, { 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 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.669, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] + %bp = phi { ptr, i64 } [ { ptr @str.671, i64 4 }, %if.then.442 ], [ %callN, %if.else.443 ] ret { ptr, i64 } %bp } @@ -7066,12 +7072,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.674, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.673, i64 4 }, { 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 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.672, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] + %bp = phi { ptr, i64 } [ { ptr @str.674, i64 4 }, %if.then.445 ], [ %callN, %if.else.446 ] ret { ptr, i64 } %bp } @@ -7093,12 +7099,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.677, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.676, i64 8 }, { 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 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.675, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] + %bp = phi { ptr, i64 } [ { ptr @str.677, i64 4 }, %if.then.448 ], [ %callN, %if.else.449 ] ret { ptr, i64 } %bp } @@ -7121,12 +7127,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.680, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.679, i64 6 }, { 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 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.678, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] + %bp = phi { ptr, i64 } [ { ptr @str.680, i64 4 }, %if.then.451 ], [ %callN, %if.else.452 ] ret { ptr, i64 } %bp } @@ -7148,12 +7154,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.683, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.682, i64 9 }, { 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 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.681, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] + %bp = phi { ptr, i64 } [ { ptr @str.683, i64 4 }, %if.then.454 ], [ %callN, %if.else.455 ] ret { ptr, i64 } %bp } @@ -7176,12 +7182,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.686, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.685, i64 7 }, { 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 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.684, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] + %bp = phi { ptr, i64 } [ { ptr @str.686, i64 4 }, %if.then.457 ], [ %callN, %if.else.458 ] ret { ptr, i64 } %bp } @@ -7204,12 +7210,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.689, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.688, i64 5 }, { 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 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.687, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] + %bp = phi { ptr, i64 } [ { ptr @str.689, i64 4 }, %if.then.460 ], [ %callN, %if.else.461 ] ret { ptr, i64 } %bp } @@ -7232,12 +7238,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.692, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.691, i64 7 }, { 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 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.690, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] + %bp = phi { ptr, i64 } [ { ptr @str.692, i64 4 }, %if.then.463 ], [ %callN, %if.else.464 ] ret { ptr, i64 } %bp } @@ -7260,12 +7266,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.695, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.694, i64 4 }, { 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 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.693, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] + %bp = phi { ptr, i64 } [ { ptr @str.695, i64 4 }, %if.then.466 ], [ %callN, %if.else.467 ] ret { ptr, i64 } %bp } @@ -7288,12 +7294,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.698, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.697, i64 7 }, { 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 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.696, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] + %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.469 ], [ %callN, %if.else.470 ] ret { ptr, i64 } %bp } @@ -7316,12 +7322,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.701, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.700, i64 5 }, { 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 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.699, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] + %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.472 ], [ %callN, %if.else.473 ] ret { ptr, i64 } %bp } @@ -7344,12 +7350,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.704, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.703, i64 7 }, { 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 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.702, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] + %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.475 ], [ %callN, %if.else.476 ] ret { ptr, i64 } %bp } @@ -7372,12 +7378,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.707, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.706, i64 12 }, { 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 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.705, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] + %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.478 ], [ %callN, %if.else.479 ] ret { ptr, i64 } %bp } @@ -7400,12 +7406,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.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.483 if.merge.483: ; preds = %if.else.482, %if.then.481 - %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] + %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.481 ], [ %callN, %if.else.482 ] ret { ptr, i64 } %bp } @@ -7428,12 +7434,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.713, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.712, i64 10 }, { 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 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.711, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.484 ], [ %callN, %if.else.485 ] ret { ptr, i64 } %bp } @@ -7456,12 +7462,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.716, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.715, i64 7 }, { 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 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.714, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] + %bp = phi { ptr, i64 } [ { ptr @str.716, i64 4 }, %if.then.487 ], [ %callN, %if.else.488 ] ret { ptr, i64 } %bp } @@ -7484,12 +7490,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.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.492 if.merge.492: ; preds = %if.else.491, %if.then.490 - %bp = phi { ptr, i64 } [ { ptr @str.717, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] + %bp = phi { ptr, i64 } [ { ptr @str.719, i64 4 }, %if.then.490 ], [ %callN, %if.else.491 ] ret { ptr, i64 } %bp } @@ -7512,12 +7518,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.722, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.721, i64 7 }, { 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 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.720, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] + %bp = phi { ptr, i64 } [ { ptr @str.722, i64 4 }, %if.then.493 ], [ %callN, %if.else.494 ] ret { ptr, i64 } %bp } @@ -7540,12 +7546,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.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.498 if.merge.498: ; preds = %if.else.497, %if.then.496 - %bp = phi { ptr, i64 } [ { ptr @str.723, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] + %bp = phi { ptr, i64 } [ { ptr @str.725, i64 4 }, %if.then.496 ], [ %callN, %if.else.497 ] ret { ptr, i64 } %bp } @@ -7568,12 +7574,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.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.501 if.merge.501: ; preds = %if.else.500, %if.then.499 - %bp = phi { ptr, i64 } [ { ptr @str.726, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] + %bp = phi { ptr, i64 } [ { ptr @str.728, i64 4 }, %if.then.499 ], [ %callN, %if.else.500 ] ret { ptr, i64 } %bp } @@ -7589,7 +7595,7 @@ entry: br i1 %lnot, label %if.then.508, label %if.merge.509 if.then.508: ; preds = %entry - ret { ptr, i64 } { ptr @str.729, i64 4 } + ret { ptr, i64 } { ptr @str.731, i64 4 } if.merge.509: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -7613,7 +7619,7 @@ entry: br i1 %lnot, label %if.then.510, label %if.merge.511 if.then.510: ; preds = %entry - ret { ptr, i64 } { ptr @str.730, i64 4 } + ret { ptr, i64 } { ptr @str.732, i64 4 } if.merge.511: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -7637,7 +7643,7 @@ entry: br i1 %lnot, label %if.then.512, label %if.merge.513 if.then.512: ; preds = %entry - ret { ptr, i64 } { ptr @str.731, i64 4 } + ret { ptr, i64 } { ptr @str.733, i64 4 } if.merge.513: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -7661,7 +7667,7 @@ entry: br i1 %lnot, label %if.then.514, label %if.merge.515 if.then.514: ; preds = %entry - ret { ptr, i64 } { ptr @str.732, i64 4 } + ret { ptr, i64 } { ptr @str.734, 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 7210379..dd6cf27 100644 --- a/examples/expected/1202-ffi-cc-c-large-aggregate.ir +++ b/examples/expected/1202-ffi-cc-c-large-aggregate.ir @@ -12,6 +12,51 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare void @out.1(ptr) #0 + +; Function Attrs: nounwind +declare ptr @cstring(ptr, i64) #0 + +; Function Attrs: nounwind +declare ptr @int_to_string(ptr, i64) #0 + +; Function Attrs: nounwind +declare ptr @uint_to_string(ptr, i64) #0 + +; Function Attrs: nounwind +declare ptr @bool_to_string(ptr, i1) #0 + +; Function Attrs: nounwind +declare ptr @float_to_string(ptr, double) #0 + +; Function Attrs: nounwind +declare void @hex_group(ptr, ptr, i64, i64) #0 + +; Function Attrs: nounwind +declare [4 x i64] @decompose_u16x4(ptr, i64) #0 + +; Function Attrs: nounwind +declare ptr @int_to_hex_string(ptr, i64) #0 + +; Function Attrs: nounwind +declare ptr @concat(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @substr(ptr, ptr, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @path_join(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @any_to_string(ptr, [2 x i64]) #0 + +; Function Attrs: nounwind +declare ptr @build_format(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @out.2(ptr) #0 + ; Function Attrs: nounwind declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 @@ -94,106 +139,67 @@ declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @cstring(ptr, i64) #0 +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_string(ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @uint_to_string(ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @bool_to_string(ptr, i1) #0 +declare i64 @GPA.init.6(ptr) #0 ; Function Attrs: nounwind -declare ptr @float_to_string(ptr, double) #0 +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @hex_group(ptr, ptr, i64, i64) #0 +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [4 x i64] @decompose_u16x4(ptr, i64) #0 +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_hex_string(ptr, i64) #0 +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @concat(ptr, ptr, ptr) #0 +declare void @Arena.reset.11(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @substr(ptr, ptr, i64, i64) #0 +declare void @Arena.deinit.12(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @path_join(ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @any_to_string(ptr, [2 x i64]) #0 +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @build_format(ptr, ptr) #0 +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @BufAlloc.reset.16(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.21(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -369,166 +375,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -726,64 +732,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -813,97 +819,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -942,7 +948,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.126(ptr, i1) #0 +declare void @assert.128(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 e37ba7e..b16ec00 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.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.166 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.167 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.168 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.169 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.170 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.171 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.172 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.173 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.174 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.175 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.176 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.177 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.178 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.179 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.180 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.181 = private unnamed_addr constant [10 x i8] c"compiled\0A\00", align 1 +@str.182 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.183 = 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_.182 = private unnamed_addr constant [6 x i8] c"SxFoo\00" +@OBJC_CLASS_NAME_.184 = 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_.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" +@OBJC_METH_VAR_NAME_.185 = private unnamed_addr constant [8 x i8] c"dealloc\00" +@OBJC_METH_VAR_TYPE_.186 = private unnamed_addr constant [4 x i8] c"v@:\00" +@OBJC_METH_VAR_NAME_.187 = private unnamed_addr constant [6 x i8] c"alloc\00" +@OBJC_METH_VAR_TYPE_.188 = private unnamed_addr constant [4 x i8] c"@@:\00" ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -45,85 +45,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -339,7 +261,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.164, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.166, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -435,7 +357,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.165, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, 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 @@ -443,7 +365,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.166, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -453,13 +375,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.167, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, 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.168, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, 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 @@ -467,7 +389,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.169, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -481,7 +403,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.170, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, 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 @@ -489,7 +411,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.171, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -500,7 +422,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.172, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -557,7 +479,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.173, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, 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 @@ -565,7 +487,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.174, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, 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 @@ -576,7 +498,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.175, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.177, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -596,7 +518,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.176, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.178, 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 @@ -604,7 +526,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.177, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.179, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -615,7 +537,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.178, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.180, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -625,67 +547,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -861,166 +867,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1218,64 +1224,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1305,97 +1311,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1434,118 +1440,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.128(i64, ptr) #0 +declare void @BuildOptions.add_framework.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.129(i64, ptr) #0 +declare void @BuildOptions.set_output_path.131(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.132(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.133(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.132(i64) #0 +declare i64 @BuildOptions.asset_dir_count.134(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.135(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.136(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.137(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.138(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.137(i64) #0 +declare ptr @BuildOptions.binary_path.139(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.141(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.142(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.143(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.142(i64) #0 +declare ptr @BuildOptions.bundle_path.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.143(i64) #0 +declare ptr @BuildOptions.bundle_id.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.144(i64) #0 +declare ptr @BuildOptions.codesign_identity.146(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.145(i64) #0 +declare ptr @BuildOptions.provisioning_profile.147(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.146(i64) #0 +declare ptr @BuildOptions.target_triple.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.147(i64) #0 +declare i1 @BuildOptions.is_macos.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.148(i64) #0 +declare i1 @BuildOptions.is_ios.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.149(i64) #0 +declare i1 @BuildOptions.is_ios_device.151(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.152(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.151(i64) #0 +declare i1 @BuildOptions.is_android.153(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.152(i64) #0 +declare i64 @BuildOptions.framework_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.154(i64) #0 +declare i64 @BuildOptions.framework_path_count.156(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.157(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.158(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.159(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.158(i64) #0 +declare ptr @BuildOptions.manifest_path.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.159(i64) #0 +declare ptr @BuildOptions.keystore_path.161(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.160(i64) #0 +declare i64 @BuildOptions.jni_main_count.162(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.163(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.164(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.163() #0 +declare i64 @build_options.165() #0 ; Function Attrs: nounwind define internal void @SxFoo.bump(ptr %0, ptr %1) #0 { @@ -1588,14 +1594,14 @@ entry: define internal void @print__ct_sfeff9eeccd48b824__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.179, i64 9 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.181, 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.180, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.182, 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) @@ -1611,7 +1617,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.181, i64 9 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.183, i64 9 }) ret { ptr, i64 } %call } @@ -1691,17 +1697,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_.182, i64 0) + %cls = call ptr @objc_allocateClassPair(ptr %super_cls, ptr @OBJC_CLASS_NAME_.184, 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_.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) + %sel_dealloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.185) + %2 = call i8 @class_addMethod(ptr %cls, ptr %sel_dealloc, ptr @__SxFoo_dealloc_imp, ptr @OBJC_METH_VAR_TYPE_.186) + %sel_alloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.187) + %3 = call i8 @class_addMethod(ptr %metacls, ptr %sel_alloc, ptr @__SxFoo_alloc_imp, ptr @OBJC_METH_VAR_TYPE_.188) %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 4c7471a..0f2071a 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.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 [1 x i8] zeroinitializer, align 1 +@str.166 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.167 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.168 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.169 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.170 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.171 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.172 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.173 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.174 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.175 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.176 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.177 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.178 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.179 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.180 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.181 = private unnamed_addr constant [6 x i8] c"SxFoo\00", align 1 +@str.182 = private unnamed_addr constant [8 x i8] c"dealloc\00", align 1 +@str.183 = private unnamed_addr constant [6 x i8] c"alloc\00", align 1 +@str.184 = private unnamed_addr constant [8 x i8] c"release\00", 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 [1 x i8] zeroinitializer, align 1 +@str.186 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.187 = private unnamed_addr constant [28 x i8] c"FAIL: SxFoo not registered\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.189 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.190 = private unnamed_addr constant [27 x i8] c"FAIL: dealloc IMP missing\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.192 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.193 = private unnamed_addr constant [28 x i8] c"FAIL: +alloc returned null\0A\00", 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.195 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.196 = private unnamed_addr constant [36 x i8] c"FAIL: +alloc round 2 returned null\0A\00", align 1 @str.197 = private unnamed_addr constant [13 x i8] c"dealloc: ok\0A\00", align 1 +@str.198 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.199 = 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_.198 = private unnamed_addr constant [6 x i8] c"SxFoo\00" +@OBJC_CLASS_NAME_.200 = 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_.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" +@OBJC_METH_VAR_NAME_.201 = private unnamed_addr constant [8 x i8] c"dealloc\00" +@OBJC_METH_VAR_TYPE_.202 = private unnamed_addr constant [4 x i8] c"v@:\00" +@OBJC_METH_VAR_NAME_.203 = private unnamed_addr constant [6 x i8] c"alloc\00" +@OBJC_METH_VAR_TYPE_.204 = private unnamed_addr constant [4 x i8] c"@@:\00" ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -61,85 +61,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -355,7 +277,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.164, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.166, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -451,7 +373,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.165, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, 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 @@ -459,7 +381,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.166, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -469,13 +391,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.167, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, 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.168, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, 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 @@ -483,7 +405,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.169, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -497,7 +419,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.170, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, 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 @@ -505,7 +427,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.171, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -516,7 +438,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.172, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -573,7 +495,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.173, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, 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 @@ -581,7 +503,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.174, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, 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 @@ -592,7 +514,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.175, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.177, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -612,7 +534,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.176, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.178, 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 @@ -620,7 +542,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.177, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.179, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -631,7 +553,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.178, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.180, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -641,67 +563,151 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -877,166 +883,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1234,64 +1240,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1321,97 +1327,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1450,118 +1456,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.128(i64, ptr) #0 +declare void @BuildOptions.add_framework.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.129(i64, ptr) #0 +declare void @BuildOptions.set_output_path.131(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.132(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.133(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.132(i64) #0 +declare i64 @BuildOptions.asset_dir_count.134(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.135(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.136(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.137(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.138(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.137(i64) #0 +declare ptr @BuildOptions.binary_path.139(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.141(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.142(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.143(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.142(i64) #0 +declare ptr @BuildOptions.bundle_path.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.143(i64) #0 +declare ptr @BuildOptions.bundle_id.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.144(i64) #0 +declare ptr @BuildOptions.codesign_identity.146(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.145(i64) #0 +declare ptr @BuildOptions.provisioning_profile.147(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.146(i64) #0 +declare ptr @BuildOptions.target_triple.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.147(i64) #0 +declare i1 @BuildOptions.is_macos.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.148(i64) #0 +declare i1 @BuildOptions.is_ios.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.149(i64) #0 +declare i1 @BuildOptions.is_ios_device.151(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.152(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.151(i64) #0 +declare i1 @BuildOptions.is_android.153(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.152(i64) #0 +declare i64 @BuildOptions.framework_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.154(i64) #0 +declare i64 @BuildOptions.framework_path_count.156(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.157(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.158(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.159(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.158(i64) #0 +declare ptr @BuildOptions.manifest_path.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.159(i64) #0 +declare ptr @BuildOptions.keystore_path.161(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.160(i64) #0 +declare i64 @BuildOptions.jni_main_count.162(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.163(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.164(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.163() #0 +declare i64 @build_options.165() #0 ; Function Attrs: nounwind declare ptr @objc_getClass(ptr) #0 @@ -1648,7 +1654,7 @@ entry: %allocaN = alloca ptr, align 8 %allocaN = alloca ptr, align 8 %allocaN = alloca ptr, align 8 - %call = call ptr @objc_getClass(ptr @str.179) + %call = call ptr @objc_getClass(ptr @str.181) store ptr %call, ptr %alloca, align 8 %load = load ptr, ptr %alloca, align 8 %icmp = icmp eq ptr %load, null @@ -1659,7 +1665,7 @@ if.then.0: ; preds = %entry ret i32 1 if.merge.1: ; preds = %entry - %callN = call ptr @sel_registerName(ptr @str.180) + %callN = call ptr @sel_registerName(ptr @str.182) store ptr %callN, ptr %allocaN, align 8 %loadN = load ptr, ptr %alloca, align 8 %loadN = load ptr, ptr %allocaN, align 8 @@ -1674,7 +1680,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.181) + %callN = call ptr @sel_registerName(ptr @str.183) store ptr %callN, ptr %allocaN, align 8 store ptr @objc_msgSend, ptr %allocaN, align 8 %loadN = load ptr, ptr %alloca, align 8 @@ -1691,7 +1697,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.182) + %callN = call ptr @sel_registerName(ptr @str.184) store ptr %callN, ptr %allocaN, align 8 store ptr @objc_msgSend, ptr %allocaN, align 8 %loadN = load ptr, ptr %allocaN, align 8 @@ -1738,14 +1744,14 @@ entry: define internal void @print__ct_s354c93d7643e1bdf__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.183, i64 27 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.185, 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.184, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.186, 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) @@ -1761,7 +1767,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.185, i64 27 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.187, i64 27 }) ret { ptr, i64 } %call } @@ -1769,14 +1775,14 @@ entry: define internal void @print__ct_sfe783e2b27a4beff__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.186, i64 26 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.188, 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.187, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.189, 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) @@ -1792,7 +1798,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.188, i64 26 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.190, i64 26 }) ret { ptr, i64 } %call } @@ -1800,14 +1806,14 @@ entry: define internal void @print__ct_scaebdbbd10c81716__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.189, i64 27 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.191, 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.190, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.192, 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) @@ -1823,7 +1829,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.191, i64 27 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.193, i64 27 }) ret { ptr, i64 } %call } @@ -1831,14 +1837,14 @@ entry: define internal void @print__ct_s7c1052877b8cc801__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.192, i64 35 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.194, 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.193, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.195, 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) @@ -1854,7 +1860,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.194, i64 35 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.196, i64 35 }) ret { ptr, i64 } %call } @@ -1862,14 +1868,14 @@ entry: define internal void @print__ct_sed4e79fbcbd67966__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.195, i64 12 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.197, 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.196, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.198, 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) @@ -1885,7 +1891,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.197, i64 12 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.199, i64 12 }) ret { ptr, i64 } %call } @@ -1943,17 +1949,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_.198, i64 0) + %cls = call ptr @objc_allocateClassPair(ptr %super_cls, ptr @OBJC_CLASS_NAME_.200, 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_.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) + %sel_dealloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.201) + %2 = call i1 @class_addMethod(ptr %cls, ptr %sel_dealloc, ptr @__SxFoo_dealloc_imp, ptr @OBJC_METH_VAR_TYPE_.202) + %sel_alloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.203) + %3 = call i1 @class_addMethod(ptr %metacls, ptr %sel_alloc, ptr @__SxFoo_alloc_imp, ptr @OBJC_METH_VAR_TYPE_.204) %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 38ac80a..2ddfeb2 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.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 +@str.166 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.167 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.168 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.169 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.170 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.171 = 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.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 }] +@tag.str.172 = private constant [9 x i8] c"Overflow\00" +@tag.str.173 = private constant [3 x i8] c"Io\00" +@tag.str.174 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.175 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.176 = private constant [10 x i8] c"BadEscape\00" +@tag.str.177 = private constant [10 x i8] c"BadNumber\00" +@tag.str.178 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.179 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.180 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.181 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.182 = private constant [13 x i8] c"MissingValue\00" +@tag.str.183 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.184 = 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.172, i64 8 }, { ptr, i64 } { ptr @tag.str.173, i64 2 }, { ptr, i64 } { ptr @tag.str.174, i64 15 }, { ptr, i64 } { ptr @tag.str.175, i64 13 }, { ptr, i64 } { ptr @tag.str.176, i64 9 }, { ptr, i64 } { ptr @tag.str.177, i64 9 }, { ptr, i64 } { ptr @tag.str.178, i64 15 }, { ptr, i64 } { ptr @tag.str.179, i64 14 }, { ptr, i64 } { ptr @tag.str.180, i64 14 }, { ptr, i64 } { ptr @tag.str.181, i64 11 }, { ptr, i64 } { ptr @tag.str.182, i64 12 }, { ptr, i64 } { ptr @tag.str.183, i64 15 }, { ptr, i64 } { ptr @tag.str.184, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@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 +@tn.str.185 = private constant [5 x i8] c"bool\00" +@tn.str.186 = private constant [3 x i8] c"s8\00" +@tn.str.187 = private constant [4 x i8] c"s16\00" +@tn.str.188 = private constant [4 x i8] c"s32\00" +@tn.str.189 = private constant [4 x i8] c"s64\00" +@tn.str.190 = private constant [3 x i8] c"u8\00" +@tn.str.191 = private constant [4 x i8] c"u16\00" +@tn.str.192 = private constant [4 x i8] c"u32\00" +@tn.str.193 = private constant [4 x i8] c"u64\00" +@tn.str.194 = private constant [4 x i8] c"f32\00" +@tn.str.195 = private constant [4 x i8] c"f64\00" +@tn.str.196 = private constant [7 x i8] c"string\00" +@tn.str.197 = private constant [4 x i8] c"Any\00" +@tn.str.198 = private constant [9 x i8] c"noreturn\00" +@tn.str.199 = private constant [6 x i8] c"isize\00" +@tn.str.200 = private constant [6 x i8] c"usize\00" +@tn.str.201 = private constant [5 x i8] c"void\00" +@tn.str.202 = private constant [6 x i8] c"*void\00" +@tn.str.203 = private constant [16 x i8] c"Source_Location\00" +@tn.str.204 = private constant [10 x i8] c"Allocator\00" +@tn.str.205 = private constant [8 x i8] c"Context\00" +@tn.str.206 = private constant [7 x i8] c"[4]s64\00" +@tn.str.207 = private constant [9 x i8] c"[]string\00" +@tn.str.208 = private constant [11 x i8] c"CAllocator\00" +@tn.str.209 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.210 = private constant [4 x i8] c"GPA\00" +@tn.str.211 = private constant [5 x i8] c"*GPA\00" +@tn.str.212 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.213 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.214 = private constant [6 x i8] c"Arena\00" +@tn.str.215 = private constant [7 x i8] c"*Arena\00" +@tn.str.216 = private constant [6 x i8] c"[*]u8\00" +@tn.str.217 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.218 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.219 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.220 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.221 = private constant [9 x i8] c"OpenMode\00" +@tn.str.222 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.223 = private constant [5 x i8] c"File\00" +@tn.str.224 = private constant [6 x i8] c"*File\00" +@tn.str.225 = private constant [6 x i8] c"?File\00" +@tn.str.226 = private constant [8 x i8] c"?string\00" +@tn.str.227 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.228 = private constant [4 x i8] c"*u8\00" +@tn.str.229 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.230 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.231 = private constant [5 x i8] c"*s32\00" +@tn.str.232 = private constant [9 x i8] c"SockAddr\00" +@tn.str.233 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.234 = private constant [5 x i8] c"*u32\00" +@tn.str.235 = private constant [10 x i8] c"JsonError\00" +@tn.str.236 = private constant [6 x i8] c"Array\00" +@tn.str.237 = private constant [7 x i8] c"Object\00" +@tn.str.238 = private constant [6 x i8] c"Value\00" +@tn.str.239 = private constant [7 x i8] c"Member\00" +@tn.str.240 = private constant [9 x i8] c"[*]Value\00" +@tn.str.241 = private constant [7 x i8] c"*Array\00" +@tn.str.242 = private constant [10 x i8] c"[*]Member\00" +@tn.str.243 = private constant [8 x i8] c"*Object\00" +@tn.str.244 = private constant [5 x i8] c"[]u8\00" +@tn.str.245 = private constant [5 x i8] c"Sink\00" +@tn.str.246 = private constant [6 x i8] c"*Sink\00" +@tn.str.247 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.248 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.249 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.250 = private constant [7 x i8] c"Parser\00" +@tn.str.251 = private constant [8 x i8] c"*Parser\00" +@tn.str.252 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.253 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.254 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.255 = private constant [13 x i8] c"Architecture\00" +@tn.str.256 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.257 = private constant [11 x i8] c"() -> bool\00" +@tn.str.258 = private constant [5 x i8] c"*s64\00" +@tn.str.259 = private constant [9 x i8] c"CliError\00" +@tn.str.260 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.261 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.262 = private constant [8 x i8] c"Command\00" +@tn.str.263 = private constant [10 x i8] c"FlagValue\00" +@tn.str.264 = private constant [5 x i8] c"Diag\00" +@tn.str.265 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.266 = private constant [7 x i8] c"Parsed\00" +@tn.str.267 = private constant [8 x i8] c"*Parsed\00" +@tn.str.268 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.269 = private constant [10 x i8] c"[]Command\00" +@tn.str.270 = private constant [6 x i8] c"*Diag\00" +@tn.str.271 = private constant [7 x i8] c"[8]s64\00" +@tn.str.272 = private constant [7 x i8] c"[64]u8\00" +@tn.str.273 = private constant [7 x i8] c"Sha256\00" +@tn.str.274 = private constant [8 x i8] c"*Sha256\00" +@tn.str.275 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.276 = private constant [8 x i8] c"[64]s64\00" +@tn.str.277 = private constant [9 x i8] c"NSString\00" +@tn.str.278 = private constant [10 x i8] c"*NSString\00" +@tn.str.279 = private constant [10 x i8] c"Closure()\00" +@tn.str.280 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.281 = private constant [7 x i8] c"**void\00" +@tn.str.282 = private constant [6 x i8] c"SxBox\00" +@tn.str.283 = private constant [7 x i8] c"*SxBox\00" +@tn.str.284 = private constant [13 x i8] c"__SxBoxState\00" +@tn.str.285 = private constant [8 x i8] c"**SxBox\00" +@tn.str.286 = private constant [8 x i8] c"*string\00" +@tn.str.287 = private constant [6 x i8] c"[]Any\00" +@tn.str.288 = private constant [5 x i8] c"*Any\00" +@tn.str.289 = private constant [7 x i8] c"*[]Any\00" +@tn.str.290 = private constant [6 x i8] c"*bool\00" +@tn.str.291 = private constant [7 x i8] c"[1]Any\00" +@tn.str.292 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.293 = private constant [7 x i8] c"[3]Any\00" +@tn.str.294 = private constant [8 x i8] c"*[3]Any\00" +@tn.str.295 = private constant [8 x i8] c"*[4]s64\00" +@tn.str.296 = private constant [5 x i8] c"*f64\00" +@tn.str.297 = private constant [17 x i8] c"*Source_Location\00" +@tn.str.298 = private constant [11 x i8] c"*Allocator\00" +@tn.str.299 = private constant [9 x i8] c"*Context\00" +@tn.str.300 = private constant [12 x i8] c"*TraceFrame\00" +@tn.str.301 = private constant [15 x i8] c"*ProcessResult\00" +@tn.str.302 = private constant [8 x i8] c"*Member\00" +@tn.str.303 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.304 = private constant [10 x i8] c"*FlagSpec\00" +@tn.str.305 = private constant [9 x i8] c"*Command\00" +@tn.str.306 = private constant [11 x i8] c"*FlagValue\00" +@tn.str.307 = private constant [14 x i8] c"*__SxBoxState\00" +@tn.str.308 = private constant [10 x i8] c"*OpenMode\00" +@tn.str.309 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.310 = private constant [7 x i8] c"*Value\00" +@tn.str.311 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.312 = private constant [14 x i8] c"*Architecture\00" +@tn.str.313 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.314 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.315 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.316 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.317 = private constant [10 x i8] c"*[]string\00" +@tn.str.318 = private constant [6 x i8] c"*[]u8\00" +@tn.str.319 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.320 = private constant [11 x i8] c"*[]Command\00" +@tn.str.321 = private constant [6 x i8] c"**GPA\00" +@tn.str.322 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.323 = private constant [8 x i8] c"**Arena\00" +@tn.str.324 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.325 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.326 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.327 = private constant [7 x i8] c"**File\00" +@tn.str.328 = private constant [5 x i8] c"**u8\00" +@tn.str.329 = private constant [6 x i8] c"**s32\00" +@tn.str.330 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.331 = private constant [6 x i8] c"**u32\00" +@tn.str.332 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.333 = private constant [8 x i8] c"**Array\00" +@tn.str.334 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.335 = private constant [9 x i8] c"**Object\00" +@tn.str.336 = private constant [7 x i8] c"**Sink\00" +@tn.str.337 = private constant [9 x i8] c"**Parser\00" +@tn.str.338 = private constant [6 x i8] c"**s64\00" +@tn.str.339 = private constant [9 x i8] c"**Parsed\00" +@tn.str.340 = private constant [7 x i8] c"**Diag\00" +@tn.str.341 = private constant [9 x i8] c"**Sha256\00" +@tn.str.342 = private constant [11 x i8] c"**NSString\00" +@tn.str.343 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.344 = private constant [8 x i8] c"***void\00" +@tn.str.345 = private constant [9 x i8] c"***SxBox\00" +@tn.str.346 = private constant [9 x i8] c"**string\00" +@tn.str.347 = private constant [6 x i8] c"**Any\00" +@tn.str.348 = private constant [8 x i8] c"**[]Any\00" +@tn.str.349 = private constant [7 x i8] c"**bool\00" +@tn.str.350 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.351 = private constant [9 x i8] c"**[3]Any\00" +@tn.str.352 = private constant [7 x i8] c"*?File\00" +@tn.str.353 = private constant [9 x i8] c"*?string\00" +@tn.str.354 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.355 = private constant [9 x i8] c"*?[64]u8\00" +@tn.str.356 = private constant [16 x i8] c"__sx_objc_super\00" +@tn.str.357 = private constant [17 x i8] c"*__sx_objc_super\00" +@tn.str.358 = 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.185, i64 4 }, { 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 2 }, { 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 3 }, { ptr, i64 } { ptr @tn.str.195, i64 3 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 3 }, { ptr, i64 } { ptr @tn.str.198, i64 8 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 5 }, { ptr, i64 } { ptr @tn.str.201, i64 4 }, { ptr, i64 } { ptr @tn.str.202, i64 5 }, { ptr, i64 } { ptr @tn.str.203, i64 15 }, { ptr, i64 } { ptr @tn.str.204, i64 9 }, { ptr, i64 } { ptr @tn.str.205, i64 7 }, { ptr, i64 } { ptr @tn.str.206, i64 6 }, { ptr, i64 } { ptr @tn.str.207, i64 8 }, { ptr, i64 } { ptr @tn.str.208, i64 10 }, { ptr, i64 } { ptr @tn.str.209, i64 11 }, { ptr, i64 } { ptr @tn.str.210, i64 3 }, { ptr, i64 } { ptr @tn.str.211, i64 4 }, { ptr, i64 } { ptr @tn.str.212, i64 10 }, { ptr, i64 } { ptr @tn.str.213, i64 11 }, { ptr, i64 } { ptr @tn.str.214, i64 5 }, { ptr, i64 } { ptr @tn.str.215, i64 6 }, { ptr, i64 } { ptr @tn.str.216, i64 5 }, { ptr, i64 } { ptr @tn.str.217, i64 8 }, { ptr, i64 } { ptr @tn.str.218, i64 9 }, { ptr, i64 } { ptr @tn.str.219, i64 17 }, { ptr, i64 } { ptr @tn.str.220, i64 18 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 8 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 5 }, { ptr, i64 } { ptr @tn.str.225, i64 5 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 10 }, { ptr, i64 } { ptr @tn.str.228, i64 3 }, { ptr, i64 } { ptr @tn.str.229, i64 13 }, { ptr, i64 } { ptr @tn.str.230, i64 14 }, { ptr, i64 } { ptr @tn.str.231, i64 4 }, { ptr, i64 } { ptr @tn.str.232, i64 8 }, { ptr, i64 } { ptr @tn.str.233, i64 9 }, { ptr, i64 } { ptr @tn.str.234, i64 4 }, { ptr, i64 } { ptr @tn.str.235, i64 9 }, { ptr, i64 } { ptr @tn.str.236, i64 5 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 5 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 8 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { ptr, i64 } { ptr @tn.str.242, i64 9 }, { ptr, i64 } { ptr @tn.str.243, i64 7 }, { ptr, i64 } { ptr @tn.str.244, i64 4 }, { ptr, i64 } { ptr @tn.str.245, i64 4 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 16 }, { ptr, i64 } { ptr @tn.str.248, i64 14 }, { ptr, i64 } { ptr @tn.str.249, i64 21 }, { ptr, i64 } { ptr @tn.str.250, i64 6 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 24 }, { ptr, i64 } { ptr @tn.str.253, i64 23 }, { ptr, i64 } { ptr @tn.str.254, i64 15 }, { ptr, i64 } { ptr @tn.str.255, i64 12 }, { ptr, i64 } { ptr @tn.str.256, i64 12 }, { ptr, i64 } { ptr @tn.str.257, i64 10 }, { ptr, i64 } { ptr @tn.str.258, i64 4 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 8 }, { ptr, i64 } { ptr @tn.str.261, i64 10 }, { ptr, i64 } { ptr @tn.str.262, i64 7 }, { ptr, i64 } { ptr @tn.str.263, i64 9 }, { ptr, i64 } { ptr @tn.str.264, i64 4 }, { ptr, i64 } { ptr @tn.str.265, i64 13 }, { ptr, i64 } { ptr @tn.str.266, i64 6 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 18 }, { ptr, i64 } { ptr @tn.str.269, i64 9 }, { ptr, i64 } { ptr @tn.str.270, i64 5 }, { ptr, i64 } { ptr @tn.str.271, i64 6 }, { ptr, i64 } { ptr @tn.str.272, i64 6 }, { ptr, i64 } { ptr @tn.str.273, i64 6 }, { ptr, i64 } { ptr @tn.str.274, i64 7 }, { ptr, i64 } { ptr @tn.str.275, i64 7 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 8 }, { ptr, i64 } { ptr @tn.str.278, i64 9 }, { ptr, i64 } { ptr @tn.str.279, i64 9 }, { ptr, i64 } { ptr @tn.str.280, i64 12 }, { ptr, i64 } { ptr @tn.str.281, i64 6 }, { ptr, i64 } { ptr @tn.str.282, i64 5 }, { ptr, i64 } { ptr @tn.str.283, i64 6 }, { ptr, i64 } { ptr @tn.str.284, i64 12 }, { ptr, i64 } { ptr @tn.str.285, i64 7 }, { ptr, i64 } { ptr @tn.str.286, i64 7 }, { ptr, i64 } { ptr @tn.str.287, i64 5 }, { ptr, i64 } { ptr @tn.str.288, i64 4 }, { ptr, i64 } { ptr @tn.str.289, i64 6 }, { ptr, i64 } { ptr @tn.str.290, i64 5 }, { ptr, i64 } { ptr @tn.str.291, i64 6 }, { ptr, i64 } { ptr @tn.str.292, i64 7 }, { ptr, i64 } { ptr @tn.str.293, i64 6 }, { ptr, i64 } { ptr @tn.str.294, i64 7 }, { ptr, i64 } { ptr @tn.str.295, i64 7 }, { ptr, i64 } { ptr @tn.str.296, i64 4 }, { ptr, i64 } { ptr @tn.str.297, i64 16 }, { ptr, i64 } { ptr @tn.str.298, i64 10 }, { ptr, i64 } { ptr @tn.str.299, i64 8 }, { ptr, i64 } { ptr @tn.str.300, i64 11 }, { ptr, i64 } { ptr @tn.str.301, i64 14 }, { ptr, i64 } { ptr @tn.str.302, i64 7 }, { ptr, i64 } { ptr @tn.str.303, i64 13 }, { ptr, i64 } { ptr @tn.str.304, i64 9 }, { ptr, i64 } { ptr @tn.str.305, i64 8 }, { ptr, i64 } { ptr @tn.str.306, i64 10 }, { ptr, i64 } { ptr @tn.str.307, i64 13 }, { ptr, i64 } { ptr @tn.str.308, i64 9 }, { ptr, i64 } { ptr @tn.str.309, i64 9 }, { ptr, i64 } { ptr @tn.str.310, i64 6 }, { ptr, i64 } { ptr @tn.str.311, i64 16 }, { ptr, i64 } { ptr @tn.str.312, i64 13 }, { ptr, i64 } { ptr @tn.str.313, i64 14 }, { ptr, i64 } { ptr @tn.str.314, i64 7 }, { ptr, i64 } { ptr @tn.str.315, i64 7 }, { ptr, i64 } { ptr @tn.str.316, i64 8 }, { ptr, i64 } { ptr @tn.str.317, i64 9 }, { ptr, i64 } { ptr @tn.str.318, i64 5 }, { ptr, i64 } { ptr @tn.str.319, i64 11 }, { ptr, i64 } { ptr @tn.str.320, i64 10 }, { ptr, i64 } { ptr @tn.str.321, i64 5 }, { ptr, i64 } { ptr @tn.str.322, i64 12 }, { ptr, i64 } { ptr @tn.str.323, i64 7 }, { ptr, i64 } { ptr @tn.str.324, i64 6 }, { ptr, i64 } { ptr @tn.str.325, i64 10 }, { ptr, i64 } { ptr @tn.str.326, i64 19 }, { ptr, i64 } { ptr @tn.str.327, i64 6 }, { ptr, i64 } { ptr @tn.str.328, i64 4 }, { ptr, i64 } { ptr @tn.str.329, i64 5 }, { ptr, i64 } { ptr @tn.str.330, i64 10 }, { ptr, i64 } { ptr @tn.str.331, i64 5 }, { ptr, i64 } { ptr @tn.str.332, i64 9 }, { ptr, i64 } { ptr @tn.str.333, i64 7 }, { ptr, i64 } { ptr @tn.str.334, i64 10 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.339, i64 8 }, { ptr, i64 } { ptr @tn.str.340, i64 6 }, { ptr, i64 } { ptr @tn.str.341, i64 8 }, { ptr, i64 } { ptr @tn.str.342, i64 10 }, { ptr, i64 } { ptr @tn.str.343, i64 13 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.348, i64 7 }, { ptr, i64 } { ptr @tn.str.349, i64 6 }, { ptr, i64 } { ptr @tn.str.350, i64 8 }, { ptr, i64 } { ptr @tn.str.351, i64 8 }, { ptr, i64 } { ptr @tn.str.352, i64 6 }, { ptr, i64 } { ptr @tn.str.353, i64 8 }, { ptr, i64 } { ptr @tn.str.354, i64 15 }, { ptr, i64 } { ptr @tn.str.355, i64 8 }, { ptr, i64 } { ptr @tn.str.356, i64 15 }, { ptr, i64 } { ptr @tn.str.357, i64 16 }, { ptr, i64 } { ptr @tn.str.358, i64 5 }] @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 [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 [1 x i8] zeroinitializer, align 1 +@str.363 = 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 [15 x i8] c"result := \22\22; \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 [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.370 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.371 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.372 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.373 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.374 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.375 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.376 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.377 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.378 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.379 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.380 = private unnamed_addr constant [6 x i8] c"SxBox\00", align 1 +@str.381 = private unnamed_addr constant [9 x i8] c"setArea:\00", 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 [1 x i8] zeroinitializer, align 1 +@str.383 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.384 = private unnamed_addr constant [31 x i8] c"FAIL: width/height round-trip\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.386 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.387 = private unnamed_addr constant [31 x i8] c"FAIL: area expected 0, got {}\0A\00", 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 [1 x i8] zeroinitializer, align 1 +@str.389 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.390 = private unnamed_addr constant [52 x i8] c"FAIL: setArea: should not be registered (readonly)\0A\00", 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 +@str.392 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.393 = private unnamed_addr constant [29 x i8] c"property: w={} h={} area={}\0A\00", align 1 +@str.394 = private unnamed_addr constant [16 x i8] c"Source_Location\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 = private constant [5 x i8] c"file\00" -@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 }] +@fld.str.398 = private constant [5 x i8] c"line\00" +@fld.str.399 = private constant [4 x i8] c"col\00" +@fld.str.400 = 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.398, i64 4 }, { ptr, i64 } { ptr @fld.str.399, i64 3 }, { ptr, i64 } { ptr @fld.str.400, i64 4 }] +@str.401 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.402 = private unnamed_addr constant [10 x i8] c"Allocator\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 [4 x i8] c"ctx\00" +@fld.str.407 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.408 = private constant [14 x i8] c"dealloc_bytes\00" +@field_names.409 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.406, i64 3 }, { ptr, i64 } { ptr @fld.str.407, i64 11 }, { ptr, i64 } { ptr @fld.str.408, i64 13 }] +@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 [11 x i8] c"CAllocator\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 +@field_names.423 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.424 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.425 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00" +@field_names.430 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.429, i64 11 }] +@str.431 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.432 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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"next\00" +@fld.str.437 = private constant [4 x i8] c"cap\00" +@field_names.438 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.436, i64 4 }, { ptr, i64 } { ptr @fld.str.437, i64 3 }] +@str.439 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.440 = private unnamed_addr constant [6 x i8] c"Arena\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"first\00" +@fld.str.445 = private constant [10 x i8] c"end_index\00" +@fld.str.446 = private constant [7 x i8] c"parent\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 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"BufAlloc\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 [4 x i8] c"buf\00" +@fld.str.454 = private constant [4 x i8] c"len\00" +@fld.str.455 = private constant [4 x i8] c"pos\00" +@field_names.456 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.453, i64 3 }, { 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 [8 x i8] c"Context\00", align 1 +@str.458 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\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 +@fld.str.462 = private constant [7 x i8] c"parent\00" +@fld.str.463 = private constant [12 x i8] c"alloc_count\00" +@fld.str.464 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.465 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.466 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.462, i64 6 }, { ptr, i64 } { ptr @fld.str.463, i64 11 }, { ptr, i64 } { ptr @fld.str.464, i64 13 }, { ptr, i64 } { ptr @fld.str.465, i64 17 }] +@str.467 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.468 = private unnamed_addr constant [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.473 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.472, i64 2 }] +@str.474 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.475 = private unnamed_addr constant [11 x i8] c"TraceFrame\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 [5 x i8] c"file\00" +@fld.str.480 = private constant [5 x i8] c"line\00" +@fld.str.481 = private constant [4 x i8] c"col\00" +@fld.str.482 = private constant [5 x i8] c"func\00" +@fld.str.483 = private constant [10 x i8] c"line_text\00" +@field_names.484 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.479, i64 4 }, { ptr, i64 } { ptr @fld.str.480, i64 4 }, { ptr, i64 } { ptr @fld.str.481, i64 3 }, { ptr, i64 } { ptr @fld.str.482, i64 4 }, { ptr, i64 } { ptr @fld.str.483, i64 9 }] +@str.485 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.486 = private unnamed_addr constant [14 x i8] c"ProcessResult\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 [10 x i8] c"exit_code\00" +@fld.str.491 = private constant [7 x i8] c"stdout\00" +@field_names.492 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.490, i64 9 }, { ptr, i64 } { ptr @fld.str.491, i64 6 }] +@str.493 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.494 = private unnamed_addr constant [9 x i8] c"SockAddr\00", align 1 +@str.495 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.496 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.497 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.498 = private constant [8 x i8] c"sin_len\00" +@fld.str.499 = private constant [11 x i8] c"sin_family\00" +@fld.str.500 = private constant [9 x i8] c"sin_port\00" +@fld.str.501 = private constant [9 x i8] c"sin_addr\00" +@fld.str.502 = private constant [9 x i8] c"sin_zero\00" +@field_names.503 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.498, i64 7 }, { ptr, i64 } { ptr @fld.str.499, i64 10 }, { ptr, i64 } { ptr @fld.str.500, i64 8 }, { ptr, i64 } { ptr @fld.str.501, i64 8 }, { 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 [6 x i8] c"Array\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"items\00" +@fld.str.510 = private constant [4 x i8] c"len\00" +@fld.str.511 = private constant [4 x i8] c"cap\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 3 }, { ptr, i64 } { ptr @fld.str.511, i64 3 }] +@str.513 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.514 = private unnamed_addr constant [7 x i8] c"Object\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 [6 x i8] c"items\00" +@fld.str.519 = private constant [4 x i8] c"len\00" +@fld.str.520 = private constant [4 x i8] c"cap\00" +@field_names.521 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.518, i64 5 }, { ptr, i64 } { ptr @fld.str.519, i64 3 }, { ptr, i64 } { ptr @fld.str.520, i64 3 }] +@str.522 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.523 = private unnamed_addr constant [7 x i8] c"Member\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 [4 x i8] c"key\00" +@fld.str.528 = private constant [4 x i8] c"val\00" +@field_names.529 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.527, i64 3 }, { ptr, i64 } { ptr @fld.str.528, i64 3 }] +@str.530 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.531 = private unnamed_addr constant [5 x i8] c"Sink\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"dst\00" +@fld.str.536 = private constant [4 x i8] c"pos\00" +@fld.str.537 = private constant [5 x i8] c"file\00" +@field_names.538 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.535, i64 3 }, { ptr, i64 } { ptr @fld.str.536, i64 3 }, { ptr, i64 } { ptr @fld.str.537, i64 4 }] +@str.539 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.540 = private unnamed_addr constant [7 x i8] c"Parser\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 [4 x i8] c"src\00" +@fld.str.545 = private constant [4 x i8] c"pos\00" +@fld.str.546 = private constant [6 x i8] c"alloc\00" +@field_names.547 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.544, i64 3 }, { ptr, i64 } { ptr @fld.str.545, i64 3 }, { ptr, i64 } { ptr @fld.str.546, i64 5 }] +@str.548 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.549 = private unnamed_addr constant [13 x i8] c"BuildOptions\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 +@field_names.553 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.554 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.555 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 +@str.558 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.559 = private constant [5 x i8] c"name\00" +@fld.str.560 = private constant [12 x i8] c"takes_value\00" +@fld.str.561 = private constant [9 x i8] c"required\00" +@field_names.562 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.559, i64 4 }, { ptr, i64 } { ptr @fld.str.560, i64 11 }, { ptr, i64 } { ptr @fld.str.561, i64 8 }] +@str.563 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.564 = private unnamed_addr constant [8 x i8] c"Command\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 +@str.567 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.568 = private constant [6 x i8] c"group\00" +@fld.str.569 = private constant [8 x i8] c"command\00" +@fld.str.570 = private constant [6 x i8] c"flags\00" +@field_names.571 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.568, i64 5 }, { ptr, i64 } { ptr @fld.str.569, i64 7 }, { ptr, i64 } { ptr @fld.str.570, i64 5 }] +@str.572 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.573 = private unnamed_addr constant [10 x i8] c"FlagValue\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 +@str.576 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.577 = private constant [4 x i8] c"set\00" +@fld.str.578 = private constant [6 x i8] c"value\00" +@field_names.579 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.577, i64 3 }, { ptr, i64 } { ptr @fld.str.578, i64 5 }] +@str.580 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.581 = private unnamed_addr constant [5 x i8] c"Diag\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 [6 x i8] c"index\00" +@fld.str.586 = private constant [6 x i8] c"token\00" +@field_names.587 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.585, i64 5 }, { ptr, i64 } { ptr @fld.str.586, i64 5 }] +@str.588 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.589 = private unnamed_addr constant [7 x i8] c"Parsed\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"group\00" +@fld.str.594 = private constant [8 x i8] c"command\00" +@fld.str.595 = private constant [10 x i8] c"cmd_index\00" +@fld.str.596 = private constant [5 x i8] c"json\00" +@fld.str.597 = private constant [5 x i8] c"rest\00" +@fld.str.598 = private constant [5 x i8] c"spec\00" +@fld.str.599 = private constant [7 x i8] c"values\00" +@field_names.600 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.593, i64 5 }, { ptr, i64 } { ptr @fld.str.594, i64 7 }, { ptr, i64 } { ptr @fld.str.595, i64 9 }, { ptr, i64 } { ptr @fld.str.596, i64 4 }, { ptr, i64 } { ptr @fld.str.597, i64 4 }, { ptr, i64 } { ptr @fld.str.598, i64 4 }, { ptr, i64 } { ptr @fld.str.599, i64 6 }] +@str.601 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.602 = private unnamed_addr constant [7 x i8] c"Sha256\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 +@fld.str.606 = private constant [2 x i8] c"h\00" +@fld.str.607 = private constant [4 x i8] c"buf\00" +@fld.str.608 = private constant [8 x i8] c"buf_len\00" +@fld.str.609 = private constant [10 x i8] c"total_len\00" +@field_names.610 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.606, i64 1 }, { ptr, i64 } { ptr @fld.str.607, i64 3 }, { ptr, i64 } { ptr @fld.str.608, i64 7 }, { ptr, i64 } { ptr @fld.str.609, i64 9 }] +@str.611 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.612 = private unnamed_addr constant [9 x i8] c"NSString\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 [6 x i8] c"SxBox\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 +@field_names.622 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.623 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.624 = private unnamed_addr constant [13 x i8] c"__SxBoxState\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 +@fld.str.628 = private constant [15 x i8] c"__sx_allocator\00" +@fld.str.629 = private constant [6 x i8] c"width\00" +@fld.str.630 = private constant [7 x i8] c"height\00" +@fld.str.631 = private constant [5 x i8] c"area\00" +@field_names.632 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.628, i64 14 }, { ptr, i64 } { ptr @fld.str.629, i64 5 }, { ptr, i64 } { ptr @fld.str.630, i64 6 }, { ptr, i64 } { ptr @fld.str.631, i64 4 }] +@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 +@fld.str.635 = private constant [5 x i8] c"read\00" +@fld.str.636 = private constant [6 x i8] c"write\00" +@fld.str.637 = private constant [7 x i8] c"append\00" +@fld.str.638 = private constant [11 x i8] c"read_write\00" +@field_names.639 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.635, i64 4 }, { ptr, i64 } { ptr @fld.str.636, i64 5 }, { ptr, i64 } { ptr @fld.str.637, i64 6 }, { ptr, i64 } { ptr @fld.str.638, i64 10 }] +@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 [4 x i8] c"set\00" +@fld.str.644 = private constant [8 x i8] c"current\00" +@fld.str.645 = private constant [4 x i8] c"end\00" +@field_names.646 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.643, i64 3 }, { ptr, i64 } { ptr @fld.str.644, i64 7 }, { ptr, i64 } { ptr @fld.str.645, i64 3 }] +@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 [6 x i8] c"null_\00" +@fld.str.651 = private constant [6 x i8] c"bool_\00" +@fld.str.652 = private constant [5 x i8] c"int_\00" +@fld.str.653 = private constant [4 x i8] c"str\00" +@fld.str.654 = private constant [6 x i8] c"array\00" +@fld.str.655 = private constant [7 x i8] c"object\00" +@field_names.656 = private constant [6 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.650, i64 5 }, { ptr, i64 } { ptr @fld.str.651, i64 5 }, { ptr, i64 } { ptr @fld.str.652, i64 4 }, { ptr, i64 } { ptr @fld.str.653, i64 3 }, { ptr, i64 } { ptr @fld.str.654, i64 5 }, { ptr, i64 } { ptr @fld.str.655, i64 6 }] +@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 [6 x i8] c"macos\00" +@fld.str.661 = private constant [6 x i8] c"linux\00" +@fld.str.662 = private constant [8 x i8] c"windows\00" +@fld.str.663 = private constant [5 x i8] c"wasm\00" +@fld.str.664 = private constant [4 x i8] c"ios\00" +@fld.str.665 = private constant [8 x i8] c"android\00" +@fld.str.666 = private constant [8 x i8] c"unknown\00" +@field_names.667 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.660, i64 5 }, { ptr, i64 } { ptr @fld.str.661, i64 5 }, { ptr, i64 } { ptr @fld.str.662, i64 7 }, { ptr, i64 } { ptr @fld.str.663, i64 4 }, { ptr, i64 } { ptr @fld.str.664, i64 3 }, { ptr, i64 } { ptr @fld.str.665, i64 7 }, { ptr, i64 } { ptr @fld.str.666, i64 7 }] +@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 [2 x i8] c".\00", align 1 +@fld.str.671 = private constant [8 x i8] c"aarch64\00" +@fld.str.672 = private constant [7 x i8] c"x86_64\00" +@fld.str.673 = private constant [7 x i8] c"wasm32\00" +@fld.str.674 = private constant [7 x i8] c"wasm64\00" +@fld.str.675 = private constant [8 x i8] c"unknown\00" +@field_names.676 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.671, i64 7 }, { ptr, i64 } { ptr @fld.str.672, i64 6 }, { ptr, i64 } { ptr @fld.str.673, i64 6 }, { ptr, i64 } { ptr @fld.str.674, i64 6 }, { ptr, i64 } { ptr @fld.str.675, i64 7 }] +@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 [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 [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 [3 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 [3 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 [2 x i8] c"]\00", align 1 +@str.708 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.711 = private unnamed_addr constant [3 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 [2 x i8] c"]\00", align 1 +@str.714 = private unnamed_addr constant [3 x i8] c", \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"*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 [12 x i8] c"*CAllocator\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"*GPA\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 [12 x i8] c"*ArenaChunk\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 [7 x i8] c"*Arena\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 [6 x i8] c"[*]u8\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"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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 [6 x i8] c"*File\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 [4 x i8] c"*u8\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 [5 x i8] c"*s32\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 [10 x i8] c"*SockAddr\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"*u32\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 [9 x i8] c"[*]Value\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 [7 x i8] c"*Array\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 [10 x i8] c"[*]Member\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 [8 x i8] c"*Object\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 [6 x i8] c"*Sink\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 [8 x i8] c"*Parser\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 [5 x i8] c"*s64\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"*Parsed\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 [6 x i8] c"*Diag\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"*Sha256\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 [10 x i8] c"*NSString\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 [13 x i8] c"**CAllocator\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 [7 x i8] c"**void\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 [7 x i8] c"*SxBox\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 [8 x i8] c"**SxBox\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 [8 x i8] c"*string\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 [5 x i8] c"*Any\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 [7 x i8] c"*[]Any\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 [8 x i8] c"*[1]Any\00", align 1 +@str.813 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.814 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.815 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 +@str.816 = private unnamed_addr constant [4 x i8] c"@0x\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 +@str.819 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.820 = 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_.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_METH_VAR_NAME_.821 = private unnamed_addr constant [10 x i8] c"setWidth:\00" +@OBJC_METH_VAR_NAME_.822 = private unnamed_addr constant [11 x i8] c"setHeight:\00" +@OBJC_METH_VAR_NAME_.823 = private unnamed_addr constant [6 x i8] c"width\00" +@OBJC_METH_VAR_NAME_.824 = private unnamed_addr constant [7 x i8] c"height\00" +@OBJC_METH_VAR_NAME_.825 = 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_.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_CLASS_NAME_.826 = private unnamed_addr constant [6 x i8] c"SxBox\00" +@OBJC_METH_VAR_NAME_.827 = 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_.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" +@OBJC_METH_VAR_NAME_.828 = private unnamed_addr constant [10 x i8] c"setWidth:\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 [7 x i8] c"height\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 [11 x i8] c"setHeight:\00" +@OBJC_METH_VAR_TYPE_.833 = private unnamed_addr constant [5 x i8] c"v@:i\00" +@OBJC_METH_VAR_NAME_.834 = private unnamed_addr constant [5 x i8] c"area\00" +@OBJC_METH_VAR_TYPE_.835 = private unnamed_addr constant [4 x i8] c"i@:\00" +@OBJC_METH_VAR_NAME_.836 = private unnamed_addr constant [8 x i8] c"dealloc\00" +@OBJC_METH_VAR_TYPE_.837 = private unnamed_addr constant [4 x i8] c"v@:\00" +@OBJC_METH_VAR_NAME_.838 = private unnamed_addr constant [6 x i8] c"alloc\00" +@OBJC_METH_VAR_TYPE_.839 = private unnamed_addr constant [4 x i8] c"@@:\00" +@OBJC_CLASS_NAME_.840 = 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 @@ -712,85 +712,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -933,7 +855,7 @@ entry: br i1 %icmp, label %if.then.64, label %if.merge.65 if.then.64: ; preds = %entry - ret { ptr, i64 } { ptr @str.164, i64 1 } + ret { ptr, i64 } { ptr @str.166, i64 1 } if.merge.65: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1060,7 +982,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.165, i64 4 }, %if.then.86 ], [ { ptr @str.166, i64 5 }, %if.else.87 ] + %bp = phi { ptr, i64 } [ { ptr @str.167, i64 4 }, %if.then.86 ], [ { ptr @str.168, i64 5 }, %if.else.87 ] ret { ptr, i64 } %bp } @@ -1394,7 +1316,7 @@ entry: br i1 %icmp, label %if.then.404, label %if.merge.405 if.then.404: ; preds = %entry - ret { ptr, i64 } { ptr @str.167, i64 1 } + ret { ptr, i64 } { ptr @str.169, i64 1 } if.merge.405: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1544,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.168, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.170, 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 @@ -1571,12 +1493,12 @@ entry: i64 19, label %match.arm.51 i64 20, 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 24, label %match.arm.51 + i64 26, label %match.arm.51 + i64 28, label %match.arm.51 i64 30, label %match.arm.51 - i64 32, label %match.arm.51 - i64 34, label %match.arm.51 + i64 33, label %match.arm.51 + i64 35, label %match.arm.51 i64 39, label %match.arm.51 i64 43, label %match.arm.51 i64 45, label %match.arm.51 @@ -1604,26 +1526,26 @@ entry: i64 51, label %match.arm.53 i64 64, label %match.arm.53 i64 75, label %match.arm.53 - i64 35, label %match.arm.55 + i64 22, label %match.arm.55 i64 81, label %match.arm.55 i64 87, label %match.arm.55 i64 88, label %match.arm.55 i64 92, label %match.arm.55 i64 107, label %match.arm.55 i64 109, label %match.arm.55 - i64 36, label %match.arm.56 + i64 23, label %match.arm.56 i64 60, label %match.arm.56 i64 77, label %match.arm.56 i64 85, label %match.arm.56 i64 103, label %match.arm.56 i64 18, 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 25, label %match.arm.57 + i64 27, label %match.arm.57 i64 29, label %match.arm.57 i64 31, label %match.arm.57 - i64 33, label %match.arm.57 + i64 32, label %match.arm.57 + i64 34, label %match.arm.57 + i64 36, label %match.arm.57 i64 40, label %match.arm.57 i64 44, label %match.arm.57 i64 47, label %match.arm.57 @@ -1662,7 +1584,7 @@ match.merge.45: ; preds = %dispatch.merge.516, ret { ptr, i64 } %loadN match.arm.46: ; preds = %entry - store { ptr, i64 } { ptr @str.169, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.171, 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 @@ -1707,12 +1629,12 @@ match.arm.51: ; preds = %entry, %entry, %ent i64 19, label %dispatch.case.104 i64 20, label %dispatch.case.105 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 24, label %dispatch.case.107 + i64 26, label %dispatch.case.108 + i64 28, label %dispatch.case.109 i64 30, label %dispatch.case.110 - i64 32, label %dispatch.case.111 - i64 34, label %dispatch.case.112 + i64 33, label %dispatch.case.111 + i64 35, label %dispatch.case.112 i64 39, label %dispatch.case.113 i64 43, label %dispatch.case.114 i64 45, label %dispatch.case.115 @@ -1766,7 +1688,7 @@ match.arm.55: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.290 [ - i64 35, label %dispatch.case.291 + i64 22, label %dispatch.case.291 i64 81, label %dispatch.case.292 i64 87, label %dispatch.case.293 i64 88, label %dispatch.case.294 @@ -1780,7 +1702,7 @@ match.arm.56: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.334 [ - i64 36, label %dispatch.case.335 + i64 23, label %dispatch.case.335 i64 60, label %dispatch.case.336 i64 77, label %dispatch.case.337 i64 85, label %dispatch.case.338 @@ -1793,13 +1715,13 @@ 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 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 - i64 33, label %dispatch.case.374 + i64 25, label %dispatch.case.368 + i64 27, label %dispatch.case.369 + i64 29, label %dispatch.case.370 + i64 31, label %dispatch.case.371 + i64 32, label %dispatch.case.372 + i64 34, label %dispatch.case.373 + i64 36, label %dispatch.case.374 i64 40, label %dispatch.case.375 i64 44, label %dispatch.case.376 i64 47, label %dispatch.case.377 @@ -1896,7 +1818,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.357, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.359, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.102 dispatch.case.104: ; preds = %match.arm.51 @@ -1918,56 +1840,56 @@ dispatch.case.105: ; preds = %match.arm.51 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 {}, ptr %ua.ptr69, align 1 - %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load70) + %ua.load70 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %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 { 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.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, 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.102 dispatch.case.109: ; preds = %match.arm.51 %ua.raw80 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr81 = inttoptr i64 %ua.raw80 to ptr - %ua.load82 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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.102 dispatch.case.110: ; preds = %match.arm.51 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.102 dispatch.case.111: ; preds = %match.arm.51 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.102 dispatch.case.112: ; preds = %match.arm.51 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.102 @@ -2129,7 +2051,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.358, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.360, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.272 dispatch.case.274: ; preds = %match.arm.52 @@ -2170,7 +2092,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.359, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.361, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.289 dispatch.case.291: ; preds = %match.arm.55 @@ -2235,7 +2157,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.360, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.362, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.333 dispatch.case.335: ; preds = %match.arm.56 @@ -2284,7 +2206,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.361, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.363, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.365 dispatch.case.367: ; preds = %match.arm.57 @@ -2531,7 +2453,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.362, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.364, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.516 dispatch.case.518: ; preds = %match.arm.58 @@ -2573,7 +2495,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.363, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.365, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2669,7 +2591,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.364, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.366, 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 @@ -2677,7 +2599,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.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 @@ -2687,13 +2609,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.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 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.367, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.369, 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 @@ -2701,7 +2623,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.368, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2715,7 +2637,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.369, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, 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 @@ -2723,7 +2645,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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2734,7 +2656,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.371, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2791,7 +2713,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.372, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.374, 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 @@ -2799,7 +2721,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.373, i64 2 }) + %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 i64, ptr %allocaN, align 8 @@ -2810,7 +2732,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.374, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.376, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2830,7 +2752,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.375, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.377, 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 @@ -2838,7 +2760,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.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 %alloca, align 8 @@ -2849,7 +2771,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.377, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.379, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.40 @@ -2859,67 +2781,151 @@ if.merge.40: ; preds = %if.then.39, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3095,166 +3101,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3452,64 +3458,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3539,97 +3545,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3668,118 +3674,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.128(i64, ptr) #0 +declare void @BuildOptions.add_framework.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.129(i64, ptr) #0 +declare void @BuildOptions.set_output_path.131(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.132(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.133(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.132(i64) #0 +declare i64 @BuildOptions.asset_dir_count.134(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.135(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.136(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.137(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.138(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.137(i64) #0 +declare ptr @BuildOptions.binary_path.139(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.141(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.142(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.143(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.142(i64) #0 +declare ptr @BuildOptions.bundle_path.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.143(i64) #0 +declare ptr @BuildOptions.bundle_id.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.144(i64) #0 +declare ptr @BuildOptions.codesign_identity.146(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.145(i64) #0 +declare ptr @BuildOptions.provisioning_profile.147(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.146(i64) #0 +declare ptr @BuildOptions.target_triple.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.147(i64) #0 +declare i1 @BuildOptions.is_macos.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.148(i64) #0 +declare i1 @BuildOptions.is_ios.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.149(i64) #0 +declare i1 @BuildOptions.is_ios_device.151(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.152(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.151(i64) #0 +declare i1 @BuildOptions.is_android.153(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.152(i64) #0 +declare i64 @BuildOptions.framework_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.154(i64) #0 +declare i64 @BuildOptions.framework_path_count.156(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.157(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.158(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.159(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.158(i64) #0 +declare ptr @BuildOptions.manifest_path.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.159(i64) #0 +declare ptr @BuildOptions.keystore_path.161(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.160(i64) #0 +declare i64 @BuildOptions.jni_main_count.162(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.163(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.164(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.163() #0 +declare i64 @build_options.165() #0 ; Function Attrs: nounwind declare ptr @objc_getClass(ptr) #0 @@ -3912,9 +3918,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.378) + %callN = call ptr @objc_getClass(ptr @str.380) store ptr %callN, ptr %allocaN, align 8 - %callN = call ptr @sel_registerName(ptr @str.379) + %callN = call ptr @sel_registerName(ptr @str.381) store ptr %callN, ptr %allocaN, align 8 %loadN = load ptr, ptr %allocaN, align 8 %loadN = load ptr, ptr %allocaN, align 8 @@ -3954,14 +3960,14 @@ entry: define internal void @print__ct_s8b0209b1c8e86f29__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.380, i64 30 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.382, 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.381, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.383, 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) @@ -3977,7 +3983,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.382, i64 30 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.384, i64 30 }) ret { ptr, i64 } %call } @@ -3985,7 +3991,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.383, i64 30 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.385, 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 @@ -4001,7 +4007,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.384, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.386, 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) @@ -4029,7 +4035,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.385, i64 30 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.387, i64 30 }) ret { ptr, i64 } %call } @@ -4037,14 +4043,14 @@ entry: define internal void @print__ct_sa76620ef481aaa22__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.386, i64 51 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.388, 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.387, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.389, 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) @@ -4060,7 +4066,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.388, i64 51 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.390, i64 51 }) ret { ptr, i64 } %call } @@ -4068,7 +4074,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.389, i64 28 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.391, i64 28 }, ptr %alloca, align 8 %allocaN = alloca i32, align 4 store i32 %1, ptr %allocaN, align 4 %allocaN = alloca i32, align 4 @@ -4098,7 +4104,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.390, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.392, 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) @@ -4150,7 +4156,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.391, i64 28 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.393, i64 28 }) ret { ptr, i64 } %call } @@ -4161,7 +4167,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.392, i64 15 }, { ptr, i64 } { ptr @str.393, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.394, i64 15 }, { 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 @@ -4180,12 +4186,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.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.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.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.136 @@ -4197,7 +4203,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.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, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4254,7 +4260,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.402, i64 9 }, { 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 @@ -4273,24 +4279,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.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.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.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.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 [3 x { ptr, i64 }], ptr @field_names.407, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 %alloca, align 8 @@ -4334,20 +4340,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.409, i64 10 }, { ptr, i64 } { ptr @str.410, i64 1 }) + %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.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 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, 2 br i1 %icmp, label %while.body.143, label %while.exit.144 while.body.143: ; preds = %while.hdr.142 @@ -4357,24 +4364,102 @@ 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.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.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 }) + %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.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.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.414, 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 + %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 }, 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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.146 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.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 + 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.421, 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.422, 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.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.424, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -4385,7 +4470,7 @@ if.merge.146: ; preds = %if.then.145, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.142 + br label %while.hdr.147 } ; Function Attrs: nounwind @@ -4393,43 +4478,43 @@ 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 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.425, i64 3 }, { 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 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.147 + br label %while.hdr.152 -while.hdr.147: ; preds = %fv.merge, %entry +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.148, label %while.exit.149 + br i1 %icmp, label %while.body.153, label %while.exit.154 -while.body.148: ; preds = %while.hdr.147 +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.150, label %if.merge.151 + br i1 %icmpN, label %if.then.155, label %if.merge.156 -while.exit.149: ; preds = %while.hdr.147 +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.417, 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.150: ; preds = %while.body.148 +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.418, 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.151 + br label %if.merge.156 -if.merge.151: ; preds = %if.then.150, %while.body.148 +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.420, 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.421, 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 { i64 }, ptr %alloca, align 8 @@ -4446,12 +4531,12 @@ 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.147 + br label %while.hdr.152 -fv.default: ; preds = %if.merge.151 +fv.default: ; preds = %if.merge.156 br label %fv.merge -fv.case: ; preds = %if.merge.151 +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 @@ -4462,43 +4547,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %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 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.152 + br label %while.hdr.157 -while.hdr.152: ; preds = %fv.merge, %entry +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.153, label %while.exit.154 + br i1 %icmp, label %while.body.158, label %while.exit.159 -while.body.153: ; preds = %while.hdr.152 +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.155, label %if.merge.156 + br i1 %icmpN, label %if.then.160, label %if.merge.161 -while.exit.154: ; preds = %while.hdr.152 +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.424, 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.155: ; preds = %while.body.153 +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.425, 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.156 + br label %if.merge.161 -if.merge.156: ; preds = %if.then.155, %while.body.153 +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.428, 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.429, 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 { ptr, i64 }, ptr %alloca, align 8 @@ -4516,18 +4601,18 @@ 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.152 + br label %while.hdr.157 -fv.default: ; preds = %if.merge.156 +fv.default: ; preds = %if.merge.161 br label %fv.merge -fv.case: ; preds = %if.merge.156 +fv.case: ; preds = %if.merge.161 %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 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.156 +fv.case17: ; preds = %if.merge.161 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -4539,91 +4624,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.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 - 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.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.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.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.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 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.157 - -fv.default: ; preds = %if.merge.161 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.161 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.439, i64 8 }, { ptr, i64 } { ptr @str.440, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.440, i64 5 }, { 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 @@ -4642,27 +4643,27 @@ 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.441, 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.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.442, 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.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.446, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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.447, 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 { ptr, i64, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4684,29 +4685,30 @@ fv.default: ; preds = %if.merge.166 br label %fv.merge fv.case: ; preds = %if.merge.166 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.166 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.166 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.448, i64 17 }, { ptr, i64 } { ptr @str.449, i64 1 }) + %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 8 }, { 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 @@ -4715,7 +4717,7 @@ entry: while.hdr.167: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.168, label %while.exit.169 while.body.168: ; preds = %while.hdr.167 @@ -4725,19 +4727,19 @@ 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.450, 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.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.451, 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.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.456, 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 @@ -4745,17 +4747,16 @@ if.merge.171: ; preds = %if.then.170, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4768,35 +4769,29 @@ fv.default: ; preds = %if.merge.171 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.171 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.171 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.171 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.458, i64 7 }, { ptr, i64 } { ptr @str.459, i64 1 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 17 }, { 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 @@ -4805,7 +4800,7 @@ entry: while.hdr.172: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.173, label %while.exit.174 while.body.173: ; preds = %while.hdr.172 @@ -4827,23 +4822,25 @@ if.then.175: ; preds = %while.body.173 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.464, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 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, ptr, ptr }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4856,16 +4853,25 @@ fv.default: ; preds = %if.merge.176 br label %fv.merge fv.case: ; preds = %if.merge.176 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.176 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.176 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.176 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4874,7 +4880,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.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 @@ -4893,24 +4899,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.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.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.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.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.471, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i32 }, ptr %alloca, align 4 @@ -4947,7 +4953,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.473, i64 10 }, { ptr, i64 } { ptr @str.474, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.475, i64 10 }, { 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 @@ -4966,24 +4972,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.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.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.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.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.482, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5049,7 +5055,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.484, i64 13 }, { ptr, i64 } { ptr @str.485, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.486, i64 13 }, { 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 @@ -5068,24 +5074,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.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.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.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.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.490, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.492, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -5127,7 +5133,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.492, i64 8 }, { ptr, i64 } { ptr @str.493, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.494, i64 8 }, { ptr, i64 } { ptr @str.495, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5146,24 +5152,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.494, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.496, 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.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 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.501, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.503, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -5224,7 +5230,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.503, i64 5 }, { ptr, i64 } { ptr @str.504, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.505, i64 5 }, { ptr, i64 } { ptr @str.506, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5243,24 +5249,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.505, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.507, 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.506, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.508, 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.510, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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, i64, i64 }, ptr %alloca, align 8 @@ -5306,7 +5312,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.512, i64 6 }, { ptr, i64 } { ptr @str.513, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.514, i64 6 }, { 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 @@ -5325,24 +5331,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.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.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.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.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.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, i64 }, ptr %alloca, align 8 @@ -5390,7 +5396,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.521, i64 6 }, { ptr, i64 } { ptr @str.522, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.523, i64 6 }, { 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 @@ -5409,24 +5415,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.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.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.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.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.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 { { ptr, i64 }, { i64, [24 x i8] } }, ptr %alloca, align 8 @@ -5470,7 +5476,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.529, i64 4 }, { ptr, i64 } { ptr @str.530, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.531, i64 4 }, { 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 @@ -5489,24 +5495,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.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.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.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.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.536, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 }, i64, ptr }, ptr %alloca, align 8 @@ -5556,7 +5562,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.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 @@ -5575,24 +5581,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.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.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.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.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.545, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { { ptr, i64 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5641,7 +5647,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.547, i64 12 }, { ptr, i64 } { ptr @str.548, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.549, i64 12 }, { ptr, i64 } { ptr @str.550, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5660,24 +5666,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.549, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.551, 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.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 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.551, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 {}, ptr %alloca, align 1 @@ -5697,7 +5703,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.553, i64 8 }, { ptr, i64 } { ptr @str.554, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.555, i64 8 }, { ptr, i64 } { ptr @str.556, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5716,24 +5722,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.555, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.557, 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.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 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.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 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5785,7 +5791,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.562, i64 7 }, { ptr, i64 } { ptr @str.563, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.564, i64 7 }, { ptr, i64 } { ptr @str.565, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5804,24 +5810,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.564, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.566, 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.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 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.569, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.571, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5873,7 +5879,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.571, i64 9 }, { ptr, i64 } { ptr @str.572, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.573, i64 9 }, { ptr, i64 } { ptr @str.574, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5892,24 +5898,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.573, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.575, 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.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 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.577, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5952,7 +5958,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.579, i64 4 }, { ptr, i64 } { ptr @str.580, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.581, i64 4 }, { 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 @@ -5971,24 +5977,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.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.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.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.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.585, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.587, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -6034,7 +6040,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.587, i64 6 }, { ptr, i64 } { ptr @str.588, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.589, i64 6 }, { ptr, i64 } { ptr @str.590, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6053,24 +6059,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.589, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.591, 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.590, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.592, 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.598, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.600, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %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 @@ -6127,7 +6133,7 @@ fv.case28: ; preds = %if.merge.251 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.251 @@ -6152,7 +6158,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.600, i64 6 }, { ptr, i64 } { ptr @str.601, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.602, i64 6 }, { ptr, i64 } { ptr @str.603, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6171,24 +6177,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.602, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, 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.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.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.608, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.610, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6243,7 +6249,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.610, i64 8 }, { ptr, i64 } { ptr @str.611, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.612, i64 8 }, { ptr, i64 } { ptr @str.613, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6262,24 +6268,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.612, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.614, 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.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.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.614, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.616, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6298,7 +6304,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.616, i64 5 }, { ptr, i64 } { ptr @str.617, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.618, i64 5 }, { ptr, i64 } { ptr @str.619, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6317,24 +6323,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.618, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.620, 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.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.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.620, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.622, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -6354,7 +6360,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.622, i64 12 }, { ptr, i64 } { ptr @str.623, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.624, i64 12 }, { ptr, i64 } { ptr @str.625, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6373,24 +6379,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.624, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.626, 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.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.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.630, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.632, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, 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 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i32, i32, i32 }, ptr %alloca, align 8 @@ -6450,9 +6456,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.637, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.639, 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 @@ -6471,8 +6477,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.280 @@ -6491,9 +6497,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.644, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.646, 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.640, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, 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 @@ -6512,8 +6518,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.282 @@ -6543,9 +6549,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.654, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 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.647, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.649, 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 @@ -6562,8 +6568,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.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.284 @@ -6641,9 +6647,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.665, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.667, 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.657, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.659, 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 @@ -6662,8 +6668,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.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 } { ptr @str.669, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.668, 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 @@ -6682,9 +6688,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.674, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.676, 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.668, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.670, 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 @@ -6703,8 +6709,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.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 } { ptr @str.678, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.677, 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 @@ -6721,7 +6727,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.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.298 @@ -6738,12 +6744,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.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.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.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.302 @@ -6772,7 +6778,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.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.303 @@ -6789,12 +6795,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.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.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.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.307 @@ -6824,7 +6830,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.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.308 @@ -6841,12 +6847,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.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.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.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.312 @@ -6874,7 +6880,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.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.313 @@ -6891,12 +6897,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.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.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.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.317 @@ -6925,7 +6931,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.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.318 @@ -6942,12 +6948,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.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.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.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.322 @@ -6976,7 +6982,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.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.323 @@ -6993,12 +6999,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.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.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.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.327 @@ -7029,7 +7035,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.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.328 @@ -7046,12 +7052,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.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.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.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.332 @@ -7081,7 +7087,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.698, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.700, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.340 @@ -7100,12 +7106,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.699, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.701, 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.700, 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 br label %if.merge.344 @@ -7134,7 +7140,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.701, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.703, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.345 @@ -7153,12 +7159,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.702, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.704, 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.703, 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.349 @@ -7187,7 +7193,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.704, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.706, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.350 @@ -7206,12 +7212,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.705, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.707, 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.706, i64 2 }) + %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 br label %if.merge.354 @@ -7241,7 +7247,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.707, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.709, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.355 @@ -7260,12 +7266,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.708, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.710, 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.709, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.711, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.359 @@ -7295,7 +7301,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.710, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.712, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 br label %while.hdr.360 @@ -7314,12 +7320,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.711, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.713, 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.712, i64 2 }) + %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.364 @@ -7361,12 +7367,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.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.403 if.merge.403: ; preds = %if.else.402, %if.then.401 - %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.401 ], [ %callN, %if.else.402 ] + %bp = phi { ptr, i64 } [ { ptr @str.715, i64 4 }, %if.then.401 ], [ %callN, %if.else.402 ] ret { ptr, i64 } %bp } @@ -7389,12 +7395,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.718, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.717, i64 11 }, { 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 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.716, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] + %bp = phi { ptr, i64 } [ { ptr @str.718, i64 4 }, %if.then.417 ], [ %callN, %if.else.418 ] ret { ptr, i64 } %bp } @@ -7417,12 +7423,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.721, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.720, i64 4 }, { 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 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.719, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] + %bp = phi { ptr, i64 } [ { ptr @str.721, i64 4 }, %if.then.420 ], [ %callN, %if.else.421 ] ret { ptr, i64 } %bp } @@ -7445,12 +7451,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.724, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.723, i64 11 }, { 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 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.722, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] + %bp = phi { ptr, i64 } [ { ptr @str.724, i64 4 }, %if.then.423 ], [ %callN, %if.else.424 ] ret { ptr, i64 } %bp } @@ -7473,12 +7479,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.727, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.726, i64 6 }, { 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 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.725, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] + %bp = phi { ptr, i64 } [ { ptr @str.727, i64 4 }, %if.then.426 ], [ %callN, %if.else.427 ] ret { ptr, i64 } %bp } @@ -7500,12 +7506,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.730, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.729, i64 5 }, { 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 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.728, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] + %bp = phi { ptr, i64 } [ { ptr @str.730, i64 4 }, %if.then.429 ], [ %callN, %if.else.430 ] ret { ptr, i64 } %bp } @@ -7528,12 +7534,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.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.434 if.merge.434: ; preds = %if.else.433, %if.then.432 - %bp = phi { ptr, i64 } [ { ptr @str.731, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] + %bp = phi { ptr, i64 } [ { ptr @str.733, i64 4 }, %if.then.432 ], [ %callN, %if.else.433 ] ret { ptr, i64 } %bp } @@ -7556,12 +7562,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.736, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.735, i64 18 }, { 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 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.734, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] + %bp = phi { ptr, i64 } [ { ptr @str.736, i64 4 }, %if.then.435 ], [ %callN, %if.else.436 ] ret { ptr, i64 } %bp } @@ -7584,12 +7590,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.739, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.738, i64 5 }, { 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 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.737, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] + %bp = phi { ptr, i64 } [ { ptr @str.739, i64 4 }, %if.then.438 ], [ %callN, %if.else.439 ] ret { ptr, i64 } %bp } @@ -7612,12 +7618,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.742, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.741, i64 3 }, { 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 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.740, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] + %bp = phi { ptr, i64 } [ { ptr @str.742, i64 4 }, %if.then.441 ], [ %callN, %if.else.442 ] ret { ptr, i64 } %bp } @@ -7640,12 +7646,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.745, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.744, i64 4 }, { 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 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.743, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] + %bp = phi { ptr, i64 } [ { ptr @str.745, i64 4 }, %if.then.444 ], [ %callN, %if.else.445 ] ret { ptr, i64 } %bp } @@ -7668,12 +7674,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.748, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.747, i64 9 }, { 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 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.746, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] + %bp = phi { ptr, i64 } [ { ptr @str.748, i64 4 }, %if.then.447 ], [ %callN, %if.else.448 ] ret { ptr, i64 } %bp } @@ -7696,12 +7702,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.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.452 if.merge.452: ; preds = %if.else.451, %if.then.450 - %bp = phi { ptr, i64 } [ { ptr @str.749, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] + %bp = phi { ptr, i64 } [ { ptr @str.751, i64 4 }, %if.then.450 ], [ %callN, %if.else.451 ] ret { ptr, i64 } %bp } @@ -7723,12 +7729,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.754, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.753, i64 8 }, { 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 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.752, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] + %bp = phi { ptr, i64 } [ { ptr @str.754, i64 4 }, %if.then.453 ], [ %callN, %if.else.454 ] ret { ptr, i64 } %bp } @@ -7751,12 +7757,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.757, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.756, i64 6 }, { 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 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.755, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] + %bp = phi { ptr, i64 } [ { ptr @str.757, i64 4 }, %if.then.456 ], [ %callN, %if.else.457 ] ret { ptr, i64 } %bp } @@ -7778,12 +7784,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.760, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.759, i64 9 }, { 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 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.758, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] + %bp = phi { ptr, i64 } [ { ptr @str.760, i64 4 }, %if.then.459 ], [ %callN, %if.else.460 ] ret { ptr, i64 } %bp } @@ -7806,12 +7812,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.763, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.762, i64 7 }, { 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 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.761, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] + %bp = phi { ptr, i64 } [ { ptr @str.763, i64 4 }, %if.then.462 ], [ %callN, %if.else.463 ] ret { ptr, i64 } %bp } @@ -7834,12 +7840,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.766, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.765, i64 5 }, { 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 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.764, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] + %bp = phi { ptr, i64 } [ { ptr @str.766, i64 4 }, %if.then.465 ], [ %callN, %if.else.466 ] ret { ptr, i64 } %bp } @@ -7862,12 +7868,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.769, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.768, i64 7 }, { 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 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.767, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] + %bp = phi { ptr, i64 } [ { ptr @str.769, i64 4 }, %if.then.468 ], [ %callN, %if.else.469 ] ret { ptr, i64 } %bp } @@ -7890,12 +7896,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.772, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.771, i64 4 }, { 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 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.770, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] + %bp = phi { ptr, i64 } [ { ptr @str.772, i64 4 }, %if.then.471 ], [ %callN, %if.else.472 ] ret { ptr, i64 } %bp } @@ -7918,12 +7924,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.775, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.774, i64 7 }, { 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 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.773, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] + %bp = phi { ptr, i64 } [ { ptr @str.775, i64 4 }, %if.then.474 ], [ %callN, %if.else.475 ] ret { ptr, i64 } %bp } @@ -7946,12 +7952,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.778, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.777, i64 5 }, { 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 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.776, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] + %bp = phi { ptr, i64 } [ { ptr @str.778, i64 4 }, %if.then.477 ], [ %callN, %if.else.478 ] ret { ptr, i64 } %bp } @@ -7974,12 +7980,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.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.482 if.merge.482: ; preds = %if.else.481, %if.then.480 - %bp = phi { ptr, i64 } [ { ptr @str.779, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] + %bp = phi { ptr, i64 } [ { ptr @str.781, i64 4 }, %if.then.480 ], [ %callN, %if.else.481 ] ret { ptr, i64 } %bp } @@ -8002,12 +8008,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.784, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.783, i64 9 }, { 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 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.782, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] + %bp = phi { ptr, i64 } [ { ptr @str.784, i64 4 }, %if.then.483 ], [ %callN, %if.else.484 ] ret { ptr, i64 } %bp } @@ -8030,12 +8036,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.787, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.786, i64 12 }, { 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 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.785, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] + %bp = phi { ptr, i64 } [ { ptr @str.787, i64 4 }, %if.then.486 ], [ %callN, %if.else.487 ] ret { ptr, i64 } %bp } @@ -8058,12 +8064,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.790, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.789, i64 6 }, { 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 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.788, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] + %bp = phi { ptr, i64 } [ { ptr @str.790, i64 4 }, %if.then.489 ], [ %callN, %if.else.490 ] ret { ptr, i64 } %bp } @@ -8086,12 +8092,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.793, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.792, i64 6 }, { 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 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.791, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] + %bp = phi { ptr, i64 } [ { ptr @str.793, i64 4 }, %if.then.492 ], [ %callN, %if.else.493 ] ret { ptr, i64 } %bp } @@ -8114,12 +8120,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.796, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.795, i64 7 }, { 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 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.794, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] + %bp = phi { ptr, i64 } [ { ptr @str.796, i64 4 }, %if.then.495 ], [ %callN, %if.else.496 ] ret { ptr, i64 } %bp } @@ -8142,12 +8148,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.799, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.798, i64 7 }, { 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 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.797, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] + %bp = phi { ptr, i64 } [ { ptr @str.799, i64 4 }, %if.then.498 ], [ %callN, %if.else.499 ] ret { ptr, i64 } %bp } @@ -8170,12 +8176,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.802, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.801, i64 4 }, { 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 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.800, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] + %bp = phi { ptr, i64 } [ { ptr @str.802, i64 4 }, %if.then.501 ], [ %callN, %if.else.502 ] ret { ptr, i64 } %bp } @@ -8198,12 +8204,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.805, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.804, i64 6 }, { 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 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.803, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] + %bp = phi { ptr, i64 } [ { ptr @str.805, i64 4 }, %if.then.504 ], [ %callN, %if.else.505 ] ret { ptr, i64 } %bp } @@ -8226,12 +8232,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.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.509 if.merge.509: ; preds = %if.else.508, %if.then.507 - %bp = phi { ptr, i64 } [ { ptr @str.806, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] + %bp = phi { ptr, i64 } [ { ptr @str.808, i64 4 }, %if.then.507 ], [ %callN, %if.else.508 ] ret { ptr, i64 } %bp } @@ -8254,12 +8260,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.811, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.810, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.813, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.812, 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.809, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] + %bp = phi { ptr, i64 } [ { ptr @str.811, i64 4 }, %if.then.510 ], [ %callN, %if.else.511 ] ret { ptr, i64 } %bp } @@ -8282,12 +8288,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.814, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.813, i64 7 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.816, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.815, 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.812, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] + %bp = phi { ptr, i64 } [ { ptr @str.814, i64 4 }, %if.then.513 ], [ %callN, %if.else.514 ] ret { ptr, i64 } %bp } @@ -8303,7 +8309,7 @@ entry: br i1 %lnot, label %if.then.522, label %if.merge.523 if.then.522: ; preds = %entry - ret { ptr, i64 } { ptr @str.815, i64 4 } + ret { ptr, i64 } { ptr @str.817, i64 4 } if.merge.523: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8327,7 +8333,7 @@ entry: br i1 %lnot, label %if.then.524, label %if.merge.525 if.then.524: ; preds = %entry - ret { ptr, i64 } { ptr @str.816, i64 4 } + ret { ptr, i64 } { ptr @str.818, i64 4 } if.merge.525: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8351,7 +8357,7 @@ entry: br i1 %lnot, label %if.then.526, label %if.merge.527 if.then.526: ; preds = %entry - ret { ptr, i64 } { ptr @str.817, i64 4 } + ret { ptr, i64 } { ptr @str.819, i64 4 } if.merge.527: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8375,7 +8381,7 @@ entry: br i1 %lnot, label %if.then.528, label %if.merge.529 if.then.528: ; preds = %entry - ret { ptr, i64 } { ptr @str.818, i64 4 } + ret { ptr, i64 } { ptr @str.820, i64 4 } if.merge.529: ; preds = %entry %loadN = load { [64 x i8], i1 }, ptr %alloca, align 1 @@ -8483,15 +8489,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_.819) - 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_setHeight_, align 8 %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.821) - 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_.822) - 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_.823) + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_width, align 8 + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.824) + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_height, align 8 + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.825) store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_area, align 8 ret void } @@ -8503,25 +8509,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_.824, i64 0) + %cls = call ptr @objc_allocateClassPair(ptr %super_cls, ptr @OBJC_CLASS_NAME_.826, 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_.825) + %sel = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.827) %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_.826) - %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) - %3 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_height_imp, ptr @OBJC_METH_VAR_TYPE_.829) + %2 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_setWidth_imp, ptr @OBJC_METH_VAR_TYPE_.829) %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.830) - %4 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_setHeight_imp, ptr @OBJC_METH_VAR_TYPE_.831) + %3 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_height_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) + %4 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_setHeight_imp, ptr @OBJC_METH_VAR_TYPE_.833) + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.834) + %5 = call i1 @class_addMethod(ptr %cls, ptr %selN, ptr @__SxBox_area_imp, ptr @OBJC_METH_VAR_TYPE_.835) 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_.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) + %sel_dealloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.836) + %6 = call i1 @class_addMethod(ptr %cls, ptr %sel_dealloc, ptr @__SxBox_dealloc_imp, ptr @OBJC_METH_VAR_TYPE_.837) + %sel_alloc = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.838) + %7 = call i1 @class_addMethod(ptr %metacls, ptr %sel_alloc, ptr @__SxBox_alloc_imp, ptr @OBJC_METH_VAR_TYPE_.839) %iv = call ptr @class_getInstanceVariable(ptr %cls, ptr @OBJC_IVAR_NAME_) store ptr %iv, ptr @__SxBox_state_ivar, align 8 ret void @@ -8529,7 +8535,7 @@ entry: define internal void @__sx_objc_class_init() { entry: - %cls = call ptr @objc_getClass(ptr @OBJC_CLASS_NAME_.838) + %cls = call ptr @objc_getClass(ptr @OBJC_CLASS_NAME_.840) 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 4e824cb..8f70747 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.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.166 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.167 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.168 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.169 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.170 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.171 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.172 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.173 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.174 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.175 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.176 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.177 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.178 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.179 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.180 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.181 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.182 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.183 = 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_.182 = private unnamed_addr constant [8 x i8] c"release\00" +@OBJC_METH_VAR_NAME_.184 = 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 @@ -37,85 +37,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -331,7 +253,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.164, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.166, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -427,7 +349,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.165, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, 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 @@ -435,7 +357,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.166, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -445,13 +367,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.167, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, 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.168, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, 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 @@ -459,7 +381,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.169, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -473,7 +395,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.170, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, 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 @@ -481,7 +403,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.171, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -492,7 +414,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.172, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -549,7 +471,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.173, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, 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 @@ -557,7 +479,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.174, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, 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 @@ -568,7 +490,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.175, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.177, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -588,7 +510,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.176, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.178, 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 @@ -596,7 +518,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.177, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.179, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -607,7 +529,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.178, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.180, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -617,67 +539,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -853,166 +859,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1210,64 +1216,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1297,97 +1303,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1426,118 +1432,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.128(i64, ptr) #0 +declare void @BuildOptions.add_framework.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.129(i64, ptr) #0 +declare void @BuildOptions.set_output_path.131(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.132(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.133(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.132(i64) #0 +declare i64 @BuildOptions.asset_dir_count.134(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.135(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.136(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.137(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.138(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.137(i64) #0 +declare ptr @BuildOptions.binary_path.139(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.141(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.142(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.143(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.142(i64) #0 +declare ptr @BuildOptions.bundle_path.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.143(i64) #0 +declare ptr @BuildOptions.bundle_id.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.144(i64) #0 +declare ptr @BuildOptions.codesign_identity.146(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.145(i64) #0 +declare ptr @BuildOptions.provisioning_profile.147(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.146(i64) #0 +declare ptr @BuildOptions.target_triple.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.147(i64) #0 +declare i1 @BuildOptions.is_macos.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.148(i64) #0 +declare i1 @BuildOptions.is_ios.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.149(i64) #0 +declare i1 @BuildOptions.is_ios_device.151(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.152(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.151(i64) #0 +declare i1 @BuildOptions.is_android.153(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.152(i64) #0 +declare i64 @BuildOptions.framework_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.154(i64) #0 +declare i64 @BuildOptions.framework_path_count.156(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.157(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.158(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.159(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.158(i64) #0 +declare ptr @BuildOptions.manifest_path.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.159(i64) #0 +declare ptr @BuildOptions.keystore_path.161(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.160(i64) #0 +declare i64 @BuildOptions.jni_main_count.162(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.163(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.164(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.163() #0 +declare i64 @build_options.165() #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -1573,14 +1579,14 @@ entry: define internal void @print__ct_sbdbafa1a5fe828c0__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.179, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.181, 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.180, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.182, 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) @@ -1596,7 +1602,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.181, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.183, i64 3 }) ret { ptr, i64 } %call } @@ -1608,7 +1614,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_.182) + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.184) 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 801a47a..74a5cd4 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.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 +@str.166 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.167 = private unnamed_addr constant [5 x i8] c"true\00", align 1 +@str.168 = private unnamed_addr constant [6 x i8] c"false\00", align 1 +@str.169 = private unnamed_addr constant [2 x i8] c"0\00", align 1 +@str.170 = private unnamed_addr constant [4 x i8] c"\00", align 1 +@str.171 = 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.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 }] +@tag.str.172 = private constant [9 x i8] c"Overflow\00" +@tag.str.173 = private constant [3 x i8] c"Io\00" +@tag.str.174 = private constant [16 x i8] c"UnexpectedToken\00" +@tag.str.175 = private constant [14 x i8] c"UnexpectedEnd\00" +@tag.str.176 = private constant [10 x i8] c"BadEscape\00" +@tag.str.177 = private constant [10 x i8] c"BadNumber\00" +@tag.str.178 = private constant [16 x i8] c"TrailingGarbage\00" +@tag.str.179 = private constant [15 x i8] c"BadControlChar\00" +@tag.str.180 = private constant [15 x i8] c"UnknownCommand\00" +@tag.str.181 = private constant [12 x i8] c"UnknownFlag\00" +@tag.str.182 = private constant [13 x i8] c"MissingValue\00" +@tag.str.183 = private constant [16 x i8] c"MissingRequired\00" +@tag.str.184 = 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.172, i64 8 }, { ptr, i64 } { ptr @tag.str.173, i64 2 }, { ptr, i64 } { ptr @tag.str.174, i64 15 }, { ptr, i64 } { ptr @tag.str.175, i64 13 }, { ptr, i64 } { ptr @tag.str.176, i64 9 }, { ptr, i64 } { ptr @tag.str.177, i64 9 }, { ptr, i64 } { ptr @tag.str.178, i64 15 }, { ptr, i64 } { ptr @tag.str.179, i64 14 }, { ptr, i64 } { ptr @tag.str.180, i64 14 }, { ptr, i64 } { ptr @tag.str.181, i64 11 }, { ptr, i64 } { ptr @tag.str.182, i64 12 }, { ptr, i64 } { ptr @tag.str.183, i64 15 }, { ptr, i64 } { ptr @tag.str.184, i64 12 }] @tn.str = private constant [13 x i8] c"\00" -@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 +@tn.str.185 = private constant [5 x i8] c"bool\00" +@tn.str.186 = private constant [3 x i8] c"s8\00" +@tn.str.187 = private constant [4 x i8] c"s16\00" +@tn.str.188 = private constant [4 x i8] c"s32\00" +@tn.str.189 = private constant [4 x i8] c"s64\00" +@tn.str.190 = private constant [3 x i8] c"u8\00" +@tn.str.191 = private constant [4 x i8] c"u16\00" +@tn.str.192 = private constant [4 x i8] c"u32\00" +@tn.str.193 = private constant [4 x i8] c"u64\00" +@tn.str.194 = private constant [4 x i8] c"f32\00" +@tn.str.195 = private constant [4 x i8] c"f64\00" +@tn.str.196 = private constant [7 x i8] c"string\00" +@tn.str.197 = private constant [4 x i8] c"Any\00" +@tn.str.198 = private constant [9 x i8] c"noreturn\00" +@tn.str.199 = private constant [6 x i8] c"isize\00" +@tn.str.200 = private constant [6 x i8] c"usize\00" +@tn.str.201 = private constant [5 x i8] c"void\00" +@tn.str.202 = private constant [6 x i8] c"*void\00" +@tn.str.203 = private constant [16 x i8] c"Source_Location\00" +@tn.str.204 = private constant [10 x i8] c"Allocator\00" +@tn.str.205 = private constant [8 x i8] c"Context\00" +@tn.str.206 = private constant [7 x i8] c"[4]s64\00" +@tn.str.207 = private constant [9 x i8] c"[]string\00" +@tn.str.208 = private constant [11 x i8] c"CAllocator\00" +@tn.str.209 = private constant [12 x i8] c"*CAllocator\00" +@tn.str.210 = private constant [4 x i8] c"GPA\00" +@tn.str.211 = private constant [5 x i8] c"*GPA\00" +@tn.str.212 = private constant [11 x i8] c"ArenaChunk\00" +@tn.str.213 = private constant [12 x i8] c"*ArenaChunk\00" +@tn.str.214 = private constant [6 x i8] c"Arena\00" +@tn.str.215 = private constant [7 x i8] c"*Arena\00" +@tn.str.216 = private constant [6 x i8] c"[*]u8\00" +@tn.str.217 = private constant [9 x i8] c"BufAlloc\00" +@tn.str.218 = private constant [10 x i8] c"*BufAlloc\00" +@tn.str.219 = private constant [18 x i8] c"TrackingAllocator\00" +@tn.str.220 = private constant [19 x i8] c"*TrackingAllocator\00" +@tn.str.221 = private constant [9 x i8] c"OpenMode\00" +@tn.str.222 = private constant [9 x i8] c"SeekFrom\00" +@tn.str.223 = private constant [5 x i8] c"File\00" +@tn.str.224 = private constant [6 x i8] c"*File\00" +@tn.str.225 = private constant [6 x i8] c"?File\00" +@tn.str.226 = private constant [8 x i8] c"?string\00" +@tn.str.227 = private constant [11 x i8] c"TraceFrame\00" +@tn.str.228 = private constant [4 x i8] c"*u8\00" +@tn.str.229 = private constant [14 x i8] c"ProcessResult\00" +@tn.str.230 = private constant [15 x i8] c"?ProcessResult\00" +@tn.str.231 = private constant [5 x i8] c"*s32\00" +@tn.str.232 = private constant [9 x i8] c"SockAddr\00" +@tn.str.233 = private constant [10 x i8] c"*SockAddr\00" +@tn.str.234 = private constant [5 x i8] c"*u32\00" +@tn.str.235 = private constant [10 x i8] c"JsonError\00" +@tn.str.236 = private constant [6 x i8] c"Array\00" +@tn.str.237 = private constant [7 x i8] c"Object\00" +@tn.str.238 = private constant [6 x i8] c"Value\00" +@tn.str.239 = private constant [7 x i8] c"Member\00" +@tn.str.240 = private constant [9 x i8] c"[*]Value\00" +@tn.str.241 = private constant [7 x i8] c"*Array\00" +@tn.str.242 = private constant [10 x i8] c"[*]Member\00" +@tn.str.243 = private constant [8 x i8] c"*Object\00" +@tn.str.244 = private constant [5 x i8] c"[]u8\00" +@tn.str.245 = private constant [5 x i8] c"Sink\00" +@tn.str.246 = private constant [6 x i8] c"*Sink\00" +@tn.str.247 = private constant [17 x i8] c"(s64, JsonError)\00" +@tn.str.248 = private constant [15 x i8] c"JsonParseError\00" +@tn.str.249 = private constant [22 x i8] c"(s64, JsonParseError)\00" +@tn.str.250 = private constant [7 x i8] c"Parser\00" +@tn.str.251 = private constant [8 x i8] c"*Parser\00" +@tn.str.252 = private constant [25 x i8] c"(string, JsonParseError)\00" +@tn.str.253 = private constant [24 x i8] c"(Value, JsonParseError)\00" +@tn.str.254 = private constant [16 x i8] c"OperatingSystem\00" +@tn.str.255 = private constant [13 x i8] c"Architecture\00" +@tn.str.256 = private constant [13 x i8] c"BuildOptions\00" +@tn.str.257 = private constant [11 x i8] c"() -> bool\00" +@tn.str.258 = private constant [5 x i8] c"*s64\00" +@tn.str.259 = private constant [9 x i8] c"CliError\00" +@tn.str.260 = private constant [9 x i8] c"FlagSpec\00" +@tn.str.261 = private constant [11 x i8] c"[]FlagSpec\00" +@tn.str.262 = private constant [8 x i8] c"Command\00" +@tn.str.263 = private constant [10 x i8] c"FlagValue\00" +@tn.str.264 = private constant [5 x i8] c"Diag\00" +@tn.str.265 = private constant [14 x i8] c"[16]FlagValue\00" +@tn.str.266 = private constant [7 x i8] c"Parsed\00" +@tn.str.267 = private constant [8 x i8] c"*Parsed\00" +@tn.str.268 = private constant [19 x i8] c"(Parsed, CliError)\00" +@tn.str.269 = private constant [10 x i8] c"[]Command\00" +@tn.str.270 = private constant [6 x i8] c"*Diag\00" +@tn.str.271 = private constant [7 x i8] c"[8]s64\00" +@tn.str.272 = private constant [7 x i8] c"[64]u8\00" +@tn.str.273 = private constant [7 x i8] c"Sha256\00" +@tn.str.274 = private constant [8 x i8] c"*Sha256\00" +@tn.str.275 = private constant [8 x i8] c"?[64]u8\00" +@tn.str.276 = private constant [8 x i8] c"[64]s64\00" +@tn.str.277 = private constant [9 x i8] c"NSString\00" +@tn.str.278 = private constant [10 x i8] c"*NSString\00" +@tn.str.279 = private constant [10 x i8] c"Closure()\00" +@tn.str.280 = private constant [7 x i8] c"Triple\00" +@tn.str.281 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.282 = private constant [7 x i8] c"**void\00" +@tn.str.283 = private constant [6 x i8] c"*bool\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"[1]Any\00" +@tn.str.288 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.289 = private constant [7 x i8] c"*[]Any\00" +@tn.str.290 = private constant [8 x i8] c"*Triple\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 [10 x i8] c"*OpenMode\00" +@tn.str.306 = private constant [10 x i8] c"*SeekFrom\00" +@tn.str.307 = private constant [7 x i8] c"*Value\00" +@tn.str.308 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.309 = private constant [14 x i8] c"*Architecture\00" +@tn.str.310 = private constant [15 x i8] c"*[16]FlagValue\00" +@tn.str.311 = private constant [8 x i8] c"*[8]s64\00" +@tn.str.312 = private constant [8 x i8] c"*[64]u8\00" +@tn.str.313 = private constant [9 x i8] c"*[64]s64\00" +@tn.str.314 = private constant [10 x i8] c"*[]string\00" +@tn.str.315 = private constant [6 x i8] c"*[]u8\00" +@tn.str.316 = private constant [12 x i8] c"*[]FlagSpec\00" +@tn.str.317 = private constant [11 x i8] c"*[]Command\00" +@tn.str.318 = private constant [6 x i8] c"**GPA\00" +@tn.str.319 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.320 = private constant [8 x i8] c"**Arena\00" +@tn.str.321 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.322 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.323 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.324 = private constant [7 x i8] c"**File\00" +@tn.str.325 = private constant [5 x i8] c"**u8\00" +@tn.str.326 = private constant [6 x i8] c"**s32\00" +@tn.str.327 = private constant [11 x i8] c"**SockAddr\00" +@tn.str.328 = private constant [6 x i8] c"**u32\00" +@tn.str.329 = private constant [10 x i8] c"*[*]Value\00" +@tn.str.330 = private constant [8 x i8] c"**Array\00" +@tn.str.331 = private constant [11 x i8] c"*[*]Member\00" +@tn.str.332 = private constant [9 x i8] c"**Object\00" +@tn.str.333 = private constant [7 x i8] c"**Sink\00" +@tn.str.334 = private constant [9 x i8] c"**Parser\00" +@tn.str.335 = private constant [6 x i8] c"**s64\00" +@tn.str.336 = private constant [9 x i8] c"**Parsed\00" +@tn.str.337 = private constant [7 x i8] c"**Diag\00" +@tn.str.338 = private constant [9 x i8] c"**Sha256\00" +@tn.str.339 = private constant [11 x i8] c"**NSString\00" +@tn.str.340 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.341 = private constant [8 x i8] c"***void\00" +@tn.str.342 = private constant [7 x i8] c"**bool\00" +@tn.str.343 = private constant [9 x i8] c"**string\00" +@tn.str.344 = private constant [6 x i8] c"**Any\00" +@tn.str.345 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.346 = private constant [8 x i8] c"**[]Any\00" +@tn.str.347 = private constant [9 x i8] c"**Triple\00" +@tn.str.348 = private constant [9 x i8] c"**[3]Any\00" +@tn.str.349 = private constant [7 x i8] c"*?File\00" +@tn.str.350 = private constant [9 x i8] c"*?string\00" +@tn.str.351 = private constant [16 x i8] c"*?ProcessResult\00" +@tn.str.352 = 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.185, i64 4 }, { 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 2 }, { 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 3 }, { ptr, i64 } { ptr @tn.str.195, i64 3 }, { ptr, i64 } { ptr @tn.str.196, i64 6 }, { ptr, i64 } { ptr @tn.str.197, i64 3 }, { ptr, i64 } { ptr @tn.str.198, i64 8 }, { ptr, i64 } { ptr @tn.str.199, i64 5 }, { ptr, i64 } { ptr @tn.str.200, i64 5 }, { ptr, i64 } { ptr @tn.str.201, i64 4 }, { ptr, i64 } { ptr @tn.str.202, i64 5 }, { ptr, i64 } { ptr @tn.str.203, i64 15 }, { ptr, i64 } { ptr @tn.str.204, i64 9 }, { ptr, i64 } { ptr @tn.str.205, i64 7 }, { ptr, i64 } { ptr @tn.str.206, i64 6 }, { ptr, i64 } { ptr @tn.str.207, i64 8 }, { ptr, i64 } { ptr @tn.str.208, i64 10 }, { ptr, i64 } { ptr @tn.str.209, i64 11 }, { ptr, i64 } { ptr @tn.str.210, i64 3 }, { ptr, i64 } { ptr @tn.str.211, i64 4 }, { ptr, i64 } { ptr @tn.str.212, i64 10 }, { ptr, i64 } { ptr @tn.str.213, i64 11 }, { ptr, i64 } { ptr @tn.str.214, i64 5 }, { ptr, i64 } { ptr @tn.str.215, i64 6 }, { ptr, i64 } { ptr @tn.str.216, i64 5 }, { ptr, i64 } { ptr @tn.str.217, i64 8 }, { ptr, i64 } { ptr @tn.str.218, i64 9 }, { ptr, i64 } { ptr @tn.str.219, i64 17 }, { ptr, i64 } { ptr @tn.str.220, i64 18 }, { ptr, i64 } { ptr @tn.str.221, i64 8 }, { ptr, i64 } { ptr @tn.str.222, i64 8 }, { ptr, i64 } { ptr @tn.str.223, i64 4 }, { ptr, i64 } { ptr @tn.str.224, i64 5 }, { ptr, i64 } { ptr @tn.str.225, i64 5 }, { ptr, i64 } { ptr @tn.str.226, i64 7 }, { ptr, i64 } { ptr @tn.str.227, i64 10 }, { ptr, i64 } { ptr @tn.str.228, i64 3 }, { ptr, i64 } { ptr @tn.str.229, i64 13 }, { ptr, i64 } { ptr @tn.str.230, i64 14 }, { ptr, i64 } { ptr @tn.str.231, i64 4 }, { ptr, i64 } { ptr @tn.str.232, i64 8 }, { ptr, i64 } { ptr @tn.str.233, i64 9 }, { ptr, i64 } { ptr @tn.str.234, i64 4 }, { ptr, i64 } { ptr @tn.str.235, i64 9 }, { ptr, i64 } { ptr @tn.str.236, i64 5 }, { ptr, i64 } { ptr @tn.str.237, i64 6 }, { ptr, i64 } { ptr @tn.str.238, i64 5 }, { ptr, i64 } { ptr @tn.str.239, i64 6 }, { ptr, i64 } { ptr @tn.str.240, i64 8 }, { ptr, i64 } { ptr @tn.str.241, i64 6 }, { ptr, i64 } { ptr @tn.str.242, i64 9 }, { ptr, i64 } { ptr @tn.str.243, i64 7 }, { ptr, i64 } { ptr @tn.str.244, i64 4 }, { ptr, i64 } { ptr @tn.str.245, i64 4 }, { ptr, i64 } { ptr @tn.str.246, i64 5 }, { ptr, i64 } { ptr @tn.str.247, i64 16 }, { ptr, i64 } { ptr @tn.str.248, i64 14 }, { ptr, i64 } { ptr @tn.str.249, i64 21 }, { ptr, i64 } { ptr @tn.str.250, i64 6 }, { ptr, i64 } { ptr @tn.str.251, i64 7 }, { ptr, i64 } { ptr @tn.str.252, i64 24 }, { ptr, i64 } { ptr @tn.str.253, i64 23 }, { ptr, i64 } { ptr @tn.str.254, i64 15 }, { ptr, i64 } { ptr @tn.str.255, i64 12 }, { ptr, i64 } { ptr @tn.str.256, i64 12 }, { ptr, i64 } { ptr @tn.str.257, i64 10 }, { ptr, i64 } { ptr @tn.str.258, i64 4 }, { ptr, i64 } { ptr @tn.str.259, i64 8 }, { ptr, i64 } { ptr @tn.str.260, i64 8 }, { ptr, i64 } { ptr @tn.str.261, i64 10 }, { ptr, i64 } { ptr @tn.str.262, i64 7 }, { ptr, i64 } { ptr @tn.str.263, i64 9 }, { ptr, i64 } { ptr @tn.str.264, i64 4 }, { ptr, i64 } { ptr @tn.str.265, i64 13 }, { ptr, i64 } { ptr @tn.str.266, i64 6 }, { ptr, i64 } { ptr @tn.str.267, i64 7 }, { ptr, i64 } { ptr @tn.str.268, i64 18 }, { ptr, i64 } { ptr @tn.str.269, i64 9 }, { ptr, i64 } { ptr @tn.str.270, i64 5 }, { ptr, i64 } { ptr @tn.str.271, i64 6 }, { ptr, i64 } { ptr @tn.str.272, i64 6 }, { ptr, i64 } { ptr @tn.str.273, i64 6 }, { ptr, i64 } { ptr @tn.str.274, i64 7 }, { ptr, i64 } { ptr @tn.str.275, i64 7 }, { ptr, i64 } { ptr @tn.str.276, i64 7 }, { ptr, i64 } { ptr @tn.str.277, i64 8 }, { 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 12 }, { ptr, i64 } { ptr @tn.str.282, i64 6 }, { ptr, i64 } { ptr @tn.str.283, i64 5 }, { 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 7 }, { 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 9 }, { ptr, i64 } { ptr @tn.str.306, i64 9 }, { ptr, i64 } { ptr @tn.str.307, i64 6 }, { ptr, i64 } { ptr @tn.str.308, i64 16 }, { ptr, i64 } { ptr @tn.str.309, i64 13 }, { ptr, i64 } { ptr @tn.str.310, i64 14 }, { ptr, i64 } { ptr @tn.str.311, i64 7 }, { ptr, i64 } { ptr @tn.str.312, i64 7 }, { ptr, i64 } { ptr @tn.str.313, i64 8 }, { ptr, i64 } { ptr @tn.str.314, i64 9 }, { ptr, i64 } { ptr @tn.str.315, i64 5 }, { ptr, i64 } { ptr @tn.str.316, i64 11 }, { ptr, i64 } { ptr @tn.str.317, i64 10 }, { ptr, i64 } { ptr @tn.str.318, i64 5 }, { ptr, i64 } { ptr @tn.str.319, i64 12 }, { ptr, i64 } { ptr @tn.str.320, i64 7 }, { ptr, i64 } { ptr @tn.str.321, i64 6 }, { ptr, i64 } { ptr @tn.str.322, i64 10 }, { ptr, i64 } { ptr @tn.str.323, i64 19 }, { ptr, i64 } { ptr @tn.str.324, i64 6 }, { ptr, i64 } { ptr @tn.str.325, i64 4 }, { ptr, i64 } { ptr @tn.str.326, i64 5 }, { ptr, i64 } { ptr @tn.str.327, i64 10 }, { ptr, i64 } { ptr @tn.str.328, i64 5 }, { ptr, i64 } { ptr @tn.str.329, i64 9 }, { ptr, i64 } { ptr @tn.str.330, i64 7 }, { ptr, i64 } { ptr @tn.str.331, i64 10 }, { 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 5 }, { ptr, i64 } { ptr @tn.str.336, i64 8 }, { ptr, i64 } { ptr @tn.str.337, i64 6 }, { ptr, i64 } { ptr @tn.str.338, i64 8 }, { ptr, i64 } { ptr @tn.str.339, i64 10 }, { ptr, i64 } { ptr @tn.str.340, i64 13 }, { ptr, i64 } { ptr @tn.str.341, i64 7 }, { ptr, i64 } { ptr @tn.str.342, i64 6 }, { ptr, i64 } { ptr @tn.str.343, i64 8 }, { ptr, i64 } { ptr @tn.str.344, i64 5 }, { ptr, i64 } { ptr @tn.str.345, i64 8 }, { ptr, i64 } { ptr @tn.str.346, i64 7 }, { ptr, i64 } { ptr @tn.str.347, i64 8 }, { ptr, i64 } { ptr @tn.str.348, i64 8 }, { ptr, i64 } { ptr @tn.str.349, i64 6 }, { ptr, i64 } { ptr @tn.str.350, i64 8 }, { ptr, i64 } { ptr @tn.str.351, i64 15 }, { ptr, i64 } { ptr @tn.str.352, i64 8 }] @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 [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 [1 x i8] zeroinitializer, align 1 +@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 [15 x i8] c"result := \22\22; \00", align 1 +@str.360 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.361 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.362 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.363 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.364 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.365 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.366 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.367 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.368 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.369 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.370 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.371 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.372 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.373 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.374 = private unnamed_addr constant [9 x i8] c"NSObject\00", align 1 +@str.375 = private unnamed_addr constant [14 x i8] c"SxTripleProbe\00", align 1 +@str.376 = private unnamed_addr constant [12 x i8] c"tripleValue\00", align 1 +@str.377 = private unnamed_addr constant [15 x i8] c"{Triple=qqq}@:\00", 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 [1 x i8] zeroinitializer, align 1 +@str.379 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.380 = private unnamed_addr constant [16 x i8] c"addMethod = {}\0A\00", 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 +@str.382 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.383 = private unnamed_addr constant [23 x i8] c"triple = ({}, {}, {})\0A\00", align 1 +@str.384 = private unnamed_addr constant [16 x i8] c"Source_Location\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 = private constant [5 x i8] c"file\00" -@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 }] +@fld.str.388 = private constant [5 x i8] c"line\00" +@fld.str.389 = private constant [4 x i8] c"col\00" +@fld.str.390 = 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.388, i64 4 }, { ptr, i64 } { ptr @fld.str.389, i64 3 }, { ptr, i64 } { ptr @fld.str.390, i64 4 }] +@str.391 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.392 = private unnamed_addr constant [10 x i8] c"Allocator\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"ctx\00" +@fld.str.397 = private constant [12 x i8] c"alloc_bytes\00" +@fld.str.398 = private constant [14 x i8] c"dealloc_bytes\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 11 }, { ptr, i64 } { ptr @fld.str.398, i64 13 }] +@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 [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 [8 x i8] c"Context\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 [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 +@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 [5 x i8] c"File\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 [3 x i8] c"fd\00" +@field_names.463 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.462, i64 2 }] +@str.464 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.465 = private unnamed_addr constant [11 x i8] c"TraceFrame\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 [5 x i8] c"file\00" +@fld.str.470 = private constant [5 x i8] c"line\00" +@fld.str.471 = private constant [4 x i8] c"col\00" +@fld.str.472 = private constant [5 x i8] c"func\00" +@fld.str.473 = private constant [10 x i8] c"line_text\00" +@field_names.474 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.469, i64 4 }, { ptr, i64 } { ptr @fld.str.470, i64 4 }, { ptr, i64 } { ptr @fld.str.471, i64 3 }, { ptr, i64 } { ptr @fld.str.472, i64 4 }, { ptr, i64 } { ptr @fld.str.473, i64 9 }] +@str.475 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.476 = private unnamed_addr constant [14 x i8] c"ProcessResult\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 [10 x i8] c"exit_code\00" +@fld.str.481 = private constant [7 x i8] c"stdout\00" +@field_names.482 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.480, i64 9 }, { ptr, i64 } { ptr @fld.str.481, i64 6 }] +@str.483 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.484 = private unnamed_addr constant [9 x i8] c"SockAddr\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 [8 x i8] c"sin_len\00" +@fld.str.489 = private constant [11 x i8] c"sin_family\00" +@fld.str.490 = private constant [9 x i8] c"sin_port\00" +@fld.str.491 = private constant [9 x i8] c"sin_addr\00" +@fld.str.492 = private constant [9 x i8] c"sin_zero\00" +@field_names.493 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.488, i64 7 }, { ptr, i64 } { ptr @fld.str.489, i64 10 }, { ptr, i64 } { ptr @fld.str.490, i64 8 }, { ptr, i64 } { ptr @fld.str.491, i64 8 }, { ptr, i64 } { ptr @fld.str.492, i64 8 }] +@str.494 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.495 = private unnamed_addr constant [6 x i8] c"Array\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 [6 x i8] c"items\00" +@fld.str.500 = private constant [4 x i8] c"len\00" +@fld.str.501 = private constant [4 x i8] c"cap\00" +@field_names.502 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.499, i64 5 }, { ptr, i64 } { ptr @fld.str.500, i64 3 }, { ptr, i64 } { ptr @fld.str.501, i64 3 }] +@str.503 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.504 = private unnamed_addr constant [7 x i8] c"Object\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"items\00" +@fld.str.509 = private constant [4 x i8] c"len\00" +@fld.str.510 = private constant [4 x i8] c"cap\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 3 }, { ptr, i64 } { ptr @fld.str.510, i64 3 }] +@str.512 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.513 = private unnamed_addr constant [7 x i8] c"Member\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"key\00" +@fld.str.518 = private constant [4 x i8] c"val\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 3 }] +@str.520 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.521 = private unnamed_addr constant [5 x i8] c"Sink\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"dst\00" +@fld.str.526 = private constant [4 x i8] c"pos\00" +@fld.str.527 = private constant [5 x i8] c"file\00" +@field_names.528 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.525, i64 3 }, { ptr, i64 } { ptr @fld.str.526, i64 3 }, { ptr, i64 } { ptr @fld.str.527, i64 4 }] +@str.529 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.530 = private unnamed_addr constant [7 x i8] c"Parser\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"src\00" +@fld.str.535 = private constant [4 x i8] c"pos\00" +@fld.str.536 = private constant [6 x i8] c"alloc\00" +@field_names.537 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.534, i64 3 }, { 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 [13 x i8] c"BuildOptions\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 +@field_names.543 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.544 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.545 = private unnamed_addr constant [9 x i8] c"FlagSpec\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 [5 x i8] c"name\00" +@fld.str.550 = private constant [12 x i8] c"takes_value\00" +@fld.str.551 = private constant [9 x i8] c"required\00" +@field_names.552 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.549, i64 4 }, { ptr, i64 } { ptr @fld.str.550, i64 11 }, { ptr, i64 } { ptr @fld.str.551, i64 8 }] +@str.553 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.554 = private unnamed_addr constant [8 x i8] c"Command\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 [6 x i8] c"group\00" +@fld.str.559 = private constant [8 x i8] c"command\00" +@fld.str.560 = private constant [6 x i8] c"flags\00" +@field_names.561 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.558, i64 5 }, { ptr, i64 } { ptr @fld.str.559, i64 7 }, { ptr, i64 } { ptr @fld.str.560, i64 5 }] +@str.562 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.563 = private unnamed_addr constant [10 x i8] c"FlagValue\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 +@str.566 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.567 = private constant [4 x i8] c"set\00" +@fld.str.568 = private constant [6 x i8] c"value\00" +@field_names.569 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.567, i64 3 }, { 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 [5 x i8] c"Diag\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 [6 x i8] c"index\00" +@fld.str.576 = private constant [6 x i8] c"token\00" +@field_names.577 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.575, i64 5 }, { 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 [7 x i8] c"Parsed\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"group\00" +@fld.str.584 = private constant [8 x i8] c"command\00" +@fld.str.585 = private constant [10 x i8] c"cmd_index\00" +@fld.str.586 = private constant [5 x i8] c"json\00" +@fld.str.587 = private constant [5 x i8] c"rest\00" +@fld.str.588 = private constant [5 x i8] c"spec\00" +@fld.str.589 = private constant [7 x i8] c"values\00" +@field_names.590 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.583, i64 5 }, { ptr, i64 } { ptr @fld.str.584, i64 7 }, { ptr, i64 } { ptr @fld.str.585, i64 9 }, { ptr, i64 } { ptr @fld.str.586, i64 4 }, { ptr, i64 } { ptr @fld.str.587, i64 4 }, { ptr, i64 } { ptr @fld.str.588, i64 4 }, { ptr, i64 } { ptr @fld.str.589, i64 6 }] +@str.591 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.592 = private unnamed_addr constant [7 x i8] c"Sha256\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 [2 x i8] c"h\00" +@fld.str.597 = private constant [4 x i8] c"buf\00" +@fld.str.598 = private constant [8 x i8] c"buf_len\00" +@fld.str.599 = private constant [10 x i8] c"total_len\00" +@field_names.600 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.596, i64 1 }, { ptr, i64 } { ptr @fld.str.597, i64 3 }, { ptr, i64 } { ptr @fld.str.598, i64 7 }, { ptr, i64 } { ptr @fld.str.599, i64 9 }] +@str.601 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.602 = private unnamed_addr constant [9 x i8] c"NSString\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 +@field_names.606 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.607 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.608 = private unnamed_addr constant [7 x i8] c"Triple\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 [2 x i8] c"a\00" +@fld.str.613 = private constant [2 x i8] c"b\00" +@fld.str.614 = private constant [2 x i8] c"c\00" +@field_names.615 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.612, i64 1 }, { ptr, i64 } { ptr @fld.str.613, i64 1 }, { ptr, i64 } { ptr @fld.str.614, i64 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 +@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 [10 x i8] c"*NSString\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 [6 x i8] c"*bool\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"*string\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"*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 [8 x i8] c"*[1]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 [7 x i8] c"*[]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 [8 x i8] c"*Triple\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"*[3]Any\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 [5 x i8] c"null\00", align 1 +@str.799 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.800 = 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 }] @@ -659,85 +659,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -880,7 +802,7 @@ entry: br i1 %icmp, label %if.then.56, label %if.merge.57 if.then.56: ; preds = %entry - ret { ptr, i64 } { ptr @str.164, i64 1 } + ret { ptr, i64 } { ptr @str.166, i64 1 } if.merge.57: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1007,7 +929,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.165, i64 4 }, %if.then.78 ], [ { ptr @str.166, i64 5 }, %if.else.79 ] + %bp = phi { ptr, i64 } [ { ptr @str.167, i64 4 }, %if.then.78 ], [ { ptr @str.168, i64 5 }, %if.else.79 ] ret { ptr, i64 } %bp } @@ -1341,7 +1263,7 @@ entry: br i1 %icmp, label %if.then.389, label %if.merge.390 if.then.389: ; preds = %entry - ret { ptr, i64 } { ptr @str.167, i64 1 } + ret { ptr, i64 } { ptr @str.169, i64 1 } if.merge.390: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 @@ -1491,7 +1413,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.168, i64 3 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.170, 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 @@ -1518,12 +1440,12 @@ 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 24, label %match.arm.43 + i64 26, label %match.arm.43 + i64 28, label %match.arm.43 i64 30, label %match.arm.43 - i64 32, label %match.arm.43 - i64 34, label %match.arm.43 + i64 33, label %match.arm.43 + i64 35, label %match.arm.43 i64 39, label %match.arm.43 i64 43, label %match.arm.43 i64 45, label %match.arm.43 @@ -1550,26 +1472,26 @@ entry: i64 51, label %match.arm.45 i64 64, label %match.arm.45 i64 75, label %match.arm.45 - i64 35, label %match.arm.47 + i64 22, label %match.arm.47 i64 81, label %match.arm.47 i64 87, label %match.arm.47 i64 88, label %match.arm.47 i64 92, label %match.arm.47 i64 103, label %match.arm.47 i64 107, label %match.arm.47 - i64 36, label %match.arm.48 + i64 23, label %match.arm.48 i64 60, label %match.arm.48 i64 77, label %match.arm.48 i64 85, label %match.arm.48 i64 101, 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 28, label %match.arm.49 + i64 25, label %match.arm.49 + i64 27, label %match.arm.49 i64 29, label %match.arm.49 i64 31, label %match.arm.49 - i64 33, label %match.arm.49 + i64 32, label %match.arm.49 + i64 34, label %match.arm.49 + i64 36, label %match.arm.49 i64 40, label %match.arm.49 i64 44, label %match.arm.49 i64 47, label %match.arm.49 @@ -1607,7 +1529,7 @@ match.merge.37: ; preds = %dispatch.merge.498, ret { ptr, i64 } %loadN match.arm.38: ; preds = %entry - store { ptr, i64 } { ptr @str.169, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.171, 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 @@ -1652,12 +1574,12 @@ 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 24, label %dispatch.case.99 + i64 26, label %dispatch.case.100 + i64 28, label %dispatch.case.101 i64 30, label %dispatch.case.102 - i64 32, label %dispatch.case.103 - i64 34, label %dispatch.case.104 + i64 33, label %dispatch.case.103 + i64 35, label %dispatch.case.104 i64 39, label %dispatch.case.105 i64 43, label %dispatch.case.106 i64 45, label %dispatch.case.107 @@ -1710,7 +1632,7 @@ match.arm.47: ; preds = %entry, %entry, %ent %ua.raw29 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw29, label %dispatch.default.276 [ - i64 35, label %dispatch.case.277 + i64 22, label %dispatch.case.277 i64 81, label %dispatch.case.278 i64 87, label %dispatch.case.279 i64 88, label %dispatch.case.280 @@ -1724,7 +1646,7 @@ match.arm.48: ; preds = %entry, %entry, %ent %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 switch i64 %ua.raw33, label %dispatch.default.320 [ - i64 36, label %dispatch.case.321 + i64 23, label %dispatch.case.321 i64 60, label %dispatch.case.322 i64 77, label %dispatch.case.323 i64 85, label %dispatch.case.324 @@ -1737,13 +1659,13 @@ 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 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 - i64 33, label %dispatch.case.360 + i64 25, label %dispatch.case.354 + i64 27, label %dispatch.case.355 + i64 29, label %dispatch.case.356 + i64 31, label %dispatch.case.357 + i64 32, label %dispatch.case.358 + i64 34, label %dispatch.case.359 + i64 36, label %dispatch.case.360 i64 40, label %dispatch.case.361 i64 44, label %dispatch.case.362 i64 47, label %dispatch.case.363 @@ -1839,7 +1761,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.351, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.353, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.96: ; preds = %match.arm.43 @@ -1861,56 +1783,56 @@ 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 }, ptr %ua.ptr69, align 8 + %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, 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, i64, { ptr, ptr, ptr } }, ptr %ua.ptr81, align 8 - %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { 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 dispatch.case.102: ; preds = %match.arm.43 %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr85 = inttoptr i64 %ua.raw84 to ptr - %ua.load86 = load { ptr, i64, i64 }, ptr %ua.ptr85, align 8 - %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load86) + %ua.load86 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr85, align 8 + %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load86) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.103: ; preds = %match.arm.43 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr - %ua.load90 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr89, align 8 - %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load90) + %ua.load90 = load { ptr, i64, i64 }, ptr %ua.ptr89, align 8 + %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 dispatch.case.104: ; preds = %match.arm.43 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr - %ua.load94 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr93, align 8 - %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load94) + %ua.load94 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr93, align 8 + %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.94 @@ -2064,7 +1986,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.352, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.354, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.258 dispatch.case.260: ; preds = %match.arm.44 @@ -2105,7 +2027,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.353, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.355, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.275 dispatch.case.277: ; preds = %match.arm.47 @@ -2170,7 +2092,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.354, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.356, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.319 dispatch.case.321: ; preds = %match.arm.48 @@ -2219,7 +2141,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.355, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.357, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.351 dispatch.case.353: ; preds = %match.arm.49 @@ -2459,7 +2381,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.356, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.358, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.498 dispatch.case.500: ; preds = %match.arm.50 @@ -2501,7 +2423,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.357, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.359, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2597,7 +2519,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.358, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.360, 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 @@ -2605,7 +2527,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.359, 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 i64, ptr %allocaN, align 8 @@ -2615,13 +2537,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.360, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.362, 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.361, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.363, 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 @@ -2629,7 +2551,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.362, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.364, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -2643,7 +2565,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.363, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.365, 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 @@ -2651,7 +2573,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.364, i64 2 }) + %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 %allocaN, align 8 @@ -2662,7 +2584,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.365, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.367, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2719,7 +2641,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.366, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.368, 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 @@ -2727,7 +2649,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.367, 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 i64, ptr %allocaN, align 8 @@ -2738,7 +2660,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.368, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.370, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -2758,7 +2680,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.369, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.371, 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 @@ -2766,7 +2688,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.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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -2777,7 +2699,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.371, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.373, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -2787,67 +2709,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -3023,166 +3029,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -3380,64 +3386,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -3467,97 +3473,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -3596,118 +3602,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.128(i64, ptr) #0 +declare void @BuildOptions.add_framework.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.129(i64, ptr) #0 +declare void @BuildOptions.set_output_path.131(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.132(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.133(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.132(i64) #0 +declare i64 @BuildOptions.asset_dir_count.134(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.135(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.136(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.137(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.138(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.137(i64) #0 +declare ptr @BuildOptions.binary_path.139(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.141(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.142(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.143(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.142(i64) #0 +declare ptr @BuildOptions.bundle_path.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.143(i64) #0 +declare ptr @BuildOptions.bundle_id.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.144(i64) #0 +declare ptr @BuildOptions.codesign_identity.146(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.145(i64) #0 +declare ptr @BuildOptions.provisioning_profile.147(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.146(i64) #0 +declare ptr @BuildOptions.target_triple.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.147(i64) #0 +declare i1 @BuildOptions.is_macos.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.148(i64) #0 +declare i1 @BuildOptions.is_ios.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.149(i64) #0 +declare i1 @BuildOptions.is_ios_device.151(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.152(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.151(i64) #0 +declare i1 @BuildOptions.is_android.153(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.152(i64) #0 +declare i64 @BuildOptions.framework_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.154(i64) #0 +declare i64 @BuildOptions.framework_path_count.156(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.157(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.158(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.159(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.158(i64) #0 +declare ptr @BuildOptions.manifest_path.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.159(i64) #0 +declare ptr @BuildOptions.keystore_path.161(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.160(i64) #0 +declare i64 @BuildOptions.jni_main_count.162(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.163(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.164(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.163() #0 +declare i64 @build_options.165() #0 ; Function Attrs: nounwind declare ptr @objc_getClass(ptr) #0 @@ -3775,19 +3781,19 @@ entry: define i32 @main() #0 { entry: call void @__sx_objc_selector_init() - %call = call ptr @objc_getClass(ptr @str.372) + %call = call ptr @objc_getClass(ptr @str.374) %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.373, i64 0) + %callN = call ptr @objc_allocateClassPair(ptr %load, ptr @str.375, i64 0) %allocaN = alloca ptr, align 8 store ptr %callN, ptr %allocaN, align 8 - %callN = call ptr @sel_registerName(ptr @str.374) + %callN = call ptr @sel_registerName(ptr @str.376) %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.375) + %callN = call i1 @class_addMethod(ptr %loadN, ptr %loadN, ptr @triple_imp, ptr @str.377) %allocaN = alloca i1, align 1 store i1 %callN, ptr %allocaN, align 1 %loadN = load i1, ptr %allocaN, align 1 @@ -3833,7 +3839,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.376, i64 15 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.378, 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 @@ -3849,7 +3855,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 12) @@ -3877,7 +3883,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.378, i64 15 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.380, i64 15 }) ret { ptr, i64 } %call } @@ -3885,7 +3891,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.379, i64 22 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.381, i64 22 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -3912,7 +3918,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.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 10) @@ -3961,7 +3967,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.381, i64 22 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.383, i64 22 }) ret { ptr, i64 } %call } @@ -3972,7 +3978,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.382, i64 15 }, { ptr, i64 } { ptr @str.383, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.384, i64 15 }, { 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 @@ -3991,12 +3997,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.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.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.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.127 @@ -4008,7 +4014,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.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 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4065,7 +4071,7 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt 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.390, i64 9 }, { ptr, i64 } { ptr @str.391, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.392, i64 9 }, { 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 @@ -4084,24 +4090,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.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.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.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.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 [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, ptr, ptr }, ptr %alloca, align 8 @@ -4145,20 +4151,21 @@ fv.case21: ; 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__Context(ptr %0, { { ptr, 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.399, i64 10 }, { ptr, i64 } { ptr @str.400, i64 1 }) + %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 }) %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, 2 br i1 %icmp, label %while.body.134, label %while.exit.135 while.body.134: ; preds = %while.hdr.133 @@ -4168,24 +4175,102 @@ 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.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.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 }) + %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.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.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.404, 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 }, 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.133 + +fv.default: ; preds = %if.merge.137 + br label %fv.merge + +fv.case: ; preds = %if.merge.137 + %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 20, i64 undef }, i64 %ba.p2i, 1 + br label %fv.merge + +fv.case17: ; preds = %if.merge.137 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 + %pNi = ptrtoint ptr %fv.field18 to i64 + %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + br label %fv.merge +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__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.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.411, 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.412, 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.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 @@ -4196,7 +4281,7 @@ if.merge.137: ; preds = %if.then.136, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.133 + br label %while.hdr.138 } ; Function Attrs: nounwind @@ -4204,43 +4289,43 @@ 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 }) + %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.138 + br label %while.hdr.143 -while.hdr.138: ; preds = %fv.merge, %entry +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.139, label %while.exit.140 + br i1 %icmp, label %while.body.144, label %while.exit.145 -while.body.139: ; preds = %while.hdr.138 +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.141, label %if.merge.142 + br i1 %icmpN, label %if.then.146, label %if.merge.147 -while.exit.140: ; preds = %while.hdr.138 +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.407, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.417, i64 1 }) ret { ptr, i64 } %callN -if.then.141: ; preds = %while.body.139 +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.408, 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 - br label %if.merge.142 + br label %if.merge.147 -if.merge.142: ; preds = %if.then.141, %while.body.139 +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.410, i64 0, i64 %loadN + %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.411, 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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64 }, ptr %alloca, align 8 @@ -4257,12 +4342,12 @@ 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 + br label %while.hdr.143 -fv.default: ; preds = %if.merge.142 +fv.default: ; preds = %if.merge.147 br label %fv.merge -fv.case: ; preds = %if.merge.142 +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 @@ -4273,43 +4358,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } 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 }) + %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.143 + br label %while.hdr.148 -while.hdr.143: ; preds = %fv.merge, %entry +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.144, label %while.exit.145 + br i1 %icmp, label %while.body.149, label %while.exit.150 -while.body.144: ; preds = %while.hdr.143 +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.146, label %if.merge.147 + br i1 %icmpN, label %if.then.151, label %if.merge.152 -while.exit.145: ; preds = %while.hdr.143 +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.414, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.424, i64 1 }) ret { ptr, i64 } %callN -if.then.146: ; preds = %while.body.144 +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.415, 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 - br label %if.merge.147 + br label %if.merge.152 -if.merge.147: ; preds = %if.then.146, %while.body.144 +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.418, i64 0, i64 %loadN + %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.419, 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 }, ptr %alloca, align 8 @@ -4327,18 +4412,18 @@ 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.143 + br label %while.hdr.148 -fv.default: ; preds = %if.merge.147 +fv.default: ; preds = %if.merge.152 br label %fv.merge -fv.case: ; preds = %if.merge.147 +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 26, i64 undef }, i64 %pNi, 1 + %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.147 +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 @@ -4350,91 +4435,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.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 - 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.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.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.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.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 - %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %fv.default [ - i64 0, label %fv.case - i64 1, label %fv.case17 - i64 2, label %fv.case20 - ] - -fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] - %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - %loadN = load i64, ptr %allocaN, align 8 - %add = add i64 %loadN, 1 - store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.148 - -fv.default: ; preds = %if.merge.152 - br label %fv.merge - -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 26, i64 undef }, i64 %pNi, 1 - br label %fv.merge - -fv.case17: ; preds = %if.merge.152 - %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 - %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 - br label %fv.merge - -fv.case20: ; preds = %if.merge.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 20, i64 undef }, i64 %ba.p2i, 1 - br label %fv.merge -} - -; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { -entry: - %alloca = alloca { ptr, i64, i64 }, align 8 - store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.429, i64 8 }, { ptr, i64 } { ptr @str.430, 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 @@ -4453,27 +4454,27 @@ 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.431, 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.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.432, 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.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.436, 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.437, 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, i64 }, ptr %alloca, align 8 + %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case @@ -4495,29 +4496,30 @@ fv.default: ; preds = %if.merge.157 br label %fv.merge fv.case: ; preds = %if.merge.157 - %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.157 - %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.157 - %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 - %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { +define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 { 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.438, i64 17 }, { ptr, i64 } { ptr @str.439, i64 1 }) + %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.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 @@ -4526,7 +4528,7 @@ entry: while.hdr.158: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 4 + %icmp = icmp slt i64 %load, 3 br i1 %icmp, label %while.body.159, label %while.exit.160 while.body.159: ; preds = %while.hdr.158 @@ -4536,19 +4538,19 @@ 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.440, 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.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.441, 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.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.446, 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 @@ -4556,17 +4558,16 @@ if.merge.162: ; preds = %if.then.161, %while %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 + %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 i64 2, label %fv.case20 - i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4579,35 +4580,29 @@ fv.default: ; preds = %if.merge.162 br label %fv.merge 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 20, i64 undef }, i64 %ba.p2i, 1 + %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 + %pNi = ptrtoint ptr %fv.field to i64 + %fv.val = insertvalue { i64, i64 } { i64 32, i64 undef }, i64 %pNi, 1 br label %fv.merge fv.case17: ; preds = %if.merge.162 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge fv.case20: ; preds = %if.merge.162 - %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge - -fv.case23: ; preds = %if.merge.162 - %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 - %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 - br label %fv.merge } ; Function Attrs: nounwind -define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 { +define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 { entry: - %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 + %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, 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.448, i64 7 }, { ptr, i64 } { ptr @str.449, i64 1 }) + store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 + %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 @@ -4616,7 +4611,7 @@ entry: while.hdr.163: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 - %icmp = icmp slt i64 %load, 2 + %icmp = icmp slt i64 %load, 4 br i1 %icmp, label %while.body.164, label %while.exit.165 while.body.164: ; preds = %while.hdr.163 @@ -4638,23 +4633,25 @@ if.then.166: ; preds = %while.body.164 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.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 }, ptr }, ptr %alloca, align 8 + %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 switch i64 %loadN, label %fv.default [ i64 0, label %fv.case i64 1, label %fv.case17 + i64 2, label %fv.case20 + i64 3, label %fv.case23 ] -fv.merge: ; preds = %fv.default, %fv.case17, %fv.case - %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ] +fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case + %fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ] %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 @@ -4667,16 +4664,25 @@ fv.default: ; preds = %if.merge.167 br label %fv.merge fv.case: ; preds = %if.merge.167 - %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 + %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 20, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge fv.case17: ; preds = %if.merge.167 - %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 - %pNi = ptrtoint ptr %fv.field18 to i64 - %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 + %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 + %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 + br label %fv.merge + +fv.case20: ; preds = %if.merge.167 + %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 + %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 + br label %fv.merge + +fv.case23: ; preds = %if.merge.167 + %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 + %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge } @@ -4685,7 +4691,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.456, i64 4 }, { ptr, i64 } { ptr @str.457, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.458, i64 4 }, { 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 @@ -4704,24 +4710,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.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.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.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.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.461, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 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 { i32 }, ptr %alloca, align 4 @@ -4758,7 +4764,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.463, i64 10 }, { ptr, i64 } { ptr @str.464, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.465, i64 10 }, { 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 @@ -4777,24 +4783,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.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.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.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.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.472, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.474, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -4860,7 +4866,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.474, i64 13 }, { ptr, i64 } { ptr @str.475, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.476, i64 13 }, { ptr, i64 } { ptr @str.477, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -4879,24 +4885,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.476, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.478, 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.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 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.480, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i32, { ptr, i64 } }, ptr %alloca, align 8 @@ -4938,7 +4944,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.482, i64 8 }, { ptr, i64 } { ptr @str.483, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.484, i64 8 }, { 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 @@ -4957,24 +4963,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.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.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.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.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.491, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 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 { i8, i8, i16, i32, i64 }, ptr %alloca, align 8 @@ -5035,7 +5041,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.493, i64 5 }, { ptr, i64 } { ptr @str.494, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.495, i64 5 }, { 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 @@ -5054,24 +5060,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.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.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.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.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.500, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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, i64, i64 }, ptr %alloca, align 8 @@ -5117,7 +5123,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.502, i64 6 }, { ptr, i64 } { ptr @str.503, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.504, i64 6 }, { 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 @@ -5136,24 +5142,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.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.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.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.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.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, i64 }, ptr %alloca, align 8 @@ -5201,7 +5207,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.511, i64 6 }, { ptr, i64 } { ptr @str.512, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.513, i64 6 }, { 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 @@ -5220,24 +5226,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.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.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.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.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.517, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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, [24 x i8] } }, ptr %alloca, align 8 @@ -5281,7 +5287,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.519, i64 4 }, { ptr, i64 } { ptr @str.520, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.521, i64 4 }, { 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 @@ -5300,24 +5306,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.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.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.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.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.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 }, i64, ptr }, ptr %alloca, align 8 @@ -5367,7 +5373,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.528, i64 6 }, { ptr, i64 } { ptr @str.529, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.530, i64 6 }, { 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 @@ -5386,24 +5392,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.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.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.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.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.535, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 }, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -5452,7 +5458,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.537, i64 12 }, { ptr, i64 } { ptr @str.538, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.539, i64 12 }, { 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 @@ -5471,24 +5477,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.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.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.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.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.541, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 %alloca, align 1 @@ -5508,7 +5514,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.543, i64 8 }, { ptr, i64 } { ptr @str.544, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.545, i64 8 }, { 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 @@ -5527,24 +5533,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.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.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.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.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.550, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 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 { { ptr, i64 }, i1, i1 }, ptr %alloca, align 8 @@ -5596,7 +5602,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.552, i64 7 }, { ptr, i64 } { ptr @str.553, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.554, i64 7 }, { 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 @@ -5615,24 +5621,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.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.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.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.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.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 { { ptr, i64 }, { ptr, i64 }, { ptr, i64 } }, ptr %alloca, align 8 @@ -5684,7 +5690,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.561, i64 9 }, { ptr, i64 } { ptr @str.562, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.563, i64 9 }, { ptr, i64 } { ptr @str.564, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -5703,24 +5709,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.563, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.565, 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.564, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.566, 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.567, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 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 { i1, { ptr, i64 } }, ptr %alloca, align 8 @@ -5763,7 +5769,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.569, i64 4 }, { ptr, i64 } { ptr @str.570, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.571, i64 4 }, { 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 @@ -5782,24 +5788,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.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.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.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.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.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 { i64, { ptr, i64 } }, ptr %alloca, align 8 @@ -5845,7 +5851,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.577, i64 6 }, { ptr, i64 } { ptr @str.578, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.579, i64 6 }, { 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 @@ -5864,24 +5870,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.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.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.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.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.588, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 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, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] }, ptr %alloca, align 8 @@ -5938,7 +5944,7 @@ fv.case28: ; preds = %if.merge.242 %fv.field29 = extractvalue { { ptr, i64 }, { ptr, i64 }, i64, i1, { ptr, i64 }, { ptr, i64 }, [16 x { i1, { ptr, i64 } }] } %loadN, 4 store { ptr, i64 } %fv.field29, ptr %ba.tmp30, align 8 %ba.p2i31 = ptrtoint ptr %ba.tmp30 to i64 - %fv.val32 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i31, 1 + %fv.val32 = insertvalue { i64, i64 } { i64 23, i64 undef }, i64 %ba.p2i31, 1 br label %fv.merge fv.case33: ; preds = %if.merge.242 @@ -5963,7 +5969,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.590, i64 6 }, { ptr, i64 } { ptr @str.591, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.592, i64 6 }, { 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 @@ -5982,24 +5988,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.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.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.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.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.598, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.600, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { [8 x i64], [64 x i8], i64, i64 }, ptr %alloca, align 8 @@ -6054,7 +6060,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.600, i64 8 }, { ptr, i64 } { ptr @str.601, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.602, i64 8 }, { ptr, i64 } { ptr @str.603, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -6073,24 +6079,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.602, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.604, 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.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.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.604, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 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 {}, ptr %alloca, align 1 @@ -6109,7 +6115,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.606, i64 6 }, { ptr, i64 } { ptr @str.607, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.608, i64 6 }, { 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 @@ -6128,24 +6134,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.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.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.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.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.613, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.615, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, ptr %allocaN, align 8 %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 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, i64, i64 }, ptr %alloca, align 8 @@ -6194,9 +6200,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.620, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.622, 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.615, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.617, 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 @@ -6215,8 +6221,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.266 @@ -6235,9 +6241,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.627, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.629, 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.623, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.625, 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 @@ -6256,8 +6262,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.268 @@ -6287,9 +6293,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.637, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [6 x { ptr, i64 }], ptr @field_names.639, 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, [24 x i8] }, ptr %alloca, align 8 @@ -6306,8 +6312,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.270 @@ -6385,9 +6391,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.648, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.650, 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.640, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.642, 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 @@ -6406,8 +6412,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.272 @@ -6426,9 +6432,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.657, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.659, 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 @@ -6447,8 +6453,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.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 } { 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 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.274 @@ -6465,7 +6471,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.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.284 @@ -6482,12 +6488,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.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.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.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.288 @@ -6516,7 +6522,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.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.289 @@ -6533,12 +6539,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.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.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.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.293 @@ -6568,7 +6574,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.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.294 @@ -6585,12 +6591,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.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.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.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.298 @@ -6618,7 +6624,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.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.299 @@ -6635,12 +6641,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.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.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.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.303 @@ -6669,7 +6675,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.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.304 @@ -6686,12 +6692,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.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.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.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.308 @@ -6720,7 +6726,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.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.309 @@ -6737,12 +6743,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.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.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.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.313 @@ -6773,7 +6779,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.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.314 @@ -6790,12 +6796,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.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.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.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.318 @@ -6825,7 +6831,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.326 @@ -6844,12 +6850,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.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.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.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.330 @@ -6878,7 +6884,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.331 @@ -6897,12 +6903,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.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.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.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.335 @@ -6931,7 +6937,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.336 @@ -6950,12 +6956,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.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.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.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.340 @@ -6985,7 +6991,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.341 @@ -7004,12 +7010,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.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.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.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.345 @@ -7039,7 +7045,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.346 @@ -7058,12 +7064,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.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.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.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.350 @@ -7105,12 +7111,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.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.388 if.merge.388: ; preds = %if.else.387, %if.then.386 - %bp = phi { ptr, i64 } [ { ptr @str.696, i64 4 }, %if.then.386 ], [ %callN, %if.else.387 ] + %bp = phi { ptr, i64 } [ { ptr @str.698, i64 4 }, %if.then.386 ], [ %callN, %if.else.387 ] ret { ptr, i64 } %bp } @@ -7133,12 +7139,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.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.404 if.merge.404: ; preds = %if.else.403, %if.then.402 - %bp = phi { ptr, i64 } [ { ptr @str.699, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] + %bp = phi { ptr, i64 } [ { ptr @str.701, i64 4 }, %if.then.402 ], [ %callN, %if.else.403 ] ret { ptr, i64 } %bp } @@ -7161,12 +7167,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.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.407 if.merge.407: ; preds = %if.else.406, %if.then.405 - %bp = phi { ptr, i64 } [ { ptr @str.702, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] + %bp = phi { ptr, i64 } [ { ptr @str.704, i64 4 }, %if.then.405 ], [ %callN, %if.else.406 ] ret { ptr, i64 } %bp } @@ -7189,12 +7195,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.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.410 if.merge.410: ; preds = %if.else.409, %if.then.408 - %bp = phi { ptr, i64 } [ { ptr @str.705, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] + %bp = phi { ptr, i64 } [ { ptr @str.707, i64 4 }, %if.then.408 ], [ %callN, %if.else.409 ] ret { ptr, i64 } %bp } @@ -7217,12 +7223,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.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.413 if.merge.413: ; preds = %if.else.412, %if.then.411 - %bp = phi { ptr, i64 } [ { ptr @str.708, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] + %bp = phi { ptr, i64 } [ { ptr @str.710, i64 4 }, %if.then.411 ], [ %callN, %if.else.412 ] ret { ptr, i64 } %bp } @@ -7244,12 +7250,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.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.416 if.merge.416: ; preds = %if.else.415, %if.then.414 - %bp = phi { ptr, i64 } [ { ptr @str.711, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] + %bp = phi { ptr, i64 } [ { ptr @str.713, i64 4 }, %if.then.414 ], [ %callN, %if.else.415 ] ret { ptr, i64 } %bp } @@ -7272,12 +7278,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 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.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 } @@ -7300,12 +7306,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 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.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 } @@ -7328,12 +7334,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 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.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 } @@ -7356,12 +7362,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 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.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 } @@ -7384,12 +7390,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 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.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 } @@ -7412,12 +7418,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 } @@ -7440,12 +7446,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 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.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 } @@ -7467,12 +7473,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 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.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 } @@ -7495,12 +7501,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 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.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 } @@ -7522,12 +7528,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 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.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 } @@ -7550,12 +7556,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 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.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 } @@ -7578,12 +7584,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 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.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 } @@ -7606,12 +7612,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 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.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 } @@ -7634,12 +7640,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 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.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 } @@ -7662,12 +7668,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 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.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 } @@ -7690,12 +7696,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 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.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 } @@ -7718,12 +7724,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 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.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 } @@ -7746,12 +7752,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 9 }, { 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 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.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 } @@ -7774,12 +7780,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 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.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 } @@ -7802,12 +7808,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 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.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 } @@ -7830,12 +7836,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 } @@ -7858,12 +7864,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 } @@ -7886,12 +7892,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 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.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 } @@ -7914,12 +7920,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 7 }, { 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 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.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 } @@ -7942,12 +7948,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 } @@ -7970,12 +7976,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 7 }, { 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 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.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 } @@ -7998,12 +8004,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 } @@ -8019,7 +8025,7 @@ entry: br i1 %lnot, label %if.then.504, label %if.merge.505 if.then.504: ; preds = %entry - ret { ptr, i64 } { ptr @str.795, i64 4 } + ret { ptr, i64 } { ptr @str.797, i64 4 } if.merge.505: ; preds = %entry %loadN = load { { i32 }, i1 }, ptr %alloca, align 4 @@ -8043,7 +8049,7 @@ entry: br i1 %lnot, label %if.then.506, label %if.merge.507 if.then.506: ; preds = %entry - ret { ptr, i64 } { ptr @str.796, i64 4 } + ret { ptr, i64 } { ptr @str.798, i64 4 } if.merge.507: ; preds = %entry %loadN = load { { ptr, i64 }, i1 }, ptr %alloca, align 8 @@ -8067,7 +8073,7 @@ entry: br i1 %lnot, label %if.then.508, label %if.merge.509 if.then.508: ; preds = %entry - ret { ptr, i64 } { ptr @str.797, i64 4 } + ret { ptr, i64 } { ptr @str.799, i64 4 } if.merge.509: ; preds = %entry %loadN = load { { i32, { ptr, i64 } }, i1 }, ptr %alloca, align 8 @@ -8091,7 +8097,7 @@ entry: br i1 %lnot, label %if.then.510, label %if.merge.511 if.then.510: ; preds = %entry - ret { ptr, i64 } { ptr @str.798, i64 4 } + ret { ptr, i64 } { ptr @str.800, 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 75f4679..54d7c1b 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.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.166 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.167 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.168 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.169 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.170 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.171 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.172 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.173 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.174 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.175 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.176 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.177 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.178 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.179 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.180 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.181 = private unnamed_addr constant [9 x i8] c"NSObject\00", align 1 +@str.182 = private unnamed_addr constant [16 x i8] c"SxManglingProbe\00", align 1 +@str.183 = private unnamed_addr constant [7 x i8] c"length\00", align 1 +@str.184 = private unnamed_addr constant [4 x i8] c"i@:\00", align 1 +@str.185 = private unnamed_addr constant [11 x i8] c"addObject:\00", align 1 +@str.186 = private unnamed_addr constant [5 x i8] c"i@:i\00", align 1 +@str.187 = private unnamed_addr constant [13 x i8] c"combine:and:\00", align 1 +@str.188 = private unnamed_addr constant [6 x i8] c"i@:ii\00", align 1 +@str.189 = private unnamed_addr constant [20 x i8] c"insert:after:index:\00", align 1 +@str.190 = private unnamed_addr constant [7 x i8] c"i@:iii\00", align 1 +@str.191 = private unnamed_addr constant [24 x i8] c"add:observer:for:event:\00", align 1 +@str.192 = private unnamed_addr constant [8 x i8] c"i@:iiii\00", align 1 +@str.193 = private unnamed_addr constant [23 x i8] c"initWithFrame:options:\00", align 1 +@str.194 = private unnamed_addr constant [6 x i8] c"i@:ii\00", align 1 +@str.195 = private unnamed_addr constant [19 x i8] c"actualSelectorName\00", align 1 +@str.196 = private unnamed_addr constant [4 x i8] c"i@:\00", align 1 @str.197 = private unnamed_addr constant [19 x i8] c"mangling table OK\0A\00", align 1 +@str.198 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.199 = 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_.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" +@OBJC_METH_VAR_NAME_.200 = private unnamed_addr constant [11 x i8] c"addObject:\00" +@OBJC_METH_VAR_NAME_.201 = private unnamed_addr constant [13 x i8] c"combine:and:\00" +@OBJC_METH_VAR_NAME_.202 = private unnamed_addr constant [20 x i8] c"insert:after:index:\00" +@OBJC_METH_VAR_NAME_.203 = private unnamed_addr constant [24 x i8] c"add:observer:for:event:\00" +@OBJC_METH_VAR_NAME_.204 = private unnamed_addr constant [23 x i8] c"initWithFrame:options:\00" +@OBJC_METH_VAR_NAME_.205 = 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 @@ -63,85 +63,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -357,7 +279,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.164, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.166, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -453,7 +375,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.165, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, 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 @@ -461,7 +383,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.166, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -471,13 +393,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.167, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.169, 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.168, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.170, 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 @@ -485,7 +407,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.169, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.171, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -499,7 +421,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.170, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, 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 @@ -507,7 +429,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.171, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -518,7 +440,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.172, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.174, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -575,7 +497,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.173, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, 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 @@ -583,7 +505,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.174, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, 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 @@ -594,7 +516,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.175, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.177, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -614,7 +536,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.176, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.178, 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 @@ -622,7 +544,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.177, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.179, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -633,7 +555,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.178, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.180, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.36 @@ -643,67 +565,151 @@ if.merge.36: ; preds = %if.then.35, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -879,166 +885,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1236,64 +1242,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1323,97 +1329,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1452,118 +1458,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.128(i64, ptr) #0 +declare void @BuildOptions.add_framework.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.129(i64, ptr) #0 +declare void @BuildOptions.set_output_path.131(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.132(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.133(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.132(i64) #0 +declare i64 @BuildOptions.asset_dir_count.134(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.135(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.136(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.137(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.138(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.137(i64) #0 +declare ptr @BuildOptions.binary_path.139(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.141(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.142(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.143(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.142(i64) #0 +declare ptr @BuildOptions.bundle_path.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.143(i64) #0 +declare ptr @BuildOptions.bundle_id.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.144(i64) #0 +declare ptr @BuildOptions.codesign_identity.146(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.145(i64) #0 +declare ptr @BuildOptions.provisioning_profile.147(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.146(i64) #0 +declare ptr @BuildOptions.target_triple.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.147(i64) #0 +declare i1 @BuildOptions.is_macos.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.148(i64) #0 +declare i1 @BuildOptions.is_ios.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.149(i64) #0 +declare i1 @BuildOptions.is_ios_device.151(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.152(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.151(i64) #0 +declare i1 @BuildOptions.is_android.153(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.152(i64) #0 +declare i64 @BuildOptions.framework_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.154(i64) #0 +declare i64 @BuildOptions.framework_path_count.156(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.157(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.158(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.159(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.158(i64) #0 +declare ptr @BuildOptions.manifest_path.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.159(i64) #0 +declare ptr @BuildOptions.keystore_path.161(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.160(i64) #0 +declare i64 @BuildOptions.jni_main_count.162(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.163(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.164(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.163() #0 +declare i64 @build_options.165() #0 ; Function Attrs: nounwind declare ptr @objc_getClass(ptr) #0 @@ -1645,17 +1651,14 @@ entry: define i32 @main() #0 { entry: call void @__sx_objc_selector_init() - %call = call ptr @objc_getClass(ptr @str.179) + %call = call ptr @objc_getClass(ptr @str.181) %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.180, i64 0) + %callN = call ptr @objc_allocateClassPair(ptr %load, ptr @str.182, 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.181) - %callN = call i1 @class_addMethod(ptr %loadN, ptr %callN, ptr @universal_imp, ptr @str.182) - %loadN = load ptr, ptr %allocaN, align 8 %callN = call ptr @sel_registerName(ptr @str.183) %callN = call i1 @class_addMethod(ptr %loadN, ptr %callN, ptr @universal_imp, ptr @str.184) %loadN = load ptr, ptr %allocaN, align 8 @@ -1674,6 +1677,9 @@ entry: %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 + %callN = call ptr @sel_registerName(ptr @str.195) + %callN = call i1 @class_addMethod(ptr %loadN, ptr %callN, ptr @universal_imp, ptr @str.196) + %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 @@ -1722,14 +1728,14 @@ entry: define internal void @print__ct_s4c1a58a7c89bfbba__pack(ptr %0) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.195, i64 18 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.197, 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.196, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.198, 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) @@ -1745,7 +1751,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.197, i64 18 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.199, i64 18 }) ret { ptr, i64 } %call } @@ -1753,17 +1759,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_.198) - 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_combine_and_, align 8 %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.200) - 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_.201) - 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_.202) - 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_.203) + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_add_observer_for_event_, align 8 + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.204) + store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_initWithFrame_options_, align 8 + %selN = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_.205) 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 6911b02..edc15ce 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.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.129 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.130 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.131 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.132 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.133 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.134 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.135 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.136 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.137 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.138 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.139 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.140 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.141 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.142 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.143 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @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 +@SX_JNI_CLS_noop____V = internal global ptr null +@SX_JNI_MID_noop____V = internal global ptr null +@str.146 = private unnamed_addr constant [5 x i8] c"noop\00", align 1 +@str.147 = private unnamed_addr constant [4 x i8] c"()V\00", align 1 @str.148 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 +@str.149 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.150 = private unnamed_addr constant [4 x i8] c"ok\0A\00", align 1 ; Function Attrs: nounwind declare void @out(ptr) #0 @@ -39,85 +39,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -333,7 +255,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.127, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.129, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -429,7 +351,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.128, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, 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 @@ -437,7 +359,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.129, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, 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 @@ -447,13 +369,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.130, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, 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.131, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, 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 @@ -461,7 +383,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.132, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -475,7 +397,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.133, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, 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 @@ -483,7 +405,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.134, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, 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 @@ -494,7 +416,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.135, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -551,7 +473,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.136, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, 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 @@ -559,7 +481,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.137, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, 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 @@ -570,7 +492,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.138, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -590,7 +512,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.139, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, 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 @@ -598,7 +520,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.140, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.142, 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 @@ -609,7 +531,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.141, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.143, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -619,67 +541,151 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -855,166 +861,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1212,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.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1299,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.95(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.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1428,7 +1434,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal void @unused_jni(ptr %0, ptr %1, ptr %2) #0 { @@ -1456,7 +1462,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.142, ptr @str.143) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.144, ptr @str.145) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_noop____V, align 8 br label %jni.cont @@ -1481,7 +1487,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.144, ptr @str.145) + %jni.fresh.mid14 = call ptr %jni.GetMethodID13(ptr %load, ptr %jni.global.cls12, ptr @str.146, ptr @str.147) store ptr %jni.fresh.mid14, ptr @SX_JNI_MID_noop____V, align 8 br label %jni.cont8 @@ -1533,14 +1539,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.146, i64 3 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.148, 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.147, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.149, 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) @@ -1556,6 +1562,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.148, i64 3 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.150, 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 0ad0519..68e25f0 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.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 +@str.129 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.130 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.131 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.132 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.133 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.134 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.135 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.136 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.137 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.138 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.139 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.140 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.141 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.142 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.143 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.144 = private unnamed_addr constant [9 x i8] c"getCount\00", align 1 +@str.145 = 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.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 +@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 @@ -37,85 +37,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -331,7 +253,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.127, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.129, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -427,7 +349,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.128, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, 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 @@ -435,7 +357,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.129, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, 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 @@ -445,13 +367,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.130, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, 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.131, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, 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 @@ -459,7 +381,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.132, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -473,7 +395,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.133, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, 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 @@ -481,7 +403,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.134, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, 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 @@ -492,7 +414,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.135, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -549,7 +471,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.136, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, 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 @@ -557,7 +479,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.137, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, 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 @@ -568,7 +490,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.138, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -588,7 +510,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.139, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, 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 @@ -596,7 +518,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.140, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.142, 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 @@ -607,7 +529,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.141, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.143, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -617,67 +539,151 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -853,166 +859,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1210,64 +1216,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1297,97 +1303,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1426,7 +1432,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @read_int(ptr %0, ptr %1, ptr %2) #0 { @@ -1454,7 +1460,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.142, ptr @str.143) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.144, ptr @str.145) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_getCount____I, align 8 br label %jni.cont @@ -1508,14 +1514,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) @@ -1531,6 +1537,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/1404-ffi-jni-call-05-jlong-return.ir b/examples/expected/1404-ffi-jni-call-05-jlong-return.ir index 81b2e7c..e853b68 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.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 +@str.129 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.130 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.131 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.132 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.133 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.134 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.135 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.136 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.137 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.138 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.139 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.140 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.141 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.142 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.143 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.144 = private unnamed_addr constant [18 x i8] c"currentTimeMillis\00", align 1 +@str.145 = 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.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 +@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 @@ -37,85 +37,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -331,7 +253,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.127, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.129, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -427,7 +349,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.128, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, 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 @@ -435,7 +357,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.129, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, 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 @@ -445,13 +367,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.130, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, 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.131, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, 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 @@ -459,7 +381,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.132, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -473,7 +395,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.133, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, 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 @@ -481,7 +403,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.134, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, 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 @@ -492,7 +414,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.135, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -549,7 +471,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.136, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, 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 @@ -557,7 +479,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.137, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, 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 @@ -568,7 +490,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.138, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -588,7 +510,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.139, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, 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 @@ -596,7 +518,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.140, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.142, 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 @@ -607,7 +529,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.141, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.143, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -617,67 +539,151 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -853,166 +859,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1210,64 +1216,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1297,97 +1303,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1426,7 +1432,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i64 @read_long(ptr %0, ptr %1, ptr %2) #0 { @@ -1454,7 +1460,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.142, ptr @str.143) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.144, ptr @str.145) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_currentTimeMillis____J, align 8 br label %jni.cont @@ -1508,14 +1514,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) @@ -1531,6 +1537,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/1405-ffi-jni-call-06-jdouble-return.ir b/examples/expected/1405-ffi-jni-call-06-jdouble-return.ir index 1cbc6df..91b978d 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.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 +@str.129 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.130 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.131 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.132 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.133 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.134 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.135 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.136 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.137 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.138 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.139 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.140 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.141 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.142 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.143 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.144 = private unnamed_addr constant [9 x i8] c"getValue\00", align 1 +@str.145 = 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.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 +@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 @@ -37,85 +37,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -331,7 +253,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.127, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.129, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -427,7 +349,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.128, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, 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 @@ -435,7 +357,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.129, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, 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 @@ -445,13 +367,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.130, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, 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.131, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, 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 @@ -459,7 +381,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.132, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -473,7 +395,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.133, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, 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 @@ -481,7 +403,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.134, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, 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 @@ -492,7 +414,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.135, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -549,7 +471,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.136, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, 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 @@ -557,7 +479,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.137, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, 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 @@ -568,7 +490,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.138, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -588,7 +510,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.139, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, 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 @@ -596,7 +518,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.140, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.142, 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 @@ -607,7 +529,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.141, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.143, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -617,67 +539,151 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -853,166 +859,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1210,64 +1216,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1297,97 +1303,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1426,7 +1432,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal double @read_double(ptr %0, ptr %1, ptr %2) #0 { @@ -1454,7 +1460,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.142, ptr @str.143) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.144, ptr @str.145) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_getValue____D, align 8 br label %jni.cont @@ -1508,14 +1514,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) @@ -1531,6 +1537,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/1406-ffi-jni-call-07-jboolean-return.ir b/examples/expected/1406-ffi-jni-call-07-jboolean-return.ir index 2553d2d..62a8276 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.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 +@str.129 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.130 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.131 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.132 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.133 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.134 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.135 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.136 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.137 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.138 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.139 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.140 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.141 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.142 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.143 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.144 = private unnamed_addr constant [8 x i8] c"isShown\00", align 1 +@str.145 = 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.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 +@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 @@ -37,85 +37,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -331,7 +253,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.127, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.129, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -427,7 +349,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.128, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, 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 @@ -435,7 +357,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.129, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, 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 @@ -445,13 +367,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.130, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, 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.131, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, 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 @@ -459,7 +381,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.132, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -473,7 +395,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.133, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, 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 @@ -481,7 +403,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.134, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, 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 @@ -492,7 +414,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.135, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -549,7 +471,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.136, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, 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 @@ -557,7 +479,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.137, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, 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 @@ -568,7 +490,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.138, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -588,7 +510,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.139, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, 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 @@ -596,7 +518,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.140, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.142, 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 @@ -607,7 +529,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.141, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.143, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -617,67 +539,151 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -853,166 +859,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1210,64 +1216,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1297,97 +1303,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1426,7 +1432,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i1 @read_bool(ptr %0, ptr %1, ptr %2) #0 { @@ -1454,7 +1460,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.142, ptr @str.143) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.144, ptr @str.145) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_isShown____Z, align 8 br label %jni.cont @@ -1508,14 +1514,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) @@ -1531,6 +1537,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/1407-ffi-jni-call-08-jobject-return.ir b/examples/expected/1407-ffi-jni-call-08-jobject-return.ir index 31adf1a..7343fec 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.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 +@str.129 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.130 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.131 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.132 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.133 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.134 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.135 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.136 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.137 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.138 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.139 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.140 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.141 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.142 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.143 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.144 = private unnamed_addr constant [10 x i8] c"getWindow\00", align 1 +@str.145 = 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.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 +@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 @@ -37,85 +37,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -331,7 +253,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.127, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.129, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -427,7 +349,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.128, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, 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 @@ -435,7 +357,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.129, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, 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 @@ -445,13 +367,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.130, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, 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.131, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, 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 @@ -459,7 +381,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.132, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -473,7 +395,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.133, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, 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 @@ -481,7 +403,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.134, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, 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 @@ -492,7 +414,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.135, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -549,7 +471,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.136, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, 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 @@ -557,7 +479,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.137, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, 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 @@ -568,7 +490,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.138, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -588,7 +510,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.139, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, 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 @@ -596,7 +518,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.140, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.142, 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 @@ -607,7 +529,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.141, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.143, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -617,67 +539,151 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -853,166 +859,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1210,64 +1216,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1297,97 +1303,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1426,7 +1432,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal ptr @get_window(ptr %0, ptr %1, ptr %2) #0 { @@ -1454,7 +1460,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.142, ptr @str.143) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.144, ptr @str.145) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_getWindow____Landroid_view_Window_, align 8 br label %jni.cont @@ -1508,14 +1514,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) @@ -1531,6 +1537,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/1408-ffi-jni-call-09-static.ir b/examples/expected/1408-ffi-jni-call-09-static.ir index 6e0b0b6..37520c9 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.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 +@str.129 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.130 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.131 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.132 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.133 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.134 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.135 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.136 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.137 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.138 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.139 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.140 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.141 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.142 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.143 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.144 = private unnamed_addr constant [4 x i8] c"max\00", align 1 +@str.145 = 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.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 +@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 @@ -37,85 +37,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -331,7 +253,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.127, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.129, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -427,7 +349,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.128, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, 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 @@ -435,7 +357,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.129, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, 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 @@ -445,13 +367,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.130, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, 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.131, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, 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 @@ -459,7 +381,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.132, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -473,7 +395,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.133, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, 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 @@ -481,7 +403,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.134, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, 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 @@ -492,7 +414,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.135, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -549,7 +471,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.136, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, 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 @@ -557,7 +479,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.137, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, 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 @@ -568,7 +490,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.138, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -588,7 +510,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.139, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, 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 @@ -596,7 +518,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.140, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.142, 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 @@ -607,7 +529,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.141, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.143, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -617,67 +539,151 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -853,166 +859,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1210,64 +1216,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1297,97 +1303,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1426,7 +1432,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal i32 @call_static_max(ptr %0, ptr %1, ptr %2) #0 { @@ -1451,7 +1457,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.142, ptr @str.143) + %jni.fresh.mid = call ptr %jni.GetStaticMethodID(ptr %load, ptr %jni.global.cls, ptr @str.144, ptr @str.145) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_max___II_I, align 8 br label %jni.cont @@ -1505,14 +1511,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) @@ -1528,6 +1534,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/1418-ffi-jni-class-08-call.ir b/examples/expected/1418-ffi-jni-class-08-call.ir index 0b94c7d..a70bc62 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.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 +@str.129 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.130 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.131 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.132 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.133 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.134 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.135 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.136 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.137 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.138 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.139 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.140 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.141 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.142 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.143 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.144 = private unnamed_addr constant [10 x i8] c"getWindow\00", align 1 +@str.145 = 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.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 +@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 @@ -37,85 +37,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -331,7 +253,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.127, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.129, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -427,7 +349,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.128, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, 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 @@ -435,7 +357,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.129, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, 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 @@ -445,13 +367,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.130, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, 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.131, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, 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 @@ -459,7 +381,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.132, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -473,7 +395,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.133, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, 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 @@ -481,7 +403,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.134, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, 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 @@ -492,7 +414,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.135, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -549,7 +471,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.136, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, 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 @@ -557,7 +479,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.137, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, 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 @@ -568,7 +490,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.138, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -588,7 +510,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.139, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, 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 @@ -596,7 +518,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.140, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.142, 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 @@ -607,7 +529,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.141, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.143, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -617,67 +539,151 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -853,166 +859,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1210,64 +1216,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1297,97 +1303,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1426,7 +1432,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal void @unused_jni(ptr %0, ptr %1, ptr %2) #0 { @@ -1455,7 +1461,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.142, ptr @str.143) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.144, ptr @str.145) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_getWindow____Ljava_lang_Object_, align 8 br label %jni.cont @@ -1508,14 +1514,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) @@ -1531,6 +1537,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/1421-ffi-jni-env-02-lexical-direct.ir b/examples/expected/1421-ffi-jni-env-02-lexical-direct.ir index 8218107..6ce52fc 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.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.129 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.130 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.131 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.132 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.133 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.134 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 +@str.135 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.136 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.137 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.138 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.139 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.140 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.141 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.142 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.143 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@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 @SX_JNI_CLS_noop____V = internal global ptr null @SX_JNI_MID_noop____V = internal global ptr null -@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 +@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 @@ -37,85 +37,7 @@ 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: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca i64, align 8 - store i64 %2, ptr %allocaN, align 8 - %load = load i64, ptr %allocaN, align 8 - %call = call ptr @malloc(i64 %load) - ret ptr %call -} - -; Function Attrs: nounwind -define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { -entry: - %alloca = alloca ptr, align 8 - store ptr %1, ptr %alloca, align 8 - %allocaN = alloca ptr, align 8 - store ptr %2, ptr %allocaN, align 8 - %load = load ptr, ptr %allocaN, align 8 - call void @free(ptr %load) - ret void -} - -; Function Attrs: nounwind -declare i64 @GPA.init(ptr) #0 - -; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.add_chunk(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 +declare void @out.1(ptr) #0 ; Function Attrs: nounwind define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 { @@ -331,7 +253,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.127, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.129, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -427,7 +349,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.128, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, 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 @@ -435,7 +357,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.129, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.131, 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 @@ -445,13 +367,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.130, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, 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.131, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, 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 @@ -459,7 +381,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.132, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -473,7 +395,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.133, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.135, 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 @@ -481,7 +403,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.134, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, 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 @@ -492,7 +414,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.135, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -549,7 +471,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.136, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.138, 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 @@ -557,7 +479,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.137, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, 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 @@ -568,7 +490,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.138, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -588,7 +510,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.139, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.141, 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 @@ -596,7 +518,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.140, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.142, 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 @@ -607,7 +529,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.141, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.143, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.38 @@ -617,67 +539,151 @@ if.merge.38: ; preds = %if.then.37, %while. } ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @out.2(ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +define internal ptr @CAllocator.alloc_bytes(ptr %0, ptr %1, i64 %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + store i64 %2, ptr %allocaN, align 8 + %load = load i64, ptr %allocaN, align 8 + %call = call ptr @malloc(i64 %load) + ret ptr %call +} ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +define internal void @CAllocator.dealloc_bytes(ptr %0, ptr %1, ptr %2) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca ptr, align 8 + store ptr %2, ptr %allocaN, align 8 + %load = load ptr, ptr %allocaN, align 8 + call void @free(ptr %load) + ret void +} ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @GPA.init(ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare ptr @GPA.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare void @GPA.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.add_chunk(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 +declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 +declare void @Arena.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 +declare void @Arena.deinit(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 +declare ptr @Arena.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @Arena.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 +declare void @BufAlloc.init(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 +declare void @BufAlloc.reset(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 +declare ptr @BufAlloc.alloc_bytes(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 +declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 +declare void @TrackingAllocator.report(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @GPA.init.6(ptr) #0 + +; Function Attrs: nounwind +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.reset.11(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @Arena.deinit.12(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.reset.16(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 + +; Function Attrs: nounwind +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.report.21(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 + +; Function Attrs: nounwind +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -853,166 +859,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -1210,64 +1216,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -1297,97 +1303,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -1426,7 +1432,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind define internal void @unused_jni(ptr %0, ptr %1, ptr %2) #0 { @@ -1454,7 +1460,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.142, ptr @str.143) + %jni.fresh.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.global.cls, ptr @str.144, ptr @str.145) store ptr %jni.fresh.mid, ptr @SX_JNI_MID_noop____V, align 8 br label %jni.cont @@ -1506,14 +1512,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) @@ -1529,6 +1535,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/1425-ffi-jni-main-03-ctor.ir b/examples/expected/1425-ffi-jni-main-03-ctor.ir index 0095b99..7a44c78 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.164 = private unnamed_addr constant [23 x i8] c"(Landroid/os/Bundle;)V\00", align 1 +@str.166 = 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.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 +@str.167 = private unnamed_addr constant [7 x i8] c"\00", align 1 +@str.168 = 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,51 @@ declare ptr @memcpy(ptr, ptr, i64) declare ptr @memset(ptr, i32, i64) +; Function Attrs: nounwind +declare void @out.1(ptr) #0 + +; Function Attrs: nounwind +declare ptr @cstring(ptr, i64) #0 + +; Function Attrs: nounwind +declare ptr @int_to_string(ptr, i64) #0 + +; Function Attrs: nounwind +declare ptr @uint_to_string(ptr, i64) #0 + +; Function Attrs: nounwind +declare ptr @bool_to_string(ptr, i1) #0 + +; Function Attrs: nounwind +declare ptr @float_to_string(ptr, double) #0 + +; Function Attrs: nounwind +declare void @hex_group(ptr, ptr, i64, i64) #0 + +; Function Attrs: nounwind +declare [4 x i64] @decompose_u16x4(ptr, i64) #0 + +; Function Attrs: nounwind +declare ptr @int_to_hex_string(ptr, i64) #0 + +; Function Attrs: nounwind +declare ptr @concat(ptr, ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @substr(ptr, ptr, i64, i64) #0 + +; Function Attrs: nounwind +declare ptr @path_join(ptr, ptr) #0 + +; Function Attrs: nounwind +declare ptr @any_to_string(ptr, [2 x i64]) #0 + +; Function Attrs: nounwind +declare ptr @build_format(ptr, ptr) #0 + +; Function Attrs: nounwind +declare void @out.2(ptr) #0 + ; Function Attrs: nounwind declare ptr @mem_realloc(ptr, ptr, ptr, i64, i64, i64) #0 @@ -101,106 +146,67 @@ declare ptr @TrackingAllocator.alloc_bytes(ptr, ptr, i64) #0 declare void @TrackingAllocator.dealloc_bytes(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @cstring(ptr, i64) #0 +declare ptr @mem_realloc.3(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_string(ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.4(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @uint_to_string(ptr, i64) #0 +declare void @CAllocator.dealloc_bytes.5(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @bool_to_string(ptr, i1) #0 +declare i64 @GPA.init.6(ptr) #0 ; Function Attrs: nounwind -declare ptr @float_to_string(ptr, double) #0 +declare ptr @GPA.alloc_bytes.7(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @hex_group(ptr, ptr, i64, i64) #0 +declare void @GPA.dealloc_bytes.8(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare [4 x i64] @decompose_u16x4(ptr, i64) #0 +declare void @Arena.add_chunk.9(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @int_to_hex_string(ptr, i64) #0 +declare void @Arena.init.10(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @concat(ptr, ptr, ptr) #0 +declare void @Arena.reset.11(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @substr(ptr, ptr, i64, i64) #0 +declare void @Arena.deinit.12(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @path_join(ptr, ptr) #0 +declare ptr @Arena.alloc_bytes.13(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @any_to_string(ptr, [2 x i64]) #0 +declare void @Arena.dealloc_bytes.14(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @build_format(ptr, ptr) #0 +declare void @BufAlloc.init.15(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.1(ptr, ptr, ptr, i64, i64, i64) #0 +declare void @BufAlloc.reset.16(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.2(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.17(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.3(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.18(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.4(ptr) #0 +declare void @TrackingAllocator.init.19(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.5(ptr, ptr, i64) #0 +declare i64 @TrackingAllocator.leak_count.20(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.6(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.report.21(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.7(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.22(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.8(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.reset.9(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @Arena.deinit.10(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.11(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.12(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.init.13(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.reset.14(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.15(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.16(ptr, ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.init.17(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 - -; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.18(ptr, ptr) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.report.19(ptr, ptr) #0 - -; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.20(ptr, ptr, i64) #0 - -; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.21(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.23(ptr, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @escape(ptr, ptr) #0 @@ -376,166 +382,166 @@ declare i32 @listen(i32, i32) #0 declare i32 @accept(i32, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @read.22(i32, ptr, i64) #0 +declare i64 @read.24(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i32 @close.23(i32) #0 +declare i32 @close.25(i32) #0 ; Function Attrs: nounwind declare i16 @htons(ptr, i64) #0 ; Function Attrs: nounwind -declare ptr @mem_realloc.24(ptr, ptr, ptr, i64, i64, i64) #0 +declare ptr @mem_realloc.26(ptr, ptr, ptr, i64, i64, i64) #0 ; Function Attrs: nounwind -declare ptr @CAllocator.alloc_bytes.25(ptr, ptr, i64) #0 +declare ptr @CAllocator.alloc_bytes.27(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @CAllocator.dealloc_bytes.26(ptr, ptr, ptr) #0 +declare void @CAllocator.dealloc_bytes.28(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @GPA.init.27(ptr) #0 +declare i64 @GPA.init.29(ptr) #0 ; Function Attrs: nounwind -declare ptr @GPA.alloc_bytes.28(ptr, ptr, i64) #0 +declare ptr @GPA.alloc_bytes.30(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @GPA.dealloc_bytes.29(ptr, ptr, ptr) #0 +declare void @GPA.dealloc_bytes.31(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.add_chunk.30(ptr, ptr, i64) #0 +declare void @Arena.add_chunk.32(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.init.31(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 +declare void @Arena.init.33(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.reset.32(ptr, ptr) #0 +declare void @Arena.reset.34(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @Arena.deinit.33(ptr, ptr) #0 +declare void @Arena.deinit.35(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @Arena.alloc_bytes.34(ptr, ptr, i64) #0 +declare ptr @Arena.alloc_bytes.36(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @Arena.dealloc_bytes.35(ptr, ptr, ptr) #0 +declare void @Arena.dealloc_bytes.37(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @BufAlloc.init.36(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 +declare void @BufAlloc.init.38(ptr sret({ ptr, i64, i64 }), ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.reset.37(ptr, ptr) #0 +declare void @BufAlloc.reset.39(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @BufAlloc.alloc_bytes.38(ptr, ptr, i64) #0 +declare ptr @BufAlloc.alloc_bytes.40(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @BufAlloc.dealloc_bytes.39(ptr, ptr, ptr) #0 +declare void @BufAlloc.dealloc_bytes.41(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.init.40(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 +declare void @TrackingAllocator.init.42(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @TrackingAllocator.leak_count.41(ptr, ptr) #0 +declare i64 @TrackingAllocator.leak_count.43(ptr, ptr) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.report.42(ptr, ptr) #0 +declare void @TrackingAllocator.report.44(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @TrackingAllocator.alloc_bytes.43(ptr, ptr, i64) #0 +declare ptr @TrackingAllocator.alloc_bytes.45(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @TrackingAllocator.dealloc_bytes.44(ptr, ptr, ptr) #0 +declare void @TrackingAllocator.dealloc_bytes.46(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @open.45(ptr, i32, ...) #0 +declare i32 @open.47(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.46(i32) #0 +declare i32 @close.48(i32) #0 ; Function Attrs: nounwind -declare i64 @read.47(i32, ptr, i64) #0 +declare i64 @read.49(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.48(i32, i64, i32) #0 +declare i64 @lseek.50(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.49(ptr) #0 +declare i32 @unlink.51(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.50(ptr) #0 +declare i32 @rmdir.52(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.51(ptr, i32) #0 +declare i32 @mkdir.53(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.52(ptr, i32) #0 +declare i32 @access.54(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.53(ptr, i32) #0 +declare i32 @chmod.55(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.54(ptr, ptr) #0 +declare i32 @rename.56(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.55(ptr, ptr) #0 +declare i1 @File.is_valid.57(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.56(ptr, ptr) #0 +declare i1 @File.close.58(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.57(ptr, ptr, ptr) #0 +declare i64 @File.read.59(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.58(ptr, ptr, ptr) #0 +declare i64 @File.write.60(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.59(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.61(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.60(ptr, i64) #0 +declare i32 @mode_to_flags.62(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.61(ptr, ptr, i64) #0 +declare i64 @open_file.63(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.62(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.64(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.63(ptr, ptr, ptr) #0 +declare i1 @write_file.65(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.64(ptr, ptr, ptr) #0 +declare i1 @append_file.66(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.65(ptr, ptr) #0 +declare i1 @exists.67(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.66(ptr, ptr) #0 +declare i1 @delete_file.68(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.67(ptr, ptr) #0 +declare i1 @delete_dir.69(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.68(ptr, ptr) #0 +declare i1 @create_dir.70(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.69(ptr, ptr, i32) #0 +declare i1 @set_mode.71(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.70(ptr, ptr, ptr) #0 +declare i1 @move.72(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.71(ptr, ptr) #0 +declare i1 @create_dir_all.73(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.72(ptr, ptr, ptr) #0 +declare i1 @copy_file.74(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.73(ptr, ptr) #0 +declare ptr @basename.75(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.74(ptr, ptr) #0 +declare ptr @dirname.76(ptr, ptr) #0 ; Function Attrs: nounwind declare void @Array.add(ptr, ptr, ptr, ptr) #0 @@ -733,64 +739,64 @@ declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0 declare i64 @build_options() #0 ; Function Attrs: nounwind -declare ptr @spaces.75(ptr, i32) #0 +declare ptr @spaces.77(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @sx_trace_len.76() #0 +declare i32 @sx_trace_len.78() #0 ; Function Attrs: nounwind -declare i32 @sx_trace_truncated.77() #0 +declare i32 @sx_trace_truncated.79() #0 ; Function Attrs: nounwind -declare i64 @sx_trace_frame_at.78(i32) #0 +declare i64 @sx_trace_frame_at.80(i32) #0 ; Function Attrs: nounwind -declare ptr @to_string.79(ptr) #0 +declare ptr @to_string.81(ptr) #0 ; Function Attrs: nounwind -declare void @print_current.80(ptr) #0 +declare void @print_current.82(ptr) #0 ; Function Attrs: nounwind -declare void @print_interpreter_frames.81(ptr) #0 +declare void @print_interpreter_frames.83(ptr) #0 ; Function Attrs: nounwind -declare ptr @popen.82(ptr, ptr) #0 +declare ptr @popen.84(ptr, ptr) #0 ; Function Attrs: nounwind -declare i32 @pclose.83(ptr) #0 +declare i32 @pclose.85(ptr) #0 ; Function Attrs: nounwind -declare i64 @fread.84(ptr, i64, i64, ptr) #0 +declare i64 @fread.86(ptr, i64, i64, ptr) #0 ; Function Attrs: nounwind -declare i32 @feof.85(ptr) #0 +declare i32 @feof.87(ptr) #0 ; Function Attrs: nounwind -declare ptr @getenv.86(ptr) #0 +declare ptr @getenv.88(ptr) #0 ; Function Attrs: nounwind -declare i64 @strlen.87(ptr) #0 +declare i64 @strlen.89(ptr) #0 ; Function Attrs: nounwind -declare i32 @system.88(ptr) #0 +declare i32 @system.90(ptr) #0 ; Function Attrs: nounwind -declare void @run.89(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 +declare void @run.91(ptr sret({ { i32, { ptr, i64 } }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @env.90(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @env.92(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @find_executable.91(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @find_executable.93(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare void @_exit.92(i32) #0 +declare void @_exit.94(i32) #0 ; Function Attrs: nounwind -declare void @exit.93(ptr, i8, ptr) #0 +declare void @exit.95(ptr, i8, ptr) #0 ; Function Attrs: nounwind -declare void @assert.94(ptr, i1, ptr, ptr) #0 +declare void @assert.96(ptr, i1, ptr, ptr) #0 ; Function Attrs: nounwind declare ptr @_NSGetArgv() #0 @@ -820,97 +826,97 @@ declare ptr @Parsed.value_of(ptr, ptr, ptr) #0 declare i1 @is_long_flag(ptr, ptr) #0 ; Function Attrs: nounwind -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 +declare void @parse.97(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.96(ptr, i32, ...) #0 +declare i32 @open.98(ptr, i32, ...) #0 ; Function Attrs: nounwind -declare i32 @close.97(i32) #0 +declare i32 @close.99(i32) #0 ; Function Attrs: nounwind -declare i64 @read.98(i32, ptr, i64) #0 +declare i64 @read.100(i32, ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @lseek.99(i32, i64, i32) #0 +declare i64 @lseek.101(i32, i64, i32) #0 ; Function Attrs: nounwind -declare i32 @unlink.100(ptr) #0 +declare i32 @unlink.102(ptr) #0 ; Function Attrs: nounwind -declare i32 @rmdir.101(ptr) #0 +declare i32 @rmdir.103(ptr) #0 ; Function Attrs: nounwind -declare i32 @mkdir.102(ptr, i32) #0 +declare i32 @mkdir.104(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @access.103(ptr, i32) #0 +declare i32 @access.105(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @chmod.104(ptr, i32) #0 +declare i32 @chmod.106(ptr, i32) #0 ; Function Attrs: nounwind -declare i32 @rename.105(ptr, ptr) #0 +declare i32 @rename.107(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.is_valid.106(ptr, ptr) #0 +declare i1 @File.is_valid.108(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @File.close.107(ptr, ptr) #0 +declare i1 @File.close.109(ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.read.108(ptr, ptr, ptr) #0 +declare i64 @File.read.110(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.write.109(ptr, ptr, ptr) #0 +declare i64 @File.write.111(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @File.seek.110(ptr, ptr, i64, i64) #0 +declare i64 @File.seek.112(ptr, ptr, i64, i64) #0 ; Function Attrs: nounwind -declare i32 @mode_to_flags.111(ptr, i64) #0 +declare i32 @mode_to_flags.113(ptr, i64) #0 ; Function Attrs: nounwind -declare i64 @open_file.112(ptr, ptr, i64) #0 +declare i64 @open_file.114(ptr, ptr, i64) #0 ; Function Attrs: nounwind -declare void @read_file.113(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 +declare void @read_file.115(ptr sret({ { ptr, i64 }, i1 }), ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @write_file.114(ptr, ptr, ptr) #0 +declare i1 @write_file.116(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @append_file.115(ptr, ptr, ptr) #0 +declare i1 @append_file.117(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @exists.116(ptr, ptr) #0 +declare i1 @exists.118(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_file.117(ptr, ptr) #0 +declare i1 @delete_file.119(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @delete_dir.118(ptr, ptr) #0 +declare i1 @delete_dir.120(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir.119(ptr, ptr) #0 +declare i1 @create_dir.121(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @set_mode.120(ptr, ptr, i32) #0 +declare i1 @set_mode.122(ptr, ptr, i32) #0 ; Function Attrs: nounwind -declare i1 @move.121(ptr, ptr, ptr) #0 +declare i1 @move.123(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @create_dir_all.122(ptr, ptr) #0 +declare i1 @create_dir_all.124(ptr, ptr) #0 ; Function Attrs: nounwind -declare i1 @copy_file.123(ptr, ptr, ptr) #0 +declare i1 @copy_file.125(ptr, ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @basename.124(ptr, ptr) #0 +declare ptr @basename.126(ptr, ptr) #0 ; Function Attrs: nounwind -declare ptr @dirname.125(ptr, ptr) #0 +declare ptr @dirname.127(ptr, ptr) #0 ; Function Attrs: nounwind declare i64 @rotr(ptr, i64, i64) #0 @@ -949,118 +955,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.126(ptr, i1) #0 +declare void @assert.128(ptr, i1) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_link_flag.127(i64, ptr) #0 +declare void @BuildOptions.add_link_flag.129(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_framework.128(i64, ptr) #0 +declare void @BuildOptions.add_framework.130(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_output_path.129(i64, ptr) #0 +declare void @BuildOptions.set_output_path.131(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_wasm_shell.130(i64, ptr) #0 +declare void @BuildOptions.set_wasm_shell.132(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.add_asset_dir.131(i64, ptr, ptr) #0 +declare void @BuildOptions.add_asset_dir.133(i64, ptr, ptr) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.asset_dir_count.132(i64) #0 +declare i64 @BuildOptions.asset_dir_count.134(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_src_at.133(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_src_at.135(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.asset_dir_dest_at.134(i64, i64) #0 +declare ptr @BuildOptions.asset_dir_dest_at.136(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_callback.135(i64, ptr) #0 +declare void @BuildOptions.set_post_link_callback.137(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_post_link_module.136(i64, ptr) #0 +declare void @BuildOptions.set_post_link_module.138(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.binary_path.137(i64) #0 +declare ptr @BuildOptions.binary_path.139(i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_path.138(i64, ptr) #0 +declare void @BuildOptions.set_bundle_path.140(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_bundle_id.139(i64, ptr) #0 +declare void @BuildOptions.set_bundle_id.141(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_codesign_identity.140(i64, ptr) #0 +declare void @BuildOptions.set_codesign_identity.142(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_provisioning_profile.141(i64, ptr) #0 +declare void @BuildOptions.set_provisioning_profile.143(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_path.142(i64) #0 +declare ptr @BuildOptions.bundle_path.144(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.bundle_id.143(i64) #0 +declare ptr @BuildOptions.bundle_id.145(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.codesign_identity.144(i64) #0 +declare ptr @BuildOptions.codesign_identity.146(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.provisioning_profile.145(i64) #0 +declare ptr @BuildOptions.provisioning_profile.147(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.target_triple.146(i64) #0 +declare ptr @BuildOptions.target_triple.148(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_macos.147(i64) #0 +declare i1 @BuildOptions.is_macos.149(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios.148(i64) #0 +declare i1 @BuildOptions.is_ios.150(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_device.149(i64) #0 +declare i1 @BuildOptions.is_ios_device.151(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_ios_simulator.150(i64) #0 +declare i1 @BuildOptions.is_ios_simulator.152(i64) #0 ; Function Attrs: nounwind -declare i1 @BuildOptions.is_android.151(i64) #0 +declare i1 @BuildOptions.is_android.153(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_count.152(i64) #0 +declare i64 @BuildOptions.framework_count.154(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_at.153(i64, i64) #0 +declare ptr @BuildOptions.framework_at.155(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.framework_path_count.154(i64) #0 +declare i64 @BuildOptions.framework_path_count.156(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.framework_path_at.155(i64, i64) #0 +declare ptr @BuildOptions.framework_path_at.157(i64, i64) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_manifest_path.156(i64, ptr) #0 +declare void @BuildOptions.set_manifest_path.158(i64, ptr) #0 ; Function Attrs: nounwind -declare void @BuildOptions.set_keystore_path.157(i64, ptr) #0 +declare void @BuildOptions.set_keystore_path.159(i64, ptr) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.manifest_path.158(i64) #0 +declare ptr @BuildOptions.manifest_path.160(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.keystore_path.159(i64) #0 +declare ptr @BuildOptions.keystore_path.161(i64) #0 ; Function Attrs: nounwind -declare i64 @BuildOptions.jni_main_count.160(i64) #0 +declare i64 @BuildOptions.jni_main_count.162(i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_foreign_path_at.161(i64, i64) #0 +declare ptr @BuildOptions.jni_main_foreign_path_at.163(i64, i64) #0 ; Function Attrs: nounwind -declare ptr @BuildOptions.jni_main_java_source_at.162(i64, i64) #0 +declare ptr @BuildOptions.jni_main_java_source_at.164(i64, i64) #0 ; Function Attrs: nounwind -declare i64 @build_options.163() #0 +declare i64 @build_options.165() #0 ; Function Attrs: nounwind define i32 @main() #0 { @@ -1100,7 +1106,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.164) + %jni.mid = call ptr %jni.GetMethodID(ptr %load, ptr %jni.parent.cls, ptr @str, ptr @str.166) %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 @@ -1116,7 +1122,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.165, ptr @str.166) + %jni.ctor.mid = call ptr %jni.GetMethodID10(ptr %load, ptr %jni.ctor.cls, ptr @str.167, ptr @str.168) %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/library/modules/std.sx b/library/modules/std.sx index f529572..12b76d9 100644 --- a/library/modules/std.sx +++ b/library/modules/std.sx @@ -1,498 +1,76 @@ -Vector :: ($N: int, $T: Type) -> Type #builtin; -out :: (str: string) -> void #builtin; -// sqrt :: (x: $T) -> T #builtin; -// sin :: (x: $T) -> T #builtin; -// cos :: (x: $T) -> T #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`. 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"; +// The prelude facade: every name here is a RE-EXPORT. The implementations +// live in the part-files (std/core.sx — compiler-coupled primitives, +// std/fmt.sx — formatting + string helpers, std/list.sx — List); each +// alias below is an ordinary OWN declaration of this file, so a flat +// `#import "modules/std.sx"` sees the whole prelude bare, one hop — +// visibility never chains, aliases are the re-export mechanism. The +// part-file namespaces (`core` / `fmt` / `list`) and the namespace tail at +// the bottom are carried to flat importers the same one level. -memcpy :: (dst: *void, src: *void, size: s64) -> *void #foreign libc "memcpy"; -memset :: (dst: *void, val: s64, size: s64) -> void #foreign libc "memset"; -type_of :: (val: $T) -> Type #builtin; -type_name :: ($T: Type) -> string #builtin; -field_count :: ($T: Type) -> s64 #builtin; -field_name :: ($T: Type, idx: s64) -> string #builtin; -field_value :: (s: $T, idx: s64) -> Any #builtin; -is_flags :: ($T: Type) -> bool #builtin; -type_is_unsigned :: ($T: Type) -> bool #builtin; -field_value_int :: ($T: Type, idx: s64) -> s64 #builtin; -field_index :: ($T: Type, val: T) -> s64 #builtin; -error_tag_name :: (e: $T) -> string #builtin; - -// Call-site location, synthesized by the `#caller_location` directive when it -// is a parameter's default value (ERR E4.1b). `process.exit` / `assert` use it -// to report where they were invoked. -Source_Location :: struct { - file: string; - line: s32; - col: s32; - func: string; -} -string :: []u8 #builtin; +core :: #import "modules/std/core.sx"; +fmt :: #import "modules/std/fmt.sx"; +list :: #import "modules/std/list.sx"; #import "modules/std/mem.sx"; -// --- Allocator protocol (impls live in std/mem.sx) --- +// --- core: builtins, libc escape hatch, compiler-resolved types --- +// (`string` has no alias here: it is a reserved type name — its #builtin +// declaration in core.sx resolves program-wide and cannot be re-bound.) -// Bytes-level primitives carry the `_bytes` suffix so the typed -// helpers in std/mem.sx own the bare names (`alloc(T, n)`, `free(s)`). -Allocator :: protocol #inline { - alloc_bytes :: (size: s64) -> *void; - dealloc_bytes :: (ptr: *void); -} +Vector :: core.Vector; +out :: core.out; +size_of :: core.size_of; +align_of :: core.align_of; +libc_malloc :: core.libc_malloc; +libc_free :: core.libc_free; +memcpy :: core.memcpy; +memset :: core.memset; +type_of :: core.type_of; +type_name :: core.type_name; +field_count :: core.field_count; +field_name :: core.field_name; +field_value :: core.field_value; +is_flags :: core.is_flags; +type_is_unsigned :: core.type_is_unsigned; +field_value_int :: core.field_value_int; +field_index :: core.field_index; +error_tag_name :: core.error_tag_name; +Source_Location :: core.Source_Location; +Allocator :: core.Allocator; +Context :: core.Context; +Into :: core.Into; -// --- Context --- +// --- fmt: formatting, string helpers, slice/string allocation --- -Context :: struct { - allocator: Allocator; - data: *void; -} +cstring :: fmt.cstring; +alloc_slice :: fmt.alloc_slice; +int_to_string :: fmt.int_to_string; +uint_to_string :: fmt.uint_to_string; +bool_to_string :: fmt.bool_to_string; +float_to_string :: fmt.float_to_string; +hex_group :: fmt.hex_group; +decompose_u16x4 :: fmt.decompose_u16x4; +int_to_hex_string :: fmt.int_to_hex_string; +concat :: fmt.concat; +substr :: fmt.substr; +path_join :: fmt.path_join; +struct_to_string :: fmt.struct_to_string; +vector_to_string :: fmt.vector_to_string; +array_to_string :: fmt.array_to_string; +slice_to_string :: fmt.slice_to_string; +pointer_to_string :: fmt.pointer_to_string; +flags_to_string :: fmt.flags_to_string; +enum_to_string :: fmt.enum_to_string; +optional_to_string :: fmt.optional_to_string; +any_to_string :: fmt.any_to_string; +build_format :: fmt.build_format; +format :: fmt.format; +print :: fmt.print; -// --- Slice & string allocation --- +// --- list --- -cstring :: (size: s64) -> string { - raw := context.allocator.alloc_bytes(size + 1); - memset(raw, 0, size + 1); - s : string = ---; - s.ptr = xx raw; - s.len = size; - s -} +List :: list.List; -alloc_slice :: ($T: Type, count: s64) -> []T { - raw := context.allocator.alloc_bytes(count * size_of(T)); - memset(raw, 0, count * size_of(T)); - s : []T = ---; - s.ptr = xx raw; - s.len = count; - s -} - -int_to_string :: (n: s64) -> string { - if n == 0 { return "0"; } - neg := n < 0; - // Extract digits straight from `n` without ever negating it: `0 - n` - // overflows for s64::MIN (its magnitude is unrepresentable as a - // positive s64). sx `%` truncates toward zero, so `n % 10` keeps n's - // sign; take each remainder's absolute value for the digit. - tmp := cstring(20); - i := 19; - v := n; - while v != 0 { - d := v % 10; - if d < 0 { d = 0 - d; } - tmp[i] = d + 48; - v = v / 10; - i -= 1; - } - if neg { tmp[i] = 45; i -= 1; } - substr(tmp, i + 1, 19 - i) -} - -// Unsigned decimal of `n`'s 64 bits — renders the full u64 range -// (0 .. 18446744073709551615). Used by `any_to_string` for unsigned -// integer values, which an s64-based formatter would misread (e.g. a -// u64 all-ones value as -1). -uint_to_string :: (n: s64) -> string { - if n == 0 { return "0"; } - // Long division by 10 across the four unsigned 16-bit limbs, most - // significant first. Each step folds the running remainder into the - // next limb; the per-step accumulator stays well within s64 - // (max 9*65536 + 65535), so signed `/` and `%` are exact. - g := decompose_u16x4(n); - tmp := cstring(20); - i := 19; - while g[0] != 0 or g[1] != 0 or g[2] != 0 or g[3] != 0 { - rem := 0; - k := 0; - while k < 4 { - acc := rem * 65536 + g[k]; - g[k] = acc / 10; - rem = acc % 10; - k += 1; - } - tmp[i] = rem + 48; - i -= 1; - } - substr(tmp, i + 1, 19 - i) -} - -bool_to_string :: (b: bool) -> string { - if b then "true" else "false" -} - -float_to_string :: (f: f64) -> string { - neg := f < 0.0; - v := if neg then 0.0 - f else f; - int_part := cast(s64) v; - frac := cast(s64) ((v - cast(f64) int_part) * 1000000.0); - if frac < 0 { frac = 0 - frac; } - istr := int_to_string(int_part); - fstr := int_to_string(frac); - il := istr.len; - fl := fstr.len; - prefix := if neg then 1 else 0; - total := prefix + il + 1 + 6; - buf := cstring(total); - pos := 0; - if neg { buf[0] = 45; pos = 1; } - memcpy(@buf[pos], istr.ptr, il); - pos = pos + il; - buf[pos] = 46; - pos += 1; - pad := 6 - fl; - memset(@buf[pos], 48, pad); - pos = pos + pad; - memcpy(@buf[pos], fstr.ptr, fl); - buf -} - -hex_group :: (buf: string, offset: s64, val: s64) { - i := offset + 3; - v := val; - while i >= offset { - d := v % 16; - buf[i] = if d < 10 then d + 48 else d - 10 + 97; - v = v / 16; - i -= 1; - } -} - -// Split the 64 bits of `n` into four unsigned 16-bit limbs, most -// significant first: [g3, g2, g1, g0]. A negative input is treated as -// its two's-complement unsigned bit pattern — each limb is corrected -// back into 0..65535 — so callers get correct unsigned arithmetic out -// of a signed-only integer type. Shared by the hex and unsigned-decimal -// formatters. -decompose_u16x4 :: (n: s64) -> [4]s64 { - g0 := n % 65536; - if g0 < 0 { g0 = g0 + 65536; } - r1 := (n - g0) / 65536; - g1 := r1 % 65536; - if g1 < 0 { g1 = g1 + 65536; } - r2 := (r1 - g1) / 65536; - g2 := r2 % 65536; - if g2 < 0 { g2 = g2 + 65536; } - r3 := (r2 - g2) / 65536; - g3 := r3 % 65536; - if g3 < 0 { g3 = g3 + 65536; } - limbs : [4]s64 = ---; - limbs[0] = g3; - limbs[1] = g2; - limbs[2] = g1; - limbs[3] = g0; - limbs -} - -int_to_hex_string :: (n: s64) -> string { - if n == 0 { return "0"; } - - g := decompose_u16x4(n); - buf := cstring(16); - hex_group(buf, 0, g[0]); - hex_group(buf, 4, g[1]); - hex_group(buf, 8, g[2]); - hex_group(buf, 12, g[3]); - - // Skip leading zeros (keep at least 1 digit) - start := 0; - while start < 15 { - if buf[start] != 48 { break; } - start += 1; - } - substr(buf, start, 16 - start) -} - -concat :: (a: string, b: string) -> string { - al := a.len; - bl := b.len; - buf := cstring(al + bl); - memcpy(buf.ptr, a.ptr, al); - memcpy(@buf[al], b.ptr, bl); - buf -} - -substr :: (s: string, start: s64, len: s64) -> string { - buf := cstring(len); - memcpy(buf.ptr, @s[start], len); - buf -} - -// Join path components with the POSIX separator ('/'). Skips empty -// components and collapses duplicate separators at component -// boundaries. Used for bundle paths where Apple .app and Android APK -// both expect POSIX-style paths. -path_join :: (..parts: []string) -> string { - result := ""; - i := 0; - while i < parts.len { - p := parts[i]; - if p.len > 0 { - if result.len > 0 { - tail := result[result.len - 1]; - head := p[0]; - if tail == 47 { - if head == 47 { - p = substr(p, 1, p.len - 1); - } - } else { - if head != 47 { - result = concat(result, "/"); - } - } - } - result = concat(result, p); - } - i += 1; - } - result -} - -struct_to_string :: (s: $T) -> string { - result := concat(type_name(T), "{"); - i := 0; - while i < field_count(T) { - if i > 0 { result = concat(result, ", "); } - result = concat(result, field_name(T, i)); - result = concat(result, ": "); - result = concat(result, any_to_string(field_value(s, i))); - i += 1; - } - concat(result, "}") -} - -vector_to_string :: (v: $T) -> string { - result := "["; - i := 0; - while i < field_count(T) { - if i > 0 { result = concat(result, ", "); } - result = concat(result, any_to_string(field_value(v, i))); - i += 1; - } - concat(result, "]") -} - -array_to_string :: (a: $T) -> string { - result := "["; - i := 0; - while i < field_count(T) { - if i > 0 { result = concat(result, ", "); } - result = concat(result, any_to_string(field_value(a, i))); - i += 1; - } - concat(result, "]") -} - -slice_to_string :: (items: []$T) -> string { - result := "["; - i := 0; - while i < items.len { - if i > 0 { result = concat(result, ", "); } - result = concat(result, any_to_string(field_value(items, i))); - i += 1; - } - concat(result, "]") -} - -pointer_to_string :: (p: $T) -> string { - addr : s64 = xx p; - if addr == 0 { "null" } else { - concat(type_name(T), concat("@0x", int_to_hex_string(addr))) - } -} - -flags_to_string :: (val: $T) -> string { - v := cast(s64) val; - result := ""; - i := 0; - while i < field_count(T) { - fv := field_value_int(T, i); - if v & fv { - if result.len > 0 { result = concat(result, " | "); } - result = concat(result, concat(".", field_name(T, i))); - } - i += 1; - } - if result.len == 0 { result = "0"; } - result -} - -enum_to_string :: (u: $T) -> string { - if is_flags(T) { return flags_to_string(u); } - idx := field_index(T, u); - result := concat(".", field_name(T, idx)); - payload := field_value(u, idx); - pstr := any_to_string(payload); - if pstr.len > 0 { - result = concat(result, concat("(", concat(pstr, ")"))); - } - result -} - -optional_to_string :: (o: $T) -> string { - if o == null { return "null"; } - return any_to_string(o!); -} - -any_to_string :: (val: Any) -> string { - result := ""; - type := type_of(val); - if type == { - case void: result = ""; - case int: { - if type_is_unsigned(type) { result = uint_to_string(xx val); } - else { result = int_to_string(xx val); } - } - case string: { s : string = xx val; result = s; } - case bool: result = bool_to_string(xx val); - case float: result = float_to_string(xx val); - case struct: result = struct_to_string(cast(type) val); - case enum: result = enum_to_string(cast(type) val); - case error_set: { tagid : u32 = xx val; result = error_tag_name(tagid); } - case vector: result = vector_to_string(cast(type) val); - case array: result = array_to_string(cast(type) val); - case slice: result = slice_to_string(cast(type) val); - case pointer: result = pointer_to_string(cast(type) val); - case optional: result = optional_to_string(cast(type) val); - case type: result = type_name(val); - } - result -} - -build_format :: (fmt: string) -> string { - code := "result := \"\"; "; - seg_start := 0; - i := 0; - arg_idx := 0; - while i < fmt.len { - if fmt[i] == 123 { - if i + 1 < fmt.len { - if fmt[i + 1] == 125 { - if i > seg_start { - code = concat(code, "result = concat(result, substr(fmt, "); - code = concat(code, int_to_string(seg_start)); - code = concat(code, ", "); - code = concat(code, int_to_string(i - seg_start)); - code = concat(code, ")); "); - } - code = concat(code, "result = concat(result, any_to_string(args["); - code = concat(code, int_to_string(arg_idx)); - code = concat(code, "])); "); - arg_idx += 1; - i += 2; - seg_start = i; - } else if fmt[i + 1] == 123 { - code = concat(code, "result = concat(result, substr(fmt, "); - code = concat(code, int_to_string(seg_start)); - code = concat(code, ", "); - code = concat(code, int_to_string(i - seg_start + 1)); - code = concat(code, ")); "); - i += 2; - seg_start = i; - } else { - i += 1; - } - } else { - i += 1; - } - } else if fmt[i] == 125 { - if i + 1 < fmt.len { - if fmt[i + 1] == 125 { - code = concat(code, "result = concat(result, substr(fmt, "); - code = concat(code, int_to_string(seg_start)); - code = concat(code, ", "); - code = concat(code, int_to_string(i - seg_start + 1)); - code = concat(code, ")); "); - i += 2; - seg_start = i; - } else { - i += 1; - } - } else { - i += 1; - } - } else { - i += 1; - } - } - if seg_start < fmt.len { - code = concat(code, "result = concat(result, substr(fmt, "); - code = concat(code, int_to_string(seg_start)); - code = concat(code, ", "); - code = concat(code, int_to_string(fmt.len - seg_start)); - code = concat(code, ")); "); - } - code -} - -format :: ($fmt: string, ..$args) -> string { - #insert build_format(fmt); - #insert "return result;"; -} - -print :: ($fmt: string, ..$args) { - #insert build_format(fmt); - #insert "out(result);"; -} - -// User-space `xx` extension. `xx val : T` where the built-in conversion -// ladder makes no progress falls through to an `impl Into(T) for Source` -// lookup; the compiler monomorphises `convert` for the (Source, T) pair -// and emits a direct call. Compile-time only — no vtable, no runtime -// dispatch. -Into :: protocol(Target: Type) { - convert :: () -> Target; -} - -List :: struct ($T: Type) { - items: [*]T = null; - len: s64 = 0; - cap: s64 = 0; - - append :: (list: *List(T), item: T, alloc: Allocator = context.allocator) { - if list.len >= list.cap { - new_cap := if list.cap == 0 then 4 else list.cap * 2; - new_items : [*]T = xx alloc.alloc_bytes(new_cap * size_of(T)); - if list.len > 0 { - memcpy(new_items, list.items, list.len * size_of(T)); - alloc.dealloc_bytes(list.items); - } - list.items = new_items; - list.cap = new_cap; - } - list.items[list.len] = item; - list.len += 1; - } - - ensure_capacity :: (list: *List(T), n: s64, alloc: Allocator = context.allocator) { - if list.cap >= n { return; } - new_cap := if list.cap == 0 then 4 else list.cap; - while new_cap < n { new_cap = new_cap * 2; } - new_items : [*]T = xx alloc.alloc_bytes(new_cap * size_of(T)); - if list.len > 0 { - memcpy(new_items, list.items, list.len * size_of(T)); - alloc.dealloc_bytes(list.items); - } - list.items = new_items; - list.cap = new_cap; - } - - deinit :: (list: *List(T), alloc: Allocator = context.allocator) { - if list.items != null { - alloc.dealloc_bytes(list.items); - } - list.items = null; - list.len = 0; - list.cap = 0; - } -} // --- The stdlib namespace tail: flat-importing std.sx carries these --- mem :: #import "modules/std/mem.sx"; diff --git a/library/modules/std/core.sx b/library/modules/std/core.sx new file mode 100644 index 0000000..371c20f --- /dev/null +++ b/library/modules/std/core.sx @@ -0,0 +1,68 @@ +// The compiler-coupled prelude primitives: #builtin declarations, the libc +// escape hatch, and the types the compiler resolves by NAME program-wide +// (`Context`, `Allocator`, `Into`, `Source_Location`, `string`). Consumers +// never import this file directly — std.sx re-exports every name here. + +Vector :: ($N: int, $T: Type) -> Type #builtin; +out :: (str: string) -> void #builtin; +// sqrt :: (x: $T) -> T #builtin; +// sin :: (x: $T) -> T #builtin; +// cos :: (x: $T) -> T #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`. 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"; + +memcpy :: (dst: *void, src: *void, size: s64) -> *void #foreign libc "memcpy"; +memset :: (dst: *void, val: s64, size: s64) -> void #foreign libc "memset"; +type_of :: (val: $T) -> Type #builtin; +type_name :: ($T: Type) -> string #builtin; +field_count :: ($T: Type) -> s64 #builtin; +field_name :: ($T: Type, idx: s64) -> string #builtin; +field_value :: (s: $T, idx: s64) -> Any #builtin; +is_flags :: ($T: Type) -> bool #builtin; +type_is_unsigned :: ($T: Type) -> bool #builtin; +field_value_int :: ($T: Type, idx: s64) -> s64 #builtin; +field_index :: ($T: Type, val: T) -> s64 #builtin; +error_tag_name :: (e: $T) -> string #builtin; + +// Call-site location, synthesized by the `#caller_location` directive when it +// is a parameter's default value (ERR E4.1b). `process.exit` / `assert` use it +// to report where they were invoked. +Source_Location :: struct { + file: string; + line: s32; + col: s32; + func: string; +} +string :: []u8 #builtin; + +// --- Allocator protocol (impls live in std/mem.sx) --- + +// Bytes-level primitives carry the `_bytes` suffix so the typed +// helpers in std/mem.sx own the bare names (`alloc(T, n)`, `free(s)`). +Allocator :: protocol #inline { + alloc_bytes :: (size: s64) -> *void; + dealloc_bytes :: (ptr: *void); +} + +// --- Context --- + +Context :: struct { + allocator: Allocator; + data: *void; +} + +// User-space `xx` extension. `xx val : T` where the built-in conversion +// ladder makes no progress falls through to an `impl Into(T) for Source` +// lookup; the compiler monomorphises `convert` for the (Source, T) pair +// and emits a direct call. Compile-time only — no vtable, no runtime +// dispatch. +Into :: protocol(Target: Type) { + convert :: () -> Target; +} diff --git a/library/modules/std/fmt.sx b/library/modules/std/fmt.sx new file mode 100644 index 0000000..bb5a9ef --- /dev/null +++ b/library/modules/std/fmt.sx @@ -0,0 +1,392 @@ +// Formatting + string helpers: the `*_to_string` family, `any_to_string`, +// the comptime `format` / `print` pair, and the slice/string allocation +// helpers they build on. Consumers never import this file directly — +// std.sx re-exports every public name here. +#import "modules/std/core.sx"; + +// --- Slice & string allocation --- + +cstring :: (size: s64) -> string { + raw := context.allocator.alloc_bytes(size + 1); + memset(raw, 0, size + 1); + s : string = ---; + s.ptr = xx raw; + s.len = size; + s +} + +alloc_slice :: ($T: Type, count: s64) -> []T { + raw := context.allocator.alloc_bytes(count * size_of(T)); + memset(raw, 0, count * size_of(T)); + s : []T = ---; + s.ptr = xx raw; + s.len = count; + s +} + +int_to_string :: (n: s64) -> string { + if n == 0 { return "0"; } + neg := n < 0; + // Extract digits straight from `n` without ever negating it: `0 - n` + // overflows for s64::MIN (its magnitude is unrepresentable as a + // positive s64). sx `%` truncates toward zero, so `n % 10` keeps n's + // sign; take each remainder's absolute value for the digit. + tmp := cstring(20); + i := 19; + v := n; + while v != 0 { + d := v % 10; + if d < 0 { d = 0 - d; } + tmp[i] = d + 48; + v = v / 10; + i -= 1; + } + if neg { tmp[i] = 45; i -= 1; } + substr(tmp, i + 1, 19 - i) +} + +// Unsigned decimal of `n`'s 64 bits — renders the full u64 range +// (0 .. 18446744073709551615). Used by `any_to_string` for unsigned +// integer values, which an s64-based formatter would misread (e.g. a +// u64 all-ones value as -1). +uint_to_string :: (n: s64) -> string { + if n == 0 { return "0"; } + // Long division by 10 across the four unsigned 16-bit limbs, most + // significant first. Each step folds the running remainder into the + // next limb; the per-step accumulator stays well within s64 + // (max 9*65536 + 65535), so signed `/` and `%` are exact. + g := decompose_u16x4(n); + tmp := cstring(20); + i := 19; + while g[0] != 0 or g[1] != 0 or g[2] != 0 or g[3] != 0 { + rem := 0; + k := 0; + while k < 4 { + acc := rem * 65536 + g[k]; + g[k] = acc / 10; + rem = acc % 10; + k += 1; + } + tmp[i] = rem + 48; + i -= 1; + } + substr(tmp, i + 1, 19 - i) +} + +bool_to_string :: (b: bool) -> string { + if b then "true" else "false" +} + +float_to_string :: (f: f64) -> string { + neg := f < 0.0; + v := if neg then 0.0 - f else f; + int_part := cast(s64) v; + frac := cast(s64) ((v - cast(f64) int_part) * 1000000.0); + if frac < 0 { frac = 0 - frac; } + istr := int_to_string(int_part); + fstr := int_to_string(frac); + il := istr.len; + fl := fstr.len; + prefix := if neg then 1 else 0; + total := prefix + il + 1 + 6; + buf := cstring(total); + pos := 0; + if neg { buf[0] = 45; pos = 1; } + memcpy(@buf[pos], istr.ptr, il); + pos = pos + il; + buf[pos] = 46; + pos += 1; + pad := 6 - fl; + memset(@buf[pos], 48, pad); + pos = pos + pad; + memcpy(@buf[pos], fstr.ptr, fl); + buf +} + +hex_group :: (buf: string, offset: s64, val: s64) { + i := offset + 3; + v := val; + while i >= offset { + d := v % 16; + buf[i] = if d < 10 then d + 48 else d - 10 + 97; + v = v / 16; + i -= 1; + } +} + +// Split the 64 bits of `n` into four unsigned 16-bit limbs, most +// significant first: [g3, g2, g1, g0]. A negative input is treated as +// its two's-complement unsigned bit pattern — each limb is corrected +// back into 0..65535 — so callers get correct unsigned arithmetic out +// of a signed-only integer type. Shared by the hex and unsigned-decimal +// formatters. +decompose_u16x4 :: (n: s64) -> [4]s64 { + g0 := n % 65536; + if g0 < 0 { g0 = g0 + 65536; } + r1 := (n - g0) / 65536; + g1 := r1 % 65536; + if g1 < 0 { g1 = g1 + 65536; } + r2 := (r1 - g1) / 65536; + g2 := r2 % 65536; + if g2 < 0 { g2 = g2 + 65536; } + r3 := (r2 - g2) / 65536; + g3 := r3 % 65536; + if g3 < 0 { g3 = g3 + 65536; } + limbs : [4]s64 = ---; + limbs[0] = g3; + limbs[1] = g2; + limbs[2] = g1; + limbs[3] = g0; + limbs +} + +int_to_hex_string :: (n: s64) -> string { + if n == 0 { return "0"; } + + g := decompose_u16x4(n); + buf := cstring(16); + hex_group(buf, 0, g[0]); + hex_group(buf, 4, g[1]); + hex_group(buf, 8, g[2]); + hex_group(buf, 12, g[3]); + + // Skip leading zeros (keep at least 1 digit) + start := 0; + while start < 15 { + if buf[start] != 48 { break; } + start += 1; + } + substr(buf, start, 16 - start) +} + +concat :: (a: string, b: string) -> string { + al := a.len; + bl := b.len; + buf := cstring(al + bl); + memcpy(buf.ptr, a.ptr, al); + memcpy(@buf[al], b.ptr, bl); + buf +} + +substr :: (s: string, start: s64, len: s64) -> string { + buf := cstring(len); + memcpy(buf.ptr, @s[start], len); + buf +} + +// Join path components with the POSIX separator ('/'). Skips empty +// components and collapses duplicate separators at component +// boundaries. Used for bundle paths where Apple .app and Android APK +// both expect POSIX-style paths. +path_join :: (..parts: []string) -> string { + result := ""; + i := 0; + while i < parts.len { + p := parts[i]; + if p.len > 0 { + if result.len > 0 { + tail := result[result.len - 1]; + head := p[0]; + if tail == 47 { + if head == 47 { + p = substr(p, 1, p.len - 1); + } + } else { + if head != 47 { + result = concat(result, "/"); + } + } + } + result = concat(result, p); + } + i += 1; + } + result +} + +struct_to_string :: (s: $T) -> string { + result := concat(type_name(T), "{"); + i := 0; + while i < field_count(T) { + if i > 0 { result = concat(result, ", "); } + result = concat(result, field_name(T, i)); + result = concat(result, ": "); + result = concat(result, any_to_string(field_value(s, i))); + i += 1; + } + concat(result, "}") +} + +vector_to_string :: (v: $T) -> string { + result := "["; + i := 0; + while i < field_count(T) { + if i > 0 { result = concat(result, ", "); } + result = concat(result, any_to_string(field_value(v, i))); + i += 1; + } + concat(result, "]") +} + +array_to_string :: (a: $T) -> string { + result := "["; + i := 0; + while i < field_count(T) { + if i > 0 { result = concat(result, ", "); } + result = concat(result, any_to_string(field_value(a, i))); + i += 1; + } + concat(result, "]") +} + +slice_to_string :: (items: []$T) -> string { + result := "["; + i := 0; + while i < items.len { + if i > 0 { result = concat(result, ", "); } + result = concat(result, any_to_string(field_value(items, i))); + i += 1; + } + concat(result, "]") +} + +pointer_to_string :: (p: $T) -> string { + addr : s64 = xx p; + if addr == 0 { "null" } else { + concat(type_name(T), concat("@0x", int_to_hex_string(addr))) + } +} + +flags_to_string :: (val: $T) -> string { + v := cast(s64) val; + result := ""; + i := 0; + while i < field_count(T) { + fv := field_value_int(T, i); + if v & fv { + if result.len > 0 { result = concat(result, " | "); } + result = concat(result, concat(".", field_name(T, i))); + } + i += 1; + } + if result.len == 0 { result = "0"; } + result +} + +enum_to_string :: (u: $T) -> string { + if is_flags(T) { return flags_to_string(u); } + idx := field_index(T, u); + result := concat(".", field_name(T, idx)); + payload := field_value(u, idx); + pstr := any_to_string(payload); + if pstr.len > 0 { + result = concat(result, concat("(", concat(pstr, ")"))); + } + result +} + +optional_to_string :: (o: $T) -> string { + if o == null { return "null"; } + return any_to_string(o!); +} + +any_to_string :: (val: Any) -> string { + result := ""; + type := type_of(val); + if type == { + case void: result = ""; + case int: { + if type_is_unsigned(type) { result = uint_to_string(xx val); } + else { result = int_to_string(xx val); } + } + case string: { s : string = xx val; result = s; } + case bool: result = bool_to_string(xx val); + case float: result = float_to_string(xx val); + case struct: result = struct_to_string(cast(type) val); + case enum: result = enum_to_string(cast(type) val); + case error_set: { tagid : u32 = xx val; result = error_tag_name(tagid); } + case vector: result = vector_to_string(cast(type) val); + case array: result = array_to_string(cast(type) val); + case slice: result = slice_to_string(cast(type) val); + case pointer: result = pointer_to_string(cast(type) val); + case optional: result = optional_to_string(cast(type) val); + case type: result = type_name(val); + } + result +} + +build_format :: (fmt: string) -> string { + code := "result := \"\"; "; + seg_start := 0; + i := 0; + arg_idx := 0; + while i < fmt.len { + if fmt[i] == 123 { + if i + 1 < fmt.len { + if fmt[i + 1] == 125 { + if i > seg_start { + code = concat(code, "result = concat(result, substr(fmt, "); + code = concat(code, int_to_string(seg_start)); + code = concat(code, ", "); + code = concat(code, int_to_string(i - seg_start)); + code = concat(code, ")); "); + } + code = concat(code, "result = concat(result, any_to_string(args["); + code = concat(code, int_to_string(arg_idx)); + code = concat(code, "])); "); + arg_idx += 1; + i += 2; + seg_start = i; + } else if fmt[i + 1] == 123 { + code = concat(code, "result = concat(result, substr(fmt, "); + code = concat(code, int_to_string(seg_start)); + code = concat(code, ", "); + code = concat(code, int_to_string(i - seg_start + 1)); + code = concat(code, ")); "); + i += 2; + seg_start = i; + } else { + i += 1; + } + } else { + i += 1; + } + } else if fmt[i] == 125 { + if i + 1 < fmt.len { + if fmt[i + 1] == 125 { + code = concat(code, "result = concat(result, substr(fmt, "); + code = concat(code, int_to_string(seg_start)); + code = concat(code, ", "); + code = concat(code, int_to_string(i - seg_start + 1)); + code = concat(code, ")); "); + i += 2; + seg_start = i; + } else { + i += 1; + } + } else { + i += 1; + } + } else { + i += 1; + } + } + if seg_start < fmt.len { + code = concat(code, "result = concat(result, substr(fmt, "); + code = concat(code, int_to_string(seg_start)); + code = concat(code, ", "); + code = concat(code, int_to_string(fmt.len - seg_start)); + code = concat(code, ")); "); + } + code +} + +format :: ($fmt: string, ..$args) -> string { + #insert build_format(fmt); + #insert "return result;"; +} + +print :: ($fmt: string, ..$args) { + #insert build_format(fmt); + #insert "out(result);"; +} diff --git a/library/modules/std/list.sx b/library/modules/std/list.sx new file mode 100644 index 0000000..36a8374 --- /dev/null +++ b/library/modules/std/list.sx @@ -0,0 +1,46 @@ +// The growable container of the prelude. Consumers never import this file +// directly — std.sx re-exports `List`. +#import "modules/std/core.sx"; + +List :: struct ($T: Type) { + items: [*]T = null; + len: s64 = 0; + cap: s64 = 0; + + append :: (list: *List(T), item: T, alloc: Allocator = context.allocator) { + if list.len >= list.cap { + new_cap := if list.cap == 0 then 4 else list.cap * 2; + new_items : [*]T = xx alloc.alloc_bytes(new_cap * size_of(T)); + if list.len > 0 { + memcpy(new_items, list.items, list.len * size_of(T)); + alloc.dealloc_bytes(list.items); + } + list.items = new_items; + list.cap = new_cap; + } + list.items[list.len] = item; + list.len += 1; + } + + ensure_capacity :: (list: *List(T), n: s64, alloc: Allocator = context.allocator) { + if list.cap >= n { return; } + new_cap := if list.cap == 0 then 4 else list.cap; + while new_cap < n { new_cap = new_cap * 2; } + new_items : [*]T = xx alloc.alloc_bytes(new_cap * size_of(T)); + if list.len > 0 { + memcpy(new_items, list.items, list.len * size_of(T)); + alloc.dealloc_bytes(list.items); + } + list.items = new_items; + list.cap = new_cap; + } + + deinit :: (list: *List(T), alloc: Allocator = context.allocator) { + if list.items != null { + alloc.dealloc_bytes(list.items); + } + list.items = null; + list.len = 0; + list.cap = 0; + } +} diff --git a/readme.md b/readme.md index bc42bab..416326d 100644 --- a/readme.md +++ b/readme.md @@ -465,8 +465,11 @@ site.) **Namespace aliases carry one level.** A namespaced import is an ordinary declaration, and flat-importing the module that declares it makes the alias usable in the importer — there is no `pub` keyword. The stdlib prelude uses -exactly this: `#import "modules/std.sx"` gives every bare prelude name -(`print`, `List`, `Context`, …) plus the carried namespaces of std's tail +exactly this: std.sx is itself a pure re-export facade (every bare prelude +name is an alias into the `std/core.sx` / `std/fmt.sx` / `std/list.sx` +part-files), and `#import "modules/std.sx"` gives every bare prelude name +(`print`, `List`, `Context`, …) plus the carried namespaces — the +part-files (`core`, `fmt`, `list`) and std's tail (`mem`, `fs`, `process`, `socket`, `json`, `cli`, `hash`, `xml`, `log`, `test`): ```sx