mirror of
https://github.com/roc-lang/roc.git
synced 2025-08-03 11:52:19 +00:00
Merge pull request #7211 from roc-lang/effectful-builtins
Effectful builtin helpers
This commit is contained in:
commit
fe6790e66e
53 changed files with 1561 additions and 1422 deletions
|
@ -978,6 +978,39 @@ mod cli_tests {
|
|||
None,
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[cfg_attr(windows, ignore)]
|
||||
fn effectful_on_err() {
|
||||
build_platform_host();
|
||||
|
||||
let cli_build = ExecCli::new(
|
||||
roc_cli::CMD_DEV,
|
||||
file_from_root("crates/cli/tests/test-projects/effectful", "on_err.roc"),
|
||||
);
|
||||
|
||||
let expected_output = "Enter your password:\nLOG: Failed login attempt\n";
|
||||
|
||||
cli_build.check_build_and_run(expected_output, ALLOW_VALGRIND, Some("42"), None);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[cfg_attr(windows, ignore)]
|
||||
fn effectful_for_each_try() {
|
||||
build_platform_host();
|
||||
|
||||
let cli_build = ExecCli::new(
|
||||
roc_cli::CMD_DEV,
|
||||
file_from_root(
|
||||
"crates/cli/tests/test-projects/effectful",
|
||||
"for_each_try.roc",
|
||||
),
|
||||
);
|
||||
|
||||
let expected_output = "✅ 0\n✅ 2\n✅ 4\n✅ 6\n✅ 8\n9 is not even! ABORT!\n";
|
||||
|
||||
cli_build.check_build_and_run(expected_output, ALLOW_VALGRIND, None, None);
|
||||
}
|
||||
}
|
||||
|
||||
// this is for testing the benchmarks (on small inputs), to perform proper benchmarks see crates/cli/benches/README.md
|
||||
|
|
23
crates/cli/tests/test-projects/effectful/for_each_try.roc
Normal file
23
crates/cli/tests/test-projects/effectful/for_each_try.roc
Normal file
|
@ -0,0 +1,23 @@
|
|||
app [main!] { pf: platform "../test-platform-effects-zig/main.roc" }
|
||||
|
||||
import pf.Effect
|
||||
|
||||
main! : {} => {}
|
||||
main! = \{} ->
|
||||
good = [0, 2, 4] |> List.forEachTry! validate!
|
||||
expect good == Ok {}
|
||||
|
||||
bad = [6, 8, 9, 10] |> List.forEachTry! validate!
|
||||
expect bad == Err 9
|
||||
|
||||
{}
|
||||
|
||||
validate! : U32 => Result {} U32
|
||||
validate! = \x ->
|
||||
if Num.isEven x then
|
||||
Effect.putLine! "✅ $(Num.toStr x)"
|
||||
Ok {}
|
||||
|
||||
else
|
||||
Effect.putLine! "$(Num.toStr x) is not even! ABORT!"
|
||||
Err x
|
24
crates/cli/tests/test-projects/effectful/on_err.roc
Normal file
24
crates/cli/tests/test-projects/effectful/on_err.roc
Normal file
|
@ -0,0 +1,24 @@
|
|||
app [main!] { pf: platform "../test-platform-effects-zig/main.roc" }
|
||||
|
||||
import pf.Effect
|
||||
|
||||
main! : {} => {}
|
||||
main! = \{} ->
|
||||
_ =
|
||||
authenticate! {}
|
||||
|> Result.onErr! \BadPass ->
|
||||
Effect.putLine! "LOG: Failed login attempt"
|
||||
Ok "Bad password"
|
||||
|
||||
{}
|
||||
|
||||
authenticate! : {} => Result Str [BadPass]
|
||||
authenticate! = \{} ->
|
||||
Effect.putLine! "Enter your password:"
|
||||
|
||||
password = Effect.getLine! {}
|
||||
|
||||
if password == "password" then
|
||||
Ok "You are in"
|
||||
else
|
||||
Err BadPass
|
|
@ -5,7 +5,7 @@ import pf.Effect
|
|||
main! : {} => {}
|
||||
main! = \{} ->
|
||||
["Welcome!", "What's your name?"]
|
||||
|> forEach! Effect.putLine!
|
||||
|> List.forEach! Effect.putLine!
|
||||
|
||||
line = Effect.getLine! {}
|
||||
|
||||
|
@ -17,11 +17,3 @@ main! = \{} ->
|
|||
|
||||
Effect.putLine! "You entered: $(line)"
|
||||
Effect.putLine! "It is known"
|
||||
|
||||
forEach! : List a, (a => {}) => {}
|
||||
forEach! = \l, f! ->
|
||||
when l is
|
||||
[] -> {}
|
||||
[x, .. as xs] ->
|
||||
f! x
|
||||
forEach! xs f!
|
||||
|
|
|
@ -70,6 +70,8 @@ module [
|
|||
countIf,
|
||||
chunksOf,
|
||||
concatUtf8,
|
||||
forEach!,
|
||||
forEachTry!,
|
||||
]
|
||||
|
||||
import Bool exposing [Bool, Eq]
|
||||
|
@ -1383,3 +1385,44 @@ concatUtf8 : List U8, Str -> List U8
|
|||
|
||||
expect (List.concatUtf8 [1, 2, 3, 4] "🐦") == [1, 2, 3, 4, 240, 159, 144, 166]
|
||||
|
||||
## Run an effectful function for each element on the list.
|
||||
##
|
||||
## ```roc
|
||||
## List.forEach! ["Alice", "Bob", "Charlie"] \name ->
|
||||
## createAccount! name
|
||||
## log! "Account created"
|
||||
## ```
|
||||
##
|
||||
## If the function might fail or you need to return early, use [forEachTry!].
|
||||
forEach! : List a, (a => {}) => {}
|
||||
forEach! = \list, func! ->
|
||||
when list is
|
||||
[] ->
|
||||
{}
|
||||
|
||||
[elem, .. as rest] ->
|
||||
func! elem
|
||||
forEach! rest func!
|
||||
|
||||
## Run an effectful function that might fail for each element on the list.
|
||||
##
|
||||
## If the function returns `Err`, the iteration stops and the error is returned.
|
||||
##
|
||||
## ```roc
|
||||
## List.forEachTry! filesToDelete \path ->
|
||||
## try File.delete! path
|
||||
## Stdout.line! "$(path) deleted"
|
||||
## ```
|
||||
forEachTry! : List a, (a => Result {} err) => Result {} err
|
||||
forEachTry! = \list, func! ->
|
||||
when list is
|
||||
[] ->
|
||||
Ok {}
|
||||
|
||||
[elem, .. as rest] ->
|
||||
when func! elem is
|
||||
Ok {} ->
|
||||
forEachTry! rest func!
|
||||
|
||||
Err err ->
|
||||
Err err
|
||||
|
|
|
@ -8,6 +8,7 @@ module [
|
|||
map2,
|
||||
try,
|
||||
onErr,
|
||||
onErr!,
|
||||
withDefault,
|
||||
]
|
||||
|
||||
|
@ -119,3 +120,16 @@ onErr = \result, transform ->
|
|||
when result is
|
||||
Ok v -> Ok v
|
||||
Err e -> transform e
|
||||
|
||||
## Like [onErr], but it allows the transformation function to produce effects.
|
||||
##
|
||||
## ```roc
|
||||
## Result.onErr (Err "missing user") \msg ->
|
||||
## try Stdout.line! "ERROR: $(msg)"
|
||||
## Err msg
|
||||
## ```
|
||||
onErr! : Result a err, (err => Result a otherErr) => Result a otherErr
|
||||
onErr! = \result, transform! ->
|
||||
when result is
|
||||
Ok v -> Ok v
|
||||
Err e -> transform! e
|
||||
|
|
|
@ -5098,6 +5098,14 @@ fn canonicalize_and_constrain<'a>(
|
|||
|
||||
let mut var_store = VarStore::default();
|
||||
|
||||
let fx_mode = if module_id.is_builtin() {
|
||||
// Allow builtins to expose effectful functions
|
||||
// even if platform is `Task`-based
|
||||
FxMode::PurityInference
|
||||
} else {
|
||||
fx_mode
|
||||
};
|
||||
|
||||
let mut module_output = canonicalize_module_defs(
|
||||
arena,
|
||||
parsed_defs,
|
||||
|
|
|
@ -1509,7 +1509,8 @@ define_builtins! {
|
|||
87 LIST_CLONE: "clone"
|
||||
88 LIST_LEN_USIZE: "lenUsize"
|
||||
89 LIST_CONCAT_UTF8: "concatUtf8"
|
||||
90 LIST_WALK_FX: "walk!"
|
||||
90 LIST_FOR_EACH_FX: "forEach!"
|
||||
91 LIST_FOR_EACH_TRY_FX: "forEachTry!"
|
||||
}
|
||||
7 RESULT: "Result" => {
|
||||
0 RESULT_RESULT: "Result" exposed_type=true // the Result.Result type alias
|
||||
|
@ -1522,6 +1523,7 @@ define_builtins! {
|
|||
7 RESULT_IS_OK: "isOk"
|
||||
8 RESULT_MAP_BOTH: "mapBoth"
|
||||
9 RESULT_MAP_TWO: "map2"
|
||||
10 RESULT_ON_ERR_FX: "onErr!"
|
||||
}
|
||||
8 DICT: "Dict" => {
|
||||
0 DICT_DICT: "Dict" exposed_type=true // the Dict.Dict type alias
|
||||
|
|
|
@ -2,81 +2,81 @@ procedure Bool.11 (#Attr.2, #Attr.3):
|
|||
let Bool.23 : Int1 = lowlevel Eq #Attr.2 #Attr.3;
|
||||
ret Bool.23;
|
||||
|
||||
procedure List.111 (List.540, List.541, List.542):
|
||||
let List.644 : U64 = 0i64;
|
||||
let List.645 : U64 = CallByName List.6 List.540;
|
||||
let List.643 : [C U64, C U64] = CallByName List.80 List.540 List.541 List.542 List.644 List.645;
|
||||
ret List.643;
|
||||
procedure List.112 (List.541, List.542, List.543):
|
||||
let List.656 : U64 = 0i64;
|
||||
let List.657 : U64 = CallByName List.6 List.541;
|
||||
let List.655 : [C U64, C U64] = CallByName List.80 List.541 List.542 List.543 List.656 List.657;
|
||||
ret List.655;
|
||||
|
||||
procedure List.26 (List.208, List.209, List.210):
|
||||
let List.637 : [C U64, C U64] = CallByName List.111 List.208 List.209 List.210;
|
||||
let List.640 : U8 = 1i64;
|
||||
let List.641 : U8 = GetTagId List.637;
|
||||
let List.642 : Int1 = lowlevel Eq List.640 List.641;
|
||||
if List.642 then
|
||||
let List.211 : U64 = UnionAtIndex (Id 1) (Index 0) List.637;
|
||||
ret List.211;
|
||||
else
|
||||
let List.212 : U64 = UnionAtIndex (Id 0) (Index 0) List.637;
|
||||
procedure List.26 (List.209, List.210, List.211):
|
||||
let List.649 : [C U64, C U64] = CallByName List.112 List.209 List.210 List.211;
|
||||
let List.652 : U8 = 1i64;
|
||||
let List.653 : U8 = GetTagId List.649;
|
||||
let List.654 : Int1 = lowlevel Eq List.652 List.653;
|
||||
if List.654 then
|
||||
let List.212 : U64 = UnionAtIndex (Id 1) (Index 0) List.649;
|
||||
ret List.212;
|
||||
else
|
||||
let List.213 : U64 = UnionAtIndex (Id 0) (Index 0) List.649;
|
||||
ret List.213;
|
||||
|
||||
procedure List.38 (List.396, List.397):
|
||||
let List.636 : U64 = CallByName List.6 List.396;
|
||||
let List.398 : U64 = CallByName Num.77 List.636 List.397;
|
||||
let List.626 : List U8 = CallByName List.43 List.396 List.398;
|
||||
ret List.626;
|
||||
procedure List.38 (List.397, List.398):
|
||||
let List.648 : U64 = CallByName List.6 List.397;
|
||||
let List.399 : U64 = CallByName Num.77 List.648 List.398;
|
||||
let List.638 : List U8 = CallByName List.43 List.397 List.399;
|
||||
ret List.638;
|
||||
|
||||
procedure List.43 (List.394, List.395):
|
||||
let List.634 : U64 = CallByName List.6 List.394;
|
||||
let List.633 : U64 = CallByName Num.77 List.634 List.395;
|
||||
let List.628 : {U64, U64} = Struct {List.395, List.633};
|
||||
let List.627 : List U8 = CallByName List.49 List.394 List.628;
|
||||
ret List.627;
|
||||
procedure List.43 (List.395, List.396):
|
||||
let List.646 : U64 = CallByName List.6 List.395;
|
||||
let List.645 : U64 = CallByName Num.77 List.646 List.396;
|
||||
let List.640 : {U64, U64} = Struct {List.396, List.645};
|
||||
let List.639 : List U8 = CallByName List.49 List.395 List.640;
|
||||
ret List.639;
|
||||
|
||||
procedure List.49 (List.472, List.473):
|
||||
let List.630 : U64 = StructAtIndex 1 List.473;
|
||||
let List.631 : U64 = StructAtIndex 0 List.473;
|
||||
let List.629 : List U8 = CallByName List.72 List.472 List.630 List.631;
|
||||
ret List.629;
|
||||
procedure List.49 (List.473, List.474):
|
||||
let List.642 : U64 = StructAtIndex 1 List.474;
|
||||
let List.643 : U64 = StructAtIndex 0 List.474;
|
||||
let List.641 : List U8 = CallByName List.72 List.473 List.642 List.643;
|
||||
ret List.641;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.635 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.635;
|
||||
let List.647 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.647;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.658 : U8 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.658;
|
||||
let List.670 : U8 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.670;
|
||||
|
||||
procedure List.72 (#Attr.2, #Attr.3, #Attr.4):
|
||||
let List.632 : List U8 = lowlevel ListSublist #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.632;
|
||||
let List.644 : List U8 = lowlevel ListSublist #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.644;
|
||||
|
||||
procedure List.80 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.646 List.543 List.544 List.545 List.546 List.547:
|
||||
let List.648 : Int1 = CallByName Num.22 List.546 List.547;
|
||||
if List.648 then
|
||||
let List.657 : U8 = CallByName List.66 List.543 List.546;
|
||||
let List.649 : [C U64, C U64] = CallByName Test.4 List.544 List.657;
|
||||
let List.654 : U8 = 1i64;
|
||||
let List.655 : U8 = GetTagId List.649;
|
||||
let List.656 : Int1 = lowlevel Eq List.654 List.655;
|
||||
if List.656 then
|
||||
let List.548 : U64 = UnionAtIndex (Id 1) (Index 0) List.649;
|
||||
let List.652 : U64 = 1i64;
|
||||
let List.651 : U64 = CallByName Num.51 List.546 List.652;
|
||||
jump List.646 List.543 List.548 List.545 List.651 List.547;
|
||||
joinpoint List.658 List.544 List.545 List.546 List.547 List.548:
|
||||
let List.660 : Int1 = CallByName Num.22 List.547 List.548;
|
||||
if List.660 then
|
||||
let List.669 : U8 = CallByName List.66 List.544 List.547;
|
||||
let List.661 : [C U64, C U64] = CallByName Test.4 List.545 List.669;
|
||||
let List.666 : U8 = 1i64;
|
||||
let List.667 : U8 = GetTagId List.661;
|
||||
let List.668 : Int1 = lowlevel Eq List.666 List.667;
|
||||
if List.668 then
|
||||
let List.549 : U64 = UnionAtIndex (Id 1) (Index 0) List.661;
|
||||
let List.664 : U64 = 1i64;
|
||||
let List.663 : U64 = CallByName Num.51 List.547 List.664;
|
||||
jump List.658 List.544 List.549 List.546 List.663 List.548;
|
||||
else
|
||||
dec List.543;
|
||||
let List.549 : U64 = UnionAtIndex (Id 0) (Index 0) List.649;
|
||||
let List.653 : [C U64, C U64] = TagId(0) List.549;
|
||||
ret List.653;
|
||||
dec List.544;
|
||||
let List.550 : U64 = UnionAtIndex (Id 0) (Index 0) List.661;
|
||||
let List.665 : [C U64, C U64] = TagId(0) List.550;
|
||||
ret List.665;
|
||||
else
|
||||
dec List.543;
|
||||
let List.647 : [C U64, C U64] = TagId(1) List.544;
|
||||
ret List.647;
|
||||
dec List.544;
|
||||
let List.659 : [C U64, C U64] = TagId(1) List.545;
|
||||
ret List.659;
|
||||
in
|
||||
inc #Derived_gen.0;
|
||||
jump List.646 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
jump List.658 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.284 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,51 +1,51 @@
|
|||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.630 : U64 = 0i64;
|
||||
let List.631 : U64 = CallByName List.6 List.167;
|
||||
let List.629 : List {} = CallByName List.96 List.167 List.168 List.169 List.630 List.631;
|
||||
ret List.629;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.642 : U64 = 0i64;
|
||||
let List.643 : U64 = CallByName List.6 List.168;
|
||||
let List.641 : List {} = CallByName List.97 List.168 List.169 List.170 List.642 List.643;
|
||||
ret List.641;
|
||||
|
||||
procedure List.279 (List.280, List.281, List.277):
|
||||
let List.643 : {} = CallByName Test.2 List.281;
|
||||
let List.642 : List {} = CallByName List.71 List.280 List.643;
|
||||
ret List.642;
|
||||
procedure List.280 (List.281, List.282, List.278):
|
||||
let List.655 : {} = CallByName Test.2 List.282;
|
||||
let List.654 : List {} = CallByName List.71 List.281 List.655;
|
||||
ret List.654;
|
||||
|
||||
procedure List.5 (List.276, List.277):
|
||||
let List.278 : U64 = CallByName List.6 List.276;
|
||||
let List.627 : List {} = CallByName List.68 List.278;
|
||||
let List.626 : List {} = CallByName List.18 List.276 List.627 List.277;
|
||||
ret List.626;
|
||||
procedure List.5 (List.277, List.278):
|
||||
let List.279 : U64 = CallByName List.6 List.277;
|
||||
let List.639 : List {} = CallByName List.68 List.279;
|
||||
let List.638 : List {} = CallByName List.18 List.277 List.639 List.278;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.640 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.640;
|
||||
let List.652 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.652;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.639 : [] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.639;
|
||||
let List.651 : [] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.651;
|
||||
|
||||
procedure List.68 (#Attr.2):
|
||||
let List.645 : List {} = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.645;
|
||||
let List.657 : List {} = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.657;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.644 : List {} = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.644;
|
||||
let List.656 : List {} = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.656;
|
||||
|
||||
procedure List.96 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.632 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.634 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.634 then
|
||||
let List.638 : [] = CallByName List.66 List.170 List.173;
|
||||
let List.175 : List {} = CallByName List.279 List.171 List.638 List.172;
|
||||
let List.637 : U64 = 1i64;
|
||||
let List.636 : U64 = CallByName Num.51 List.173 List.637;
|
||||
jump List.632 List.170 List.175 List.172 List.636 List.174;
|
||||
procedure List.97 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.644 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.646 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.646 then
|
||||
let List.650 : [] = CallByName List.66 List.171 List.174;
|
||||
let List.176 : List {} = CallByName List.280 List.172 List.650 List.173;
|
||||
let List.649 : U64 = 1i64;
|
||||
let List.648 : U64 = CallByName Num.51 List.174 List.649;
|
||||
jump List.644 List.171 List.176 List.173 List.648 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.0;
|
||||
jump List.632 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
jump List.644 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,51 +1,51 @@
|
|||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.630 : U64 = 0i64;
|
||||
let List.631 : U64 = CallByName List.6 List.167;
|
||||
let List.629 : List [] = CallByName List.96 List.167 List.168 List.169 List.630 List.631;
|
||||
ret List.629;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.642 : U64 = 0i64;
|
||||
let List.643 : U64 = CallByName List.6 List.168;
|
||||
let List.641 : List [] = CallByName List.97 List.168 List.169 List.170 List.642 List.643;
|
||||
ret List.641;
|
||||
|
||||
procedure List.279 (List.280, List.281, List.277):
|
||||
let List.643 : [] = CallByName Test.2 List.281;
|
||||
let List.642 : List [] = CallByName List.71 List.280 List.643;
|
||||
ret List.642;
|
||||
procedure List.280 (List.281, List.282, List.278):
|
||||
let List.655 : [] = CallByName Test.2 List.282;
|
||||
let List.654 : List [] = CallByName List.71 List.281 List.655;
|
||||
ret List.654;
|
||||
|
||||
procedure List.5 (List.276, List.277):
|
||||
let List.278 : U64 = CallByName List.6 List.276;
|
||||
let List.627 : List [] = CallByName List.68 List.278;
|
||||
let List.626 : List [] = CallByName List.18 List.276 List.627 List.277;
|
||||
ret List.626;
|
||||
procedure List.5 (List.277, List.278):
|
||||
let List.279 : U64 = CallByName List.6 List.277;
|
||||
let List.639 : List [] = CallByName List.68 List.279;
|
||||
let List.638 : List [] = CallByName List.18 List.277 List.639 List.278;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.640 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.640;
|
||||
let List.652 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.652;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.639 : [] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.639;
|
||||
let List.651 : [] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.651;
|
||||
|
||||
procedure List.68 (#Attr.2):
|
||||
let List.645 : List [] = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.645;
|
||||
let List.657 : List [] = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.657;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.644 : List [] = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.644;
|
||||
let List.656 : List [] = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.656;
|
||||
|
||||
procedure List.96 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.632 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.634 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.634 then
|
||||
let List.638 : [] = CallByName List.66 List.170 List.173;
|
||||
let List.175 : List [] = CallByName List.279 List.171 List.638 List.172;
|
||||
let List.637 : U64 = 1i64;
|
||||
let List.636 : U64 = CallByName Num.51 List.173 List.637;
|
||||
jump List.632 List.170 List.175 List.172 List.636 List.174;
|
||||
procedure List.97 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.644 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.646 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.646 then
|
||||
let List.650 : [] = CallByName List.66 List.171 List.174;
|
||||
let List.176 : List [] = CallByName List.280 List.172 List.650 List.173;
|
||||
let List.649 : U64 = 1i64;
|
||||
let List.648 : U64 = CallByName Num.51 List.174 List.649;
|
||||
jump List.644 List.171 List.176 List.173 List.648 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.0;
|
||||
jump List.632 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
jump List.644 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,32 +1,32 @@
|
|||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : [<r>C {}, C *self {{}, []}] = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : [<r>C {}, C *self {{}, []}] = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.637 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.637;
|
||||
let List.649 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.649;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : [] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : [] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.96 (#Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16, #Derived_gen.17):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : [] = CallByName List.66 List.170 List.173;
|
||||
let List.175 : [<r>C {}, C *self {{}, []}] = CallByName Test.29 List.171 List.635 List.172;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16, #Derived_gen.17):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : [] = CallByName List.66 List.171 List.174;
|
||||
let List.176 : [<r>C {}, C *self {{}, []}] = CallByName Test.29 List.172 List.647 List.173;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.13;
|
||||
jump List.629 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17;
|
||||
jump List.641 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -2,92 +2,92 @@ procedure Bool.1 ():
|
|||
let Bool.24 : Int1 = false;
|
||||
ret Bool.24;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.646 : U64 = 0i64;
|
||||
let List.647 : U64 = CallByName List.6 List.167;
|
||||
let List.645 : List Str = CallByName List.96 List.167 List.168 List.169 List.646 List.647;
|
||||
ret List.645;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.658 : U64 = 0i64;
|
||||
let List.659 : U64 = CallByName List.6 List.168;
|
||||
let List.657 : List Str = CallByName List.97 List.168 List.169 List.170 List.658 List.659;
|
||||
ret List.657;
|
||||
|
||||
procedure List.2 (List.115, List.116):
|
||||
let List.640 : U64 = CallByName List.6 List.115;
|
||||
let List.636 : Int1 = CallByName Num.22 List.116 List.640;
|
||||
if List.636 then
|
||||
let List.638 : Str = CallByName List.66 List.115 List.116;
|
||||
inc List.638;
|
||||
let List.637 : [C {}, C Str] = TagId(1) List.638;
|
||||
ret List.637;
|
||||
procedure List.2 (List.116, List.117):
|
||||
let List.652 : U64 = CallByName List.6 List.116;
|
||||
let List.648 : Int1 = CallByName Num.22 List.117 List.652;
|
||||
if List.648 then
|
||||
let List.650 : Str = CallByName List.66 List.116 List.117;
|
||||
inc List.650;
|
||||
let List.649 : [C {}, C Str] = TagId(1) List.650;
|
||||
ret List.649;
|
||||
else
|
||||
let List.635 : {} = Struct {};
|
||||
let List.634 : [C {}, C Str] = TagId(0) List.635;
|
||||
ret List.634;
|
||||
let List.647 : {} = Struct {};
|
||||
let List.646 : [C {}, C Str] = TagId(0) List.647;
|
||||
ret List.646;
|
||||
|
||||
procedure List.279 (List.280, List.281, List.277):
|
||||
let List.659 : Str = CallByName Test.10 List.281;
|
||||
let List.658 : List Str = CallByName List.71 List.280 List.659;
|
||||
ret List.658;
|
||||
procedure List.280 (List.281, List.282, List.278):
|
||||
let List.671 : Str = CallByName Test.10 List.282;
|
||||
let List.670 : List Str = CallByName List.71 List.281 List.671;
|
||||
ret List.670;
|
||||
|
||||
procedure List.5 (List.276, List.277):
|
||||
let List.278 : U64 = CallByName List.6 List.276;
|
||||
let List.643 : List Str = CallByName List.68 List.278;
|
||||
let List.642 : List Str = CallByName List.18 List.276 List.643 List.277;
|
||||
ret List.642;
|
||||
procedure List.5 (List.277, List.278):
|
||||
let List.279 : U64 = CallByName List.6 List.277;
|
||||
let List.655 : List Str = CallByName List.68 List.279;
|
||||
let List.654 : List Str = CallByName List.18 List.277 List.655 List.278;
|
||||
ret List.654;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.641 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.641;
|
||||
let List.653 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.653;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.656 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.656;
|
||||
let List.668 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.668;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.639 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.639;
|
||||
let List.651 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.651;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.655 : [<r>C List [<r>C List *self, C *self], C [<r>C List *self, C *self]] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.655;
|
||||
let List.667 : [<r>C List [<r>C List *self, C *self], C [<r>C List *self, C *self]] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.667;
|
||||
|
||||
procedure List.68 (#Attr.2):
|
||||
let List.661 : List Str = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.661;
|
||||
let List.673 : List Str = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.673;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.660 : List Str = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.660;
|
||||
let List.672 : List Str = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.672;
|
||||
|
||||
procedure List.9 (List.387):
|
||||
let List.633 : U64 = 0i64;
|
||||
let List.626 : [C {}, C Str] = CallByName List.2 List.387 List.633;
|
||||
let List.630 : U8 = 1i64;
|
||||
let List.631 : U8 = GetTagId List.626;
|
||||
let List.632 : Int1 = lowlevel Eq List.630 List.631;
|
||||
if List.632 then
|
||||
let List.388 : Str = UnionAtIndex (Id 1) (Index 0) List.626;
|
||||
let List.627 : [C {}, C Str] = TagId(1) List.388;
|
||||
ret List.627;
|
||||
procedure List.9 (List.388):
|
||||
let List.645 : U64 = 0i64;
|
||||
let List.638 : [C {}, C Str] = CallByName List.2 List.388 List.645;
|
||||
let List.642 : U8 = 1i64;
|
||||
let List.643 : U8 = GetTagId List.638;
|
||||
let List.644 : Int1 = lowlevel Eq List.642 List.643;
|
||||
if List.644 then
|
||||
let List.389 : Str = UnionAtIndex (Id 1) (Index 0) List.638;
|
||||
let List.639 : [C {}, C Str] = TagId(1) List.389;
|
||||
ret List.639;
|
||||
else
|
||||
dec List.626;
|
||||
let List.629 : {} = Struct {};
|
||||
let List.628 : [C {}, C Str] = TagId(0) List.629;
|
||||
ret List.628;
|
||||
dec List.638;
|
||||
let List.641 : {} = Struct {};
|
||||
let List.640 : [C {}, C Str] = TagId(0) List.641;
|
||||
ret List.640;
|
||||
|
||||
procedure List.96 (#Derived_gen.3, #Derived_gen.4, #Derived_gen.5, #Derived_gen.6, #Derived_gen.7):
|
||||
joinpoint List.648 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.650 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.650 then
|
||||
let List.654 : [<r>C List [<r>C List *self, C *self], C [<r>C List *self, C *self]] = CallByName List.66 List.170 List.173;
|
||||
inc List.654;
|
||||
let List.175 : List Str = CallByName List.279 List.171 List.654 List.172;
|
||||
let List.653 : U64 = 1i64;
|
||||
let List.652 : U64 = CallByName Num.51 List.173 List.653;
|
||||
jump List.648 List.170 List.175 List.172 List.652 List.174;
|
||||
procedure List.97 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.660 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.662 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.662 then
|
||||
let List.666 : [<r>C List [<r>C List *self, C *self], C [<r>C List *self, C *self]] = CallByName List.66 List.171 List.174;
|
||||
inc List.666;
|
||||
let List.176 : List Str = CallByName List.280 List.172 List.666 List.173;
|
||||
let List.665 : U64 = 1i64;
|
||||
let List.664 : U64 = CallByName Num.51 List.174 List.665;
|
||||
jump List.660 List.171 List.176 List.173 List.664 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.3;
|
||||
jump List.648 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5 #Derived_gen.6 #Derived_gen.7;
|
||||
inc #Derived_gen.0;
|
||||
jump List.660 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
@ -97,17 +97,17 @@ procedure Num.51 (#Attr.2, #Attr.3):
|
|||
let Num.283 : U64 = lowlevel NumAddWrap #Attr.2 #Attr.3;
|
||||
ret Num.283;
|
||||
|
||||
procedure Result.5 (Result.13, Result.14):
|
||||
let Result.57 : U8 = 1i64;
|
||||
let Result.58 : U8 = GetTagId Result.13;
|
||||
let Result.59 : Int1 = lowlevel Eq Result.57 Result.58;
|
||||
if Result.59 then
|
||||
dec Result.14;
|
||||
let Result.15 : Str = UnionAtIndex (Id 1) (Index 0) Result.13;
|
||||
ret Result.15;
|
||||
procedure Result.5 (Result.14, Result.15):
|
||||
let Result.63 : U8 = 1i64;
|
||||
let Result.64 : U8 = GetTagId Result.14;
|
||||
let Result.65 : Int1 = lowlevel Eq Result.63 Result.64;
|
||||
if Result.65 then
|
||||
dec Result.15;
|
||||
let Result.16 : Str = UnionAtIndex (Id 1) (Index 0) Result.14;
|
||||
ret Result.16;
|
||||
else
|
||||
dec Result.13;
|
||||
ret Result.14;
|
||||
dec Result.14;
|
||||
ret Result.15;
|
||||
|
||||
procedure Test.10 (Test.11):
|
||||
let Test.12 : Str = CallByName Test.2 Test.11;
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
procedure List.6 (#Attr.2):
|
||||
let List.626 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.626;
|
||||
let List.638 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.638;
|
||||
|
||||
procedure Test.1 (Test.5):
|
||||
let Test.2 : I64 = 41i64;
|
||||
|
|
|
@ -2,35 +2,35 @@ procedure Bool.2 ():
|
|||
let Bool.23 : Int1 = true;
|
||||
ret Bool.23;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : [<rnw><null>, C *self Int1, C *self Int1] = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : [<rnw><null>, C *self Int1, C *self Int1] = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.637 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.637;
|
||||
let List.649 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.649;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : Int1 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : Int1 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.96 (#Derived_gen.5, #Derived_gen.6, #Derived_gen.7, #Derived_gen.8, #Derived_gen.9):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : Int1 = CallByName List.66 List.170 List.173;
|
||||
let List.175 : [<rnw><null>, C *self Int1, C *self Int1] = CallByName Test.6 List.171 List.635 List.172;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.7, #Derived_gen.8, #Derived_gen.9, #Derived_gen.10, #Derived_gen.11):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : Int1 = CallByName List.66 List.171 List.174;
|
||||
let List.176 : [<rnw><null>, C *self Int1, C *self Int1] = CallByName Test.6 List.172 List.647 List.173;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.5;
|
||||
jump List.629 #Derived_gen.5 #Derived_gen.6 #Derived_gen.7 #Derived_gen.8 #Derived_gen.9;
|
||||
inc #Derived_gen.7;
|
||||
jump List.641 #Derived_gen.7 #Derived_gen.8 #Derived_gen.9 #Derived_gen.10 #Derived_gen.11;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
4
crates/compiler/test_mono/generated/dict.txt
generated
4
crates/compiler/test_mono/generated/dict.txt
generated
|
@ -26,8 +26,8 @@ procedure Dict.52 ():
|
|||
ret Dict.743;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.626 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.626;
|
||||
let List.638 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.638;
|
||||
|
||||
procedure Num.75 (#Attr.2, #Attr.3):
|
||||
let Num.281 : U8 = lowlevel NumSubWrap #Attr.2 #Attr.3;
|
||||
|
|
|
@ -2,25 +2,25 @@ procedure Bool.1 ():
|
|||
let Bool.23 : Int1 = false;
|
||||
ret Bool.23;
|
||||
|
||||
procedure List.2 (List.115, List.116):
|
||||
let List.632 : U64 = CallByName List.6 List.115;
|
||||
let List.628 : Int1 = CallByName Num.22 List.116 List.632;
|
||||
if List.628 then
|
||||
let List.630 : {} = CallByName List.66 List.115 List.116;
|
||||
let List.629 : [C {}, C {}] = TagId(1) List.630;
|
||||
ret List.629;
|
||||
procedure List.2 (List.116, List.117):
|
||||
let List.644 : U64 = CallByName List.6 List.116;
|
||||
let List.640 : Int1 = CallByName Num.22 List.117 List.644;
|
||||
if List.640 then
|
||||
let List.642 : {} = CallByName List.66 List.116 List.117;
|
||||
let List.641 : [C {}, C {}] = TagId(1) List.642;
|
||||
ret List.641;
|
||||
else
|
||||
let List.627 : {} = Struct {};
|
||||
let List.626 : [C {}, C {}] = TagId(0) List.627;
|
||||
ret List.626;
|
||||
let List.639 : {} = Struct {};
|
||||
let List.638 : [C {}, C {}] = TagId(0) List.639;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.633 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.633;
|
||||
let List.645 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.645;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.631 : {} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.631;
|
||||
let List.643 : {} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.643;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.281 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
18
crates/compiler/test_mono/generated/encode.txt
generated
18
crates/compiler/test_mono/generated/encode.txt
generated
|
@ -1,16 +1,16 @@
|
|||
procedure List.4 (List.131, List.132):
|
||||
let List.629 : U64 = 1i64;
|
||||
let List.627 : List U8 = CallByName List.70 List.131 List.629;
|
||||
let List.626 : List U8 = CallByName List.71 List.627 List.132;
|
||||
ret List.626;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.641 : U64 = 1i64;
|
||||
let List.639 : List U8 = CallByName List.70 List.132 List.641;
|
||||
let List.638 : List U8 = CallByName List.71 List.639 List.133;
|
||||
ret List.638;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.630 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.630;
|
||||
let List.642 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.642;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.628 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.628;
|
||||
let List.640 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.640;
|
||||
|
||||
procedure Test.23 (Test.24, Test.35, Test.22):
|
||||
let Test.37 : List U8 = CallByName List.4 Test.24 Test.22;
|
||||
|
|
|
@ -67,85 +67,85 @@ procedure Encode.26 (Encode.107, Encode.108):
|
|||
let Encode.110 : List U8 = CallByName Encode.24 Encode.111 Encode.112 Encode.108;
|
||||
ret Encode.110;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : List U8 = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : List U8 = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.653 : U64 = 0i64;
|
||||
let List.654 : U64 = CallByName List.6 List.167;
|
||||
let List.652 : List U8 = CallByName List.96 List.167 List.168 List.169 List.653 List.654;
|
||||
ret List.652;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.665 : U64 = 0i64;
|
||||
let List.666 : U64 = CallByName List.6 List.168;
|
||||
let List.664 : List U8 = CallByName List.97 List.168 List.169 List.170 List.665 List.666;
|
||||
ret List.664;
|
||||
|
||||
procedure List.4 (List.131, List.132):
|
||||
let List.674 : U64 = 1i64;
|
||||
let List.673 : List U8 = CallByName List.70 List.131 List.674;
|
||||
let List.672 : List U8 = CallByName List.71 List.673 List.132;
|
||||
ret List.672;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.686 : U64 = 1i64;
|
||||
let List.685 : List U8 = CallByName List.70 List.132 List.686;
|
||||
let List.684 : List U8 = CallByName List.71 List.685 List.133;
|
||||
ret List.684;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.651 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.651;
|
||||
let List.663 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.663;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.677 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.677;
|
||||
let List.689 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.689;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.662 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.662;
|
||||
let List.674 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.674;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.668 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.668;
|
||||
let List.680 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.680;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.666 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.666;
|
||||
let List.678 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.678;
|
||||
|
||||
procedure List.8 (#Attr.2, #Attr.3):
|
||||
let List.676 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.676;
|
||||
let List.688 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.688;
|
||||
|
||||
procedure List.96 (#Derived_gen.29, #Derived_gen.30, #Derived_gen.31, #Derived_gen.32, #Derived_gen.33):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : {Str, Str} = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : List U8 = CallByName Test.71 List.171 List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.29, #Derived_gen.30, #Derived_gen.31, #Derived_gen.32, #Derived_gen.33):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : {Str, Str} = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : List U8 = CallByName Test.71 List.172 List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.29;
|
||||
jump List.629 #Derived_gen.29 #Derived_gen.30 #Derived_gen.31 #Derived_gen.32 #Derived_gen.33;
|
||||
jump List.641 #Derived_gen.29 #Derived_gen.30 #Derived_gen.31 #Derived_gen.32 #Derived_gen.33;
|
||||
|
||||
procedure List.96 (#Derived_gen.34, #Derived_gen.35, #Derived_gen.36, #Derived_gen.37, #Derived_gen.38):
|
||||
joinpoint List.655 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.657 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.657 then
|
||||
let List.661 : {Str, Str} = CallByName List.66 List.170 List.173;
|
||||
inc List.661;
|
||||
let List.175 : List U8 = CallByName Test.71 List.171 List.661;
|
||||
let List.660 : U64 = 1i64;
|
||||
let List.659 : U64 = CallByName Num.51 List.173 List.660;
|
||||
jump List.655 List.170 List.175 List.172 List.659 List.174;
|
||||
procedure List.97 (#Derived_gen.40, #Derived_gen.41, #Derived_gen.42, #Derived_gen.43, #Derived_gen.44):
|
||||
joinpoint List.667 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.669 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.669 then
|
||||
let List.673 : {Str, Str} = CallByName List.66 List.171 List.174;
|
||||
inc List.673;
|
||||
let List.176 : List U8 = CallByName Test.71 List.172 List.673;
|
||||
let List.672 : U64 = 1i64;
|
||||
let List.671 : U64 = CallByName Num.51 List.174 List.672;
|
||||
jump List.667 List.171 List.176 List.173 List.671 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.34;
|
||||
jump List.655 #Derived_gen.34 #Derived_gen.35 #Derived_gen.36 #Derived_gen.37 #Derived_gen.38;
|
||||
inc #Derived_gen.40;
|
||||
jump List.667 #Derived_gen.40 #Derived_gen.41 #Derived_gen.42 #Derived_gen.43 #Derived_gen.44;
|
||||
|
||||
procedure Num.127 (#Attr.2):
|
||||
let Num.286 : U8 = lowlevel NumIntCast #Attr.2;
|
||||
|
|
|
@ -39,54 +39,54 @@ procedure Encode.26 (Encode.107, Encode.108):
|
|||
let Encode.110 : List U8 = CallByName Encode.24 Encode.111 Encode.112 Encode.108;
|
||||
ret Encode.110;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : List U8 = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : List U8 = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.4 (List.131, List.132):
|
||||
let List.648 : U64 = 1i64;
|
||||
let List.647 : List U8 = CallByName List.70 List.131 List.648;
|
||||
let List.646 : List U8 = CallByName List.71 List.647 List.132;
|
||||
ret List.646;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.660 : U64 = 1i64;
|
||||
let List.659 : List U8 = CallByName List.70 List.132 List.660;
|
||||
let List.658 : List U8 = CallByName List.71 List.659 List.133;
|
||||
ret List.658;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.651 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.651;
|
||||
let List.663 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.663;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.642 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.642;
|
||||
let List.654 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.654;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.640 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.640;
|
||||
let List.652 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.652;
|
||||
|
||||
procedure List.8 (#Attr.2, #Attr.3):
|
||||
let List.650 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.650;
|
||||
let List.662 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.662;
|
||||
|
||||
procedure List.96 (#Derived_gen.16, #Derived_gen.17, #Derived_gen.18, #Derived_gen.19, #Derived_gen.20):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : {Str, Str} = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : List U8 = CallByName Test.71 List.171 List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.16, #Derived_gen.17, #Derived_gen.18, #Derived_gen.19, #Derived_gen.20):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : {Str, Str} = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : List U8 = CallByName Test.71 List.172 List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.16;
|
||||
jump List.629 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18 #Derived_gen.19 #Derived_gen.20;
|
||||
jump List.641 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18 #Derived_gen.19 #Derived_gen.20;
|
||||
|
||||
procedure Num.127 (#Attr.2):
|
||||
let Num.282 : U8 = lowlevel NumIntCast #Attr.2;
|
||||
|
|
|
@ -46,54 +46,54 @@ procedure Encode.26 (Encode.107, Encode.108):
|
|||
let Encode.110 : List U8 = CallByName Encode.24 Encode.111 Encode.112 Encode.108;
|
||||
ret Encode.110;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : List U8 = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : List U8 = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.4 (List.131, List.132):
|
||||
let List.648 : U64 = 1i64;
|
||||
let List.647 : List U8 = CallByName List.70 List.131 List.648;
|
||||
let List.646 : List U8 = CallByName List.71 List.647 List.132;
|
||||
ret List.646;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.660 : U64 = 1i64;
|
||||
let List.659 : List U8 = CallByName List.70 List.132 List.660;
|
||||
let List.658 : List U8 = CallByName List.71 List.659 List.133;
|
||||
ret List.658;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.651 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.651;
|
||||
let List.663 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.663;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.642 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.642;
|
||||
let List.654 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.654;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.640 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.640;
|
||||
let List.652 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.652;
|
||||
|
||||
procedure List.8 (#Attr.2, #Attr.3):
|
||||
let List.650 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.650;
|
||||
let List.662 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.662;
|
||||
|
||||
procedure List.96 (#Derived_gen.20, #Derived_gen.21, #Derived_gen.22, #Derived_gen.23, #Derived_gen.24):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : {Str, Str} = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : List U8 = CallByName Test.71 List.171 List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.20, #Derived_gen.21, #Derived_gen.22, #Derived_gen.23, #Derived_gen.24):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : {Str, Str} = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : List U8 = CallByName Test.71 List.172 List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.20;
|
||||
jump List.629 #Derived_gen.20 #Derived_gen.21 #Derived_gen.22 #Derived_gen.23 #Derived_gen.24;
|
||||
jump List.641 #Derived_gen.20 #Derived_gen.21 #Derived_gen.22 #Derived_gen.23 #Derived_gen.24;
|
||||
|
||||
procedure Num.127 (#Attr.2):
|
||||
let Num.282 : U8 = lowlevel NumIntCast #Attr.2;
|
||||
|
|
|
@ -11,23 +11,23 @@ procedure Encode.26 (Encode.107, Encode.108):
|
|||
let Encode.110 : List U8 = CallByName Encode.24 Encode.111 Encode.112 Encode.108;
|
||||
ret Encode.110;
|
||||
|
||||
procedure List.4 (List.131, List.132):
|
||||
let List.636 : U64 = 1i64;
|
||||
let List.635 : List U8 = CallByName List.70 List.131 List.636;
|
||||
let List.634 : List U8 = CallByName List.71 List.635 List.132;
|
||||
ret List.634;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.648 : U64 = 1i64;
|
||||
let List.647 : List U8 = CallByName List.70 List.132 List.648;
|
||||
let List.646 : List U8 = CallByName List.71 List.647 List.133;
|
||||
ret List.646;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.630 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.630;
|
||||
let List.642 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.642;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.628 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.628;
|
||||
let List.640 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.640;
|
||||
|
||||
procedure List.8 (#Attr.2, #Attr.3):
|
||||
let List.638 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.638;
|
||||
let List.650 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.650;
|
||||
|
||||
procedure Num.127 (#Attr.2):
|
||||
let Num.282 : U8 = lowlevel NumIntCast #Attr.2;
|
||||
|
|
|
@ -41,57 +41,57 @@ procedure Encode.26 (Encode.107, Encode.108):
|
|||
ret Encode.110;
|
||||
|
||||
procedure List.13 (#Attr.2, #Attr.3):
|
||||
let List.652 : List Str = lowlevel ListPrepend #Attr.2 #Attr.3;
|
||||
ret List.652;
|
||||
let List.664 : List Str = lowlevel ListPrepend #Attr.2 #Attr.3;
|
||||
ret List.664;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : List U8 = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : List U8 = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.4 (List.131, List.132):
|
||||
let List.648 : U64 = 1i64;
|
||||
let List.647 : List U8 = CallByName List.70 List.131 List.648;
|
||||
let List.646 : List U8 = CallByName List.71 List.647 List.132;
|
||||
ret List.646;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.660 : U64 = 1i64;
|
||||
let List.659 : List U8 = CallByName List.70 List.132 List.660;
|
||||
let List.658 : List U8 = CallByName List.71 List.659 List.133;
|
||||
ret List.658;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.651 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.651;
|
||||
let List.663 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.663;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.642 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.642;
|
||||
let List.654 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.654;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.640 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.640;
|
||||
let List.652 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.652;
|
||||
|
||||
procedure List.8 (#Attr.2, #Attr.3):
|
||||
let List.650 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.650;
|
||||
let List.662 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.662;
|
||||
|
||||
procedure List.96 (#Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16, #Derived_gen.17):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : Str = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : List U8 = CallByName Test.64 List.171 List.635 List.172;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16, #Derived_gen.17):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : Str = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : List U8 = CallByName Test.64 List.172 List.647 List.173;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.13;
|
||||
jump List.629 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17;
|
||||
jump List.641 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17;
|
||||
|
||||
procedure Num.127 (#Attr.2):
|
||||
let Num.282 : U8 = lowlevel NumIntCast #Attr.2;
|
||||
|
|
|
@ -44,57 +44,57 @@ procedure Encode.26 (Encode.107, Encode.108):
|
|||
ret Encode.110;
|
||||
|
||||
procedure List.13 (#Attr.2, #Attr.3):
|
||||
let List.652 : List Str = lowlevel ListPrepend #Attr.2 #Attr.3;
|
||||
ret List.652;
|
||||
let List.664 : List Str = lowlevel ListPrepend #Attr.2 #Attr.3;
|
||||
ret List.664;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : List U8 = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : List U8 = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.4 (List.131, List.132):
|
||||
let List.648 : U64 = 1i64;
|
||||
let List.647 : List U8 = CallByName List.70 List.131 List.648;
|
||||
let List.646 : List U8 = CallByName List.71 List.647 List.132;
|
||||
ret List.646;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.660 : U64 = 1i64;
|
||||
let List.659 : List U8 = CallByName List.70 List.132 List.660;
|
||||
let List.658 : List U8 = CallByName List.71 List.659 List.133;
|
||||
ret List.658;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.651 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.651;
|
||||
let List.663 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.663;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.642 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.642;
|
||||
let List.654 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.654;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.640 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.640;
|
||||
let List.652 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.652;
|
||||
|
||||
procedure List.8 (#Attr.2, #Attr.3):
|
||||
let List.650 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.650;
|
||||
let List.662 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.662;
|
||||
|
||||
procedure List.96 (#Derived_gen.23, #Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_gen.27):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : Str = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : List U8 = CallByName Test.64 List.171 List.635 List.172;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.14, #Derived_gen.15, #Derived_gen.16, #Derived_gen.17, #Derived_gen.18):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : Str = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : List U8 = CallByName Test.64 List.172 List.647 List.173;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.23;
|
||||
jump List.629 #Derived_gen.23 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26 #Derived_gen.27;
|
||||
inc #Derived_gen.14;
|
||||
jump List.641 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18;
|
||||
|
||||
procedure Num.127 (#Attr.2):
|
||||
let Num.282 : U8 = lowlevel NumIntCast #Attr.2;
|
||||
|
|
|
@ -145,7 +145,7 @@ procedure Dict.43 (Dict.126):
|
|||
let Dict.1101 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Inspect.30 Dict.126;
|
||||
ret Dict.1101;
|
||||
|
||||
procedure Dict.45 (#Derived_gen.42, #Derived_gen.43, #Derived_gen.44, #Derived_gen.45, #Derived_gen.46, #Derived_gen.47, #Derived_gen.48, #Derived_gen.49, #Derived_gen.50):
|
||||
procedure Dict.45 (#Derived_gen.45, #Derived_gen.46, #Derived_gen.47, #Derived_gen.48, #Derived_gen.49, #Derived_gen.50, #Derived_gen.51, #Derived_gen.52, #Derived_gen.53):
|
||||
joinpoint Dict.744 Dict.228 Dict.229 Dict.230 Dict.231 Dict.232 Dict.233 Dict.234 Dict.235 Dict.236:
|
||||
let Dict.237 : {U32, U32} = CallByName Dict.22 Dict.228 Dict.230;
|
||||
let Dict.791 : U32 = StructAtIndex 1 Dict.237;
|
||||
|
@ -188,8 +188,8 @@ procedure Dict.45 (#Derived_gen.42, #Derived_gen.43, #Derived_gen.44, #Derived_g
|
|||
let Dict.246 : U32 = CallByName Dict.55 Dict.231;
|
||||
jump Dict.744 Dict.228 Dict.229 Dict.245 Dict.246 Dict.232 Dict.233 Dict.234 Dict.235 Dict.236;
|
||||
in
|
||||
inc #Derived_gen.46;
|
||||
jump Dict.744 #Derived_gen.42 #Derived_gen.43 #Derived_gen.44 #Derived_gen.45 #Derived_gen.46 #Derived_gen.47 #Derived_gen.48 #Derived_gen.49 #Derived_gen.50;
|
||||
inc #Derived_gen.49;
|
||||
jump Dict.744 #Derived_gen.45 #Derived_gen.46 #Derived_gen.47 #Derived_gen.48 #Derived_gen.49 #Derived_gen.50 #Derived_gen.51 #Derived_gen.52 #Derived_gen.53;
|
||||
|
||||
procedure Dict.48 ():
|
||||
let Dict.868 : U32 = 0i64;
|
||||
|
@ -304,7 +304,7 @@ procedure Dict.72 (Dict.412, Dict.413, Dict.414):
|
|||
let Dict.854 : {U64, U32} = CallByName Dict.73 Dict.412 Dict.417 Dict.416;
|
||||
ret Dict.854;
|
||||
|
||||
procedure Dict.73 (#Derived_gen.21, #Derived_gen.22, #Derived_gen.23):
|
||||
procedure Dict.73 (#Derived_gen.16, #Derived_gen.17, #Derived_gen.18):
|
||||
joinpoint Dict.855 Dict.418 Dict.419 Dict.420:
|
||||
let Dict.421 : {U32, U32} = CallByName Dict.22 Dict.418 Dict.419;
|
||||
let Dict.862 : U32 = StructAtIndex 1 Dict.421;
|
||||
|
@ -319,10 +319,10 @@ procedure Dict.73 (#Derived_gen.21, #Derived_gen.22, #Derived_gen.23):
|
|||
let Dict.856 : {U64, U32} = Struct {Dict.419, Dict.420};
|
||||
ret Dict.856;
|
||||
in
|
||||
inc #Derived_gen.21;
|
||||
jump Dict.855 #Derived_gen.21 #Derived_gen.22 #Derived_gen.23;
|
||||
inc #Derived_gen.16;
|
||||
jump Dict.855 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18;
|
||||
|
||||
procedure Dict.74 (#Derived_gen.51, #Derived_gen.52, #Derived_gen.53):
|
||||
procedure Dict.74 (#Derived_gen.54, #Derived_gen.55, #Derived_gen.56):
|
||||
joinpoint Dict.761 Dict.422 Dict.423 Dict.424:
|
||||
let Dict.425 : {U32, U32} = CallByName Dict.22 Dict.422 Dict.424;
|
||||
let Dict.771 : U32 = StructAtIndex 1 Dict.425;
|
||||
|
@ -341,7 +341,7 @@ procedure Dict.74 (#Derived_gen.51, #Derived_gen.52, #Derived_gen.53):
|
|||
let Dict.762 : List {U32, U32} = CallByName List.3 Dict.422 Dict.424 Dict.423;
|
||||
ret Dict.762;
|
||||
in
|
||||
jump Dict.761 #Derived_gen.51 #Derived_gen.52 #Derived_gen.53;
|
||||
jump Dict.761 #Derived_gen.54 #Derived_gen.55 #Derived_gen.56;
|
||||
|
||||
procedure Dict.75 (Dict.427, Dict.428):
|
||||
let Dict.757 : U64 = 1i64;
|
||||
|
@ -890,171 +890,171 @@ procedure Inspect.63 (Inspect.300, Inspect.296):
|
|||
procedure Inspect.64 (Inspect.302):
|
||||
ret Inspect.302;
|
||||
|
||||
procedure List.11 (List.145, List.146):
|
||||
let List.688 : List {U32, U32} = CallByName List.68 List.146;
|
||||
let List.687 : List {U32, U32} = CallByName List.94 List.145 List.146 List.688;
|
||||
ret List.687;
|
||||
procedure List.11 (List.146, List.147):
|
||||
let List.700 : List {U32, U32} = CallByName List.68 List.147;
|
||||
let List.699 : List {U32, U32} = CallByName List.95 List.146 List.147 List.700;
|
||||
ret List.699;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.691 : U64 = 0i64;
|
||||
let List.692 : U64 = CallByName List.6 List.167;
|
||||
let List.690 : {Str, Int1} = CallByName List.96 List.167 List.168 List.169 List.691 List.692;
|
||||
ret List.690;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.703 : U64 = 0i64;
|
||||
let List.704 : U64 = CallByName List.6 List.168;
|
||||
let List.702 : {Str, Int1} = CallByName List.97 List.168 List.169 List.170 List.703 List.704;
|
||||
ret List.702;
|
||||
|
||||
procedure List.3 (List.123, List.124, List.125):
|
||||
let List.652 : {List {U32, U32}, {U32, U32}} = CallByName List.64 List.123 List.124 List.125;
|
||||
let List.651 : List {U32, U32} = StructAtIndex 0 List.652;
|
||||
ret List.651;
|
||||
procedure List.3 (List.124, List.125, List.126):
|
||||
let List.664 : {List {U32, U32}, {U32, U32}} = CallByName List.64 List.124 List.125 List.126;
|
||||
let List.663 : List {U32, U32} = StructAtIndex 0 List.664;
|
||||
ret List.663;
|
||||
|
||||
procedure List.3 (List.123, List.124, List.125):
|
||||
let List.654 : {List {Str, I64}, {Str, I64}} = CallByName List.64 List.123 List.124 List.125;
|
||||
let List.653 : List {Str, I64} = StructAtIndex 0 List.654;
|
||||
let #Derived_gen.71 : {Str, I64} = StructAtIndex 1 List.654;
|
||||
procedure List.3 (List.124, List.125, List.126):
|
||||
let List.666 : {List {Str, I64}, {Str, I64}} = CallByName List.64 List.124 List.125 List.126;
|
||||
let List.665 : List {Str, I64} = StructAtIndex 0 List.666;
|
||||
let #Derived_gen.71 : {Str, I64} = StructAtIndex 1 List.666;
|
||||
dec #Derived_gen.71;
|
||||
ret List.653;
|
||||
ret List.665;
|
||||
|
||||
procedure List.4 (List.131, List.132):
|
||||
let List.663 : U64 = 1i64;
|
||||
let List.661 : List {Str, I64} = CallByName List.70 List.131 List.663;
|
||||
let List.660 : List {Str, I64} = CallByName List.71 List.661 List.132;
|
||||
ret List.660;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.675 : U64 = 1i64;
|
||||
let List.673 : List {Str, I64} = CallByName List.70 List.132 List.675;
|
||||
let List.672 : List {Str, I64} = CallByName List.71 List.673 List.133;
|
||||
ret List.672;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.642 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.642;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.689 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.689;
|
||||
let List.654 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.654;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.701 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.701;
|
||||
|
||||
procedure List.64 (List.120, List.121, List.122):
|
||||
let List.650 : U64 = CallByName List.6 List.120;
|
||||
let List.647 : Int1 = CallByName Num.22 List.121 List.650;
|
||||
if List.647 then
|
||||
let List.648 : {List {U32, U32}, {U32, U32}} = CallByName List.67 List.120 List.121 List.122;
|
||||
ret List.648;
|
||||
else
|
||||
let List.646 : {List {U32, U32}, {U32, U32}} = Struct {List.120, List.122};
|
||||
ret List.646;
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.713 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.713;
|
||||
|
||||
procedure List.64 (List.120, List.121, List.122):
|
||||
let List.659 : U64 = CallByName List.6 List.120;
|
||||
let List.656 : Int1 = CallByName Num.22 List.121 List.659;
|
||||
if List.656 then
|
||||
let List.657 : {List {Str, I64}, {Str, I64}} = CallByName List.67 List.120 List.121 List.122;
|
||||
ret List.657;
|
||||
procedure List.64 (List.121, List.122, List.123):
|
||||
let List.662 : U64 = CallByName List.6 List.121;
|
||||
let List.659 : Int1 = CallByName Num.22 List.122 List.662;
|
||||
if List.659 then
|
||||
let List.660 : {List {U32, U32}, {U32, U32}} = CallByName List.67 List.121 List.122 List.123;
|
||||
ret List.660;
|
||||
else
|
||||
let List.655 : {List {Str, I64}, {Str, I64}} = Struct {List.120, List.122};
|
||||
ret List.655;
|
||||
let List.658 : {List {U32, U32}, {U32, U32}} = Struct {List.121, List.123};
|
||||
ret List.658;
|
||||
|
||||
procedure List.64 (List.121, List.122, List.123):
|
||||
let List.671 : U64 = CallByName List.6 List.121;
|
||||
let List.668 : Int1 = CallByName Num.22 List.122 List.671;
|
||||
if List.668 then
|
||||
let List.669 : {List {Str, I64}, {Str, I64}} = CallByName List.67 List.121 List.122 List.123;
|
||||
ret List.669;
|
||||
else
|
||||
let List.667 : {List {Str, I64}, {Str, I64}} = Struct {List.121, List.123};
|
||||
ret List.667;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.700 : {Str, I64} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.700;
|
||||
let List.712 : {Str, I64} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.712;
|
||||
|
||||
procedure List.67 (#Attr.2, #Attr.3, #Attr.4):
|
||||
let List.649 : {List {U32, U32}, {U32, U32}} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.649;
|
||||
let List.661 : {List {U32, U32}, {U32, U32}} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.661;
|
||||
|
||||
procedure List.67 (#Attr.2, #Attr.3, #Attr.4):
|
||||
let List.658 : {List {Str, I64}, {Str, I64}} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.658;
|
||||
let List.670 : {List {Str, I64}, {Str, I64}} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.670;
|
||||
|
||||
procedure List.68 (#Attr.2):
|
||||
let List.686 : List {U32, U32} = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.686;
|
||||
let List.698 : List {U32, U32} = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.698;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.664 : List {Str, I64} = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.664;
|
||||
let List.676 : List {Str, I64} = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.676;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.662 : List {Str, I64} = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.662;
|
||||
let List.674 : List {Str, I64} = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.674;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.683 : List {U32, U32} = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.683;
|
||||
let List.695 : List {U32, U32} = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.695;
|
||||
|
||||
procedure List.83 (List.176, List.177, List.178):
|
||||
let List.666 : U64 = 0i64;
|
||||
let List.667 : U64 = CallByName List.6 List.176;
|
||||
let List.665 : List {U32, U32} = CallByName List.97 List.176 List.177 List.178 List.666 List.667;
|
||||
ret List.665;
|
||||
procedure List.83 (List.177, List.178, List.179):
|
||||
let List.678 : U64 = 0i64;
|
||||
let List.679 : U64 = CallByName List.6 List.177;
|
||||
let List.677 : List {U32, U32} = CallByName List.98 List.177 List.178 List.179 List.678 List.679;
|
||||
ret List.677;
|
||||
|
||||
procedure List.94 (#Derived_gen.54, #Derived_gen.55, #Derived_gen.56):
|
||||
joinpoint List.677 List.147 List.148 List.149:
|
||||
let List.685 : U64 = 0i64;
|
||||
let List.679 : Int1 = CallByName Num.24 List.148 List.685;
|
||||
if List.679 then
|
||||
let List.684 : U64 = 1i64;
|
||||
let List.681 : U64 = CallByName Num.75 List.148 List.684;
|
||||
let List.682 : List {U32, U32} = CallByName List.71 List.149 List.147;
|
||||
jump List.677 List.147 List.681 List.682;
|
||||
procedure List.95 (#Derived_gen.37, #Derived_gen.38, #Derived_gen.39):
|
||||
joinpoint List.689 List.148 List.149 List.150:
|
||||
let List.697 : U64 = 0i64;
|
||||
let List.691 : Int1 = CallByName Num.24 List.149 List.697;
|
||||
if List.691 then
|
||||
let List.696 : U64 = 1i64;
|
||||
let List.693 : U64 = CallByName Num.75 List.149 List.696;
|
||||
let List.694 : List {U32, U32} = CallByName List.71 List.150 List.148;
|
||||
jump List.689 List.148 List.693 List.694;
|
||||
else
|
||||
ret List.149;
|
||||
ret List.150;
|
||||
in
|
||||
jump List.677 #Derived_gen.54 #Derived_gen.55 #Derived_gen.56;
|
||||
jump List.689 #Derived_gen.37 #Derived_gen.38 #Derived_gen.39;
|
||||
|
||||
procedure List.96 (#Derived_gen.12, #Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16):
|
||||
joinpoint List.693 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.695 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.695 then
|
||||
let List.699 : {Str, I64} = CallByName List.66 List.170 List.173;
|
||||
inc List.699;
|
||||
let List.175 : {Str, Int1} = CallByName Dict.188 List.171 List.699 List.172;
|
||||
let List.698 : U64 = 1i64;
|
||||
let List.697 : U64 = CallByName Num.51 List.173 List.698;
|
||||
jump List.693 List.170 List.175 List.172 List.697 List.174;
|
||||
procedure List.97 (#Derived_gen.26, #Derived_gen.27, #Derived_gen.28, #Derived_gen.29, #Derived_gen.30):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : {Str, I64} = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.159 List.172 List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.12;
|
||||
jump List.693 #Derived_gen.12 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16;
|
||||
inc #Derived_gen.26;
|
||||
jump List.641 #Derived_gen.26 #Derived_gen.27 #Derived_gen.28 #Derived_gen.29 #Derived_gen.30;
|
||||
|
||||
procedure List.96 (#Derived_gen.59, #Derived_gen.60, #Derived_gen.61, #Derived_gen.62, #Derived_gen.63):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : {Str, I64} = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : {List {U32, U32}, List {Str, I64}, U64, Float32, U8} = CallByName Dict.159 List.171 List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.40, #Derived_gen.41, #Derived_gen.42, #Derived_gen.43, #Derived_gen.44):
|
||||
joinpoint List.705 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.707 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.707 then
|
||||
let List.711 : {Str, I64} = CallByName List.66 List.171 List.174;
|
||||
inc List.711;
|
||||
let List.176 : {Str, Int1} = CallByName Dict.188 List.172 List.711 List.173;
|
||||
let List.710 : U64 = 1i64;
|
||||
let List.709 : U64 = CallByName Num.51 List.174 List.710;
|
||||
jump List.705 List.171 List.176 List.173 List.709 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.59;
|
||||
jump List.629 #Derived_gen.59 #Derived_gen.60 #Derived_gen.61 #Derived_gen.62 #Derived_gen.63;
|
||||
inc #Derived_gen.40;
|
||||
jump List.705 #Derived_gen.40 #Derived_gen.41 #Derived_gen.42 #Derived_gen.43 #Derived_gen.44;
|
||||
|
||||
procedure List.97 (#Derived_gen.31, #Derived_gen.32, #Derived_gen.33, #Derived_gen.34, #Derived_gen.35):
|
||||
joinpoint List.668 List.179 List.180 List.181 List.182 List.183:
|
||||
let List.670 : Int1 = CallByName Num.22 List.182 List.183;
|
||||
if List.670 then
|
||||
let List.674 : {Str, I64} = CallByName List.66 List.179 List.182;
|
||||
inc List.674;
|
||||
let List.184 : List {U32, U32} = CallByName Dict.406 List.180 List.674 List.182 List.181;
|
||||
let List.673 : U64 = 1i64;
|
||||
let List.672 : U64 = CallByName Num.51 List.182 List.673;
|
||||
jump List.668 List.179 List.184 List.181 List.672 List.183;
|
||||
procedure List.98 (#Derived_gen.61, #Derived_gen.62, #Derived_gen.63, #Derived_gen.64, #Derived_gen.65):
|
||||
joinpoint List.680 List.180 List.181 List.182 List.183 List.184:
|
||||
let List.682 : Int1 = CallByName Num.22 List.183 List.184;
|
||||
if List.682 then
|
||||
let List.686 : {Str, I64} = CallByName List.66 List.180 List.183;
|
||||
inc List.686;
|
||||
let List.185 : List {U32, U32} = CallByName Dict.406 List.181 List.686 List.183 List.182;
|
||||
let List.685 : U64 = 1i64;
|
||||
let List.684 : U64 = CallByName Num.51 List.183 List.685;
|
||||
jump List.680 List.180 List.185 List.182 List.684 List.184;
|
||||
else
|
||||
dec List.179;
|
||||
ret List.180;
|
||||
dec List.180;
|
||||
ret List.181;
|
||||
in
|
||||
inc #Derived_gen.31;
|
||||
jump List.668 #Derived_gen.31 #Derived_gen.32 #Derived_gen.33 #Derived_gen.34 #Derived_gen.35;
|
||||
inc #Derived_gen.61;
|
||||
jump List.680 #Derived_gen.61 #Derived_gen.62 #Derived_gen.63 #Derived_gen.64 #Derived_gen.65;
|
||||
|
||||
procedure Num.131 (#Attr.2):
|
||||
let Num.289 : U32 = lowlevel NumIntCast #Attr.2;
|
||||
|
|
|
@ -135,35 +135,35 @@ procedure Inspect.63 (Inspect.300, Inspect.296):
|
|||
procedure Inspect.64 (Inspect.302):
|
||||
ret Inspect.302;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : {Str, Int1} = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : {Str, Int1} = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.637 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.637;
|
||||
let List.649 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.649;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : I64 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : I64 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.96 (#Derived_gen.19, #Derived_gen.20, #Derived_gen.21, #Derived_gen.22, #Derived_gen.23):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : I64 = CallByName List.66 List.170 List.173;
|
||||
let List.175 : {Str, Int1} = CallByName Inspect.160 List.171 List.635 List.172;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.8, #Derived_gen.9, #Derived_gen.10, #Derived_gen.11, #Derived_gen.12):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : I64 = CallByName List.66 List.171 List.174;
|
||||
let List.176 : {Str, Int1} = CallByName Inspect.160 List.172 List.647 List.173;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.19;
|
||||
jump List.629 #Derived_gen.19 #Derived_gen.20 #Derived_gen.21 #Derived_gen.22 #Derived_gen.23;
|
||||
inc #Derived_gen.8;
|
||||
jump List.641 #Derived_gen.8 #Derived_gen.9 #Derived_gen.10 #Derived_gen.11 #Derived_gen.12;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.283 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -221,67 +221,67 @@ procedure Inspect.63 (Inspect.300, Inspect.296):
|
|||
procedure Inspect.64 (Inspect.302):
|
||||
ret Inspect.302;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : {Str, Int1} = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.167;
|
||||
let List.638 : {Str, Int1} = CallByName List.96 List.167 List.168 List.169 List.639 List.640;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : {Str, Int1} = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.637 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.637;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.651 : U64 = 0i64;
|
||||
let List.652 : U64 = CallByName List.6 List.168;
|
||||
let List.650 : {Str, Int1} = CallByName List.97 List.168 List.169 List.170 List.651 List.652;
|
||||
ret List.650;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.649 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.649;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.661 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.661;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.648 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.96 (#Derived_gen.28, #Derived_gen.29, #Derived_gen.30, #Derived_gen.31, #Derived_gen.32):
|
||||
joinpoint List.641 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.643 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.660 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.660;
|
||||
|
||||
procedure List.97 (#Derived_gen.28, #Derived_gen.29, #Derived_gen.30, #Derived_gen.31, #Derived_gen.32):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : {Str, Str} = CallByName List.66 List.170 List.173;
|
||||
let List.647 : {Str, Str} = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.175 : {Str, Int1} = CallByName Inspect.233 List.171 List.647;
|
||||
let List.176 : {Str, Int1} = CallByName Inspect.233 List.172 List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.173 List.646;
|
||||
jump List.641 List.170 List.175 List.172 List.645 List.174;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.28;
|
||||
jump List.641 #Derived_gen.28 #Derived_gen.29 #Derived_gen.30 #Derived_gen.31 #Derived_gen.32;
|
||||
|
||||
procedure List.96 (#Derived_gen.33, #Derived_gen.34, #Derived_gen.35, #Derived_gen.36, #Derived_gen.37):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : {Str, Str} = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : {Str, Int1} = CallByName Inspect.233 List.171 List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.33, #Derived_gen.34, #Derived_gen.35, #Derived_gen.36, #Derived_gen.37):
|
||||
joinpoint List.653 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.655 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.655 then
|
||||
let List.659 : {Str, Str} = CallByName List.66 List.171 List.174;
|
||||
inc List.659;
|
||||
let List.176 : {Str, Int1} = CallByName Inspect.233 List.172 List.659;
|
||||
let List.658 : U64 = 1i64;
|
||||
let List.657 : U64 = CallByName Num.51 List.174 List.658;
|
||||
jump List.653 List.171 List.176 List.173 List.657 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.33;
|
||||
jump List.629 #Derived_gen.33 #Derived_gen.34 #Derived_gen.35 #Derived_gen.36 #Derived_gen.37;
|
||||
jump List.653 #Derived_gen.33 #Derived_gen.34 #Derived_gen.35 #Derived_gen.36 #Derived_gen.37;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.284 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -161,36 +161,36 @@ procedure Inspect.63 (Inspect.300, Inspect.296):
|
|||
procedure Inspect.64 (Inspect.302):
|
||||
ret Inspect.302;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : {Str, Int1} = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : {Str, Int1} = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.637 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.637;
|
||||
let List.649 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.649;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : {[C I64, C Decimal], Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : {[C I64, C Decimal], Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.96 (#Derived_gen.22, #Derived_gen.23, #Derived_gen.24, #Derived_gen.25, #Derived_gen.26):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : {[C I64, C Decimal], Str} = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : {Str, Int1} = CallByName Inspect.233 List.171 List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.14, #Derived_gen.15, #Derived_gen.16, #Derived_gen.17, #Derived_gen.18):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : {[C I64, C Decimal], Str} = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : {Str, Int1} = CallByName Inspect.233 List.172 List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.22;
|
||||
jump List.629 #Derived_gen.22 #Derived_gen.23 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26;
|
||||
inc #Derived_gen.14;
|
||||
jump List.641 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.284 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -139,36 +139,36 @@ procedure Inspect.63 (Inspect.300, Inspect.296):
|
|||
procedure Inspect.64 (Inspect.302):
|
||||
ret Inspect.302;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : {Str, Int1} = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : {Str, Int1} = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.637 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.637;
|
||||
let List.649 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.649;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.96 (#Derived_gen.16, #Derived_gen.17, #Derived_gen.18, #Derived_gen.19, #Derived_gen.20):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : {Str, Str} = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : {Str, Int1} = CallByName Inspect.233 List.171 List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.12, #Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : {Str, Str} = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : {Str, Int1} = CallByName Inspect.233 List.172 List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.16;
|
||||
jump List.629 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18 #Derived_gen.19 #Derived_gen.20;
|
||||
inc #Derived_gen.12;
|
||||
jump List.641 #Derived_gen.12 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -146,36 +146,36 @@ procedure Inspect.63 (Inspect.300, Inspect.296):
|
|||
procedure Inspect.64 (Inspect.302):
|
||||
ret Inspect.302;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : {Str, Int1} = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : {Str, Int1} = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.637 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.637;
|
||||
let List.649 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.649;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : {Str, Str} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.96 (#Derived_gen.20, #Derived_gen.21, #Derived_gen.22, #Derived_gen.23, #Derived_gen.24):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : {Str, Str} = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : {Str, Int1} = CallByName Inspect.233 List.171 List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.16, #Derived_gen.17, #Derived_gen.18, #Derived_gen.19, #Derived_gen.20):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : {Str, Str} = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : {Str, Int1} = CallByName Inspect.233 List.172 List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.20;
|
||||
jump List.629 #Derived_gen.20 #Derived_gen.21 #Derived_gen.22 #Derived_gen.23 #Derived_gen.24;
|
||||
inc #Derived_gen.16;
|
||||
jump List.641 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18 #Derived_gen.19 #Derived_gen.20;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -132,43 +132,43 @@ procedure Inspect.63 (Inspect.300, Inspect.296):
|
|||
procedure Inspect.64 (Inspect.302):
|
||||
ret Inspect.302;
|
||||
|
||||
procedure List.1 (List.114):
|
||||
let List.639 : U64 = CallByName List.6 List.114;
|
||||
let List.640 : U64 = 0i64;
|
||||
let List.638 : Int1 = CallByName Bool.11 List.639 List.640;
|
||||
procedure List.1 (List.115):
|
||||
let List.651 : U64 = CallByName List.6 List.115;
|
||||
let List.652 : U64 = 0i64;
|
||||
let List.650 : Int1 = CallByName Bool.11 List.651 List.652;
|
||||
ret List.650;
|
||||
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : Str = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : Str = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.637 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.637;
|
||||
let List.649 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.649;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.96 (#Derived_gen.20, #Derived_gen.21, #Derived_gen.22, #Derived_gen.23, #Derived_gen.24):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : Str = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : Str = CallByName Inspect.210 List.171 List.635;
|
||||
dec List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.10, #Derived_gen.11, #Derived_gen.12, #Derived_gen.13, #Derived_gen.14):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : Str = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : Str = CallByName Inspect.210 List.172 List.647;
|
||||
dec List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.20;
|
||||
jump List.629 #Derived_gen.20 #Derived_gen.21 #Derived_gen.22 #Derived_gen.23 #Derived_gen.24;
|
||||
inc #Derived_gen.10;
|
||||
jump List.641 #Derived_gen.10 #Derived_gen.11 #Derived_gen.12 #Derived_gen.13 #Derived_gen.14;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -135,43 +135,43 @@ procedure Inspect.63 (Inspect.300, Inspect.296):
|
|||
procedure Inspect.64 (Inspect.302):
|
||||
ret Inspect.302;
|
||||
|
||||
procedure List.1 (List.114):
|
||||
let List.639 : U64 = CallByName List.6 List.114;
|
||||
let List.640 : U64 = 0i64;
|
||||
let List.638 : Int1 = CallByName Bool.11 List.639 List.640;
|
||||
procedure List.1 (List.115):
|
||||
let List.651 : U64 = CallByName List.6 List.115;
|
||||
let List.652 : U64 = 0i64;
|
||||
let List.650 : Int1 = CallByName Bool.11 List.651 List.652;
|
||||
ret List.650;
|
||||
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : Str = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : Str = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.637 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.637;
|
||||
let List.649 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.649;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.96 (#Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16, #Derived_gen.17):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : Str = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : Str = CallByName Inspect.210 List.171 List.635;
|
||||
dec List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.15, #Derived_gen.16, #Derived_gen.17, #Derived_gen.18, #Derived_gen.19):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : Str = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : Str = CallByName Inspect.210 List.172 List.647;
|
||||
dec List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.13;
|
||||
jump List.629 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17;
|
||||
inc #Derived_gen.15;
|
||||
jump List.641 #Derived_gen.15 #Derived_gen.16 #Derived_gen.17 #Derived_gen.18 #Derived_gen.19;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
procedure List.6 (#Attr.2):
|
||||
let List.626 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.626;
|
||||
let List.638 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.638;
|
||||
|
||||
procedure Num.19 (#Attr.2, #Attr.3):
|
||||
let Num.283 : U64 = lowlevel NumAdd #Attr.2 #Attr.3;
|
||||
|
|
|
@ -6,40 +6,40 @@ procedure Bool.2 ():
|
|||
let Bool.23 : Int1 = true;
|
||||
ret Bool.23;
|
||||
|
||||
procedure List.2 (List.115, List.116):
|
||||
let List.640 : U64 = CallByName List.6 List.115;
|
||||
let List.636 : Int1 = CallByName Num.22 List.116 List.640;
|
||||
if List.636 then
|
||||
let List.638 : I64 = CallByName List.66 List.115 List.116;
|
||||
let List.637 : [C {}, C I64] = TagId(1) List.638;
|
||||
ret List.637;
|
||||
procedure List.2 (List.116, List.117):
|
||||
let List.652 : U64 = CallByName List.6 List.116;
|
||||
let List.648 : Int1 = CallByName Num.22 List.117 List.652;
|
||||
if List.648 then
|
||||
let List.650 : I64 = CallByName List.66 List.116 List.117;
|
||||
let List.649 : [C {}, C I64] = TagId(1) List.650;
|
||||
ret List.649;
|
||||
else
|
||||
let List.635 : {} = Struct {};
|
||||
let List.634 : [C {}, C I64] = TagId(0) List.635;
|
||||
ret List.634;
|
||||
let List.647 : {} = Struct {};
|
||||
let List.646 : [C {}, C I64] = TagId(0) List.647;
|
||||
ret List.646;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.641 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.641;
|
||||
let List.653 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.653;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.639 : I64 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.639;
|
||||
let List.651 : I64 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.651;
|
||||
|
||||
procedure List.9 (List.387):
|
||||
let List.633 : U64 = 0i64;
|
||||
let List.626 : [C {}, C I64] = CallByName List.2 List.387 List.633;
|
||||
let List.630 : U8 = 1i64;
|
||||
let List.631 : U8 = GetTagId List.626;
|
||||
let List.632 : Int1 = lowlevel Eq List.630 List.631;
|
||||
if List.632 then
|
||||
let List.388 : I64 = UnionAtIndex (Id 1) (Index 0) List.626;
|
||||
let List.627 : [C Int1, C I64] = TagId(1) List.388;
|
||||
ret List.627;
|
||||
procedure List.9 (List.388):
|
||||
let List.645 : U64 = 0i64;
|
||||
let List.638 : [C {}, C I64] = CallByName List.2 List.388 List.645;
|
||||
let List.642 : U8 = 1i64;
|
||||
let List.643 : U8 = GetTagId List.638;
|
||||
let List.644 : Int1 = lowlevel Eq List.642 List.643;
|
||||
if List.644 then
|
||||
let List.389 : I64 = UnionAtIndex (Id 1) (Index 0) List.638;
|
||||
let List.639 : [C Int1, C I64] = TagId(1) List.389;
|
||||
ret List.639;
|
||||
else
|
||||
let List.629 : Int1 = true;
|
||||
let List.628 : [C Int1, C I64] = TagId(0) List.629;
|
||||
ret List.628;
|
||||
let List.641 : Int1 = true;
|
||||
let List.640 : [C Int1, C I64] = TagId(0) List.641;
|
||||
ret List.640;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.281 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
184
crates/compiler/test_mono/generated/issue_4770.txt
generated
184
crates/compiler/test_mono/generated/issue_4770.txt
generated
|
@ -6,118 +6,118 @@ procedure Bool.2 ():
|
|||
let Bool.24 : Int1 = true;
|
||||
ret Bool.24;
|
||||
|
||||
procedure List.101 (#Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4, #Derived_gen.5, #Derived_gen.6):
|
||||
joinpoint List.664 List.286 List.287 List.288 List.289 List.290 List.291:
|
||||
let List.666 : Int1 = CallByName Num.22 List.290 List.291;
|
||||
if List.666 then
|
||||
let List.672 : [<r>C I64, C List *self] = CallByName List.66 List.286 List.290;
|
||||
inc List.672;
|
||||
let List.673 : [<r>C I64, C List *self] = CallByName List.66 List.287 List.290;
|
||||
inc List.673;
|
||||
let List.292 : {[<r>C I64, C List *self], [<r>C I64, C List *self]} = CallByName Test.15 List.672 List.673;
|
||||
let List.668 : List {[<r>C I64, C List *self], [<r>C I64, C List *self]} = CallByName List.71 List.288 List.292;
|
||||
let List.670 : U64 = 1i64;
|
||||
let List.669 : U64 = CallByName Num.51 List.290 List.670;
|
||||
jump List.664 List.286 List.287 List.668 List.289 List.669 List.291;
|
||||
procedure List.102 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4, #Derived_gen.5):
|
||||
joinpoint List.676 List.287 List.288 List.289 List.290 List.291 List.292:
|
||||
let List.678 : Int1 = CallByName Num.22 List.291 List.292;
|
||||
if List.678 then
|
||||
let List.684 : [<r>C I64, C List *self] = CallByName List.66 List.287 List.291;
|
||||
inc List.684;
|
||||
let List.685 : [<r>C I64, C List *self] = CallByName List.66 List.288 List.291;
|
||||
inc List.685;
|
||||
let List.293 : {[<r>C I64, C List *self], [<r>C I64, C List *self]} = CallByName Test.15 List.684 List.685;
|
||||
let List.680 : List {[<r>C I64, C List *self], [<r>C I64, C List *self]} = CallByName List.71 List.289 List.293;
|
||||
let List.682 : U64 = 1i64;
|
||||
let List.681 : U64 = CallByName Num.51 List.291 List.682;
|
||||
jump List.676 List.287 List.288 List.680 List.290 List.681 List.292;
|
||||
else
|
||||
dec List.286;
|
||||
dec List.287;
|
||||
ret List.288;
|
||||
dec List.288;
|
||||
ret List.289;
|
||||
in
|
||||
inc #Derived_gen.0;
|
||||
inc #Derived_gen.1;
|
||||
inc #Derived_gen.2;
|
||||
jump List.664 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5 #Derived_gen.6;
|
||||
jump List.676 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5;
|
||||
|
||||
procedure List.111 (List.540, List.541, List.542):
|
||||
let List.640 : U64 = 0i64;
|
||||
let List.641 : U64 = CallByName List.6 List.540;
|
||||
let List.639 : [C {}, C {}] = CallByName List.80 List.540 List.541 List.542 List.640 List.641;
|
||||
procedure List.112 (List.541, List.542, List.543):
|
||||
let List.652 : U64 = 0i64;
|
||||
let List.653 : U64 = CallByName List.6 List.541;
|
||||
let List.651 : [C {}, C {}] = CallByName List.80 List.541 List.542 List.543 List.652 List.653;
|
||||
ret List.651;
|
||||
|
||||
procedure List.23 (List.283, List.284, List.285):
|
||||
let List.688 : U64 = CallByName List.6 List.283;
|
||||
let List.689 : U64 = CallByName List.6 List.284;
|
||||
let List.286 : U64 = CallByName Num.148 List.688 List.689;
|
||||
let List.674 : List {[<r>C I64, C List *self], [<r>C I64, C List *self]} = CallByName List.68 List.286;
|
||||
let List.675 : U64 = 0i64;
|
||||
let List.673 : List {[<r>C I64, C List *self], [<r>C I64, C List *self]} = CallByName List.102 List.283 List.284 List.674 List.285 List.675 List.286;
|
||||
ret List.673;
|
||||
|
||||
procedure List.244 (List.640, List.245, List.243):
|
||||
let List.670 : Int1 = CallByName Test.1 List.245;
|
||||
if List.670 then
|
||||
let List.672 : {} = Struct {};
|
||||
let List.671 : [C {}, C {}] = TagId(1) List.672;
|
||||
ret List.671;
|
||||
else
|
||||
let List.669 : {} = Struct {};
|
||||
let List.668 : [C {}, C {}] = TagId(0) List.669;
|
||||
ret List.668;
|
||||
|
||||
procedure List.56 (List.242, List.243):
|
||||
let List.649 : {} = Struct {};
|
||||
let List.641 : [C {}, C {}] = CallByName List.112 List.242 List.649 List.243;
|
||||
let List.646 : U8 = 1i64;
|
||||
let List.647 : U8 = GetTagId List.641;
|
||||
let List.648 : Int1 = lowlevel Eq List.646 List.647;
|
||||
if List.648 then
|
||||
let List.642 : Int1 = CallByName Bool.2;
|
||||
ret List.642;
|
||||
else
|
||||
let List.643 : Int1 = CallByName Bool.1;
|
||||
ret List.643;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.639 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.639;
|
||||
|
||||
procedure List.23 (List.282, List.283, List.284):
|
||||
let List.676 : U64 = CallByName List.6 List.282;
|
||||
let List.677 : U64 = CallByName List.6 List.283;
|
||||
let List.285 : U64 = CallByName Num.148 List.676 List.677;
|
||||
let List.662 : List {[<r>C I64, C List *self], [<r>C I64, C List *self]} = CallByName List.68 List.285;
|
||||
let List.663 : U64 = 0i64;
|
||||
let List.661 : List {[<r>C I64, C List *self], [<r>C I64, C List *self]} = CallByName List.101 List.282 List.283 List.662 List.284 List.663 List.285;
|
||||
ret List.661;
|
||||
|
||||
procedure List.243 (List.628, List.244, List.242):
|
||||
let List.658 : Int1 = CallByName Test.1 List.244;
|
||||
if List.658 then
|
||||
let List.660 : {} = Struct {};
|
||||
let List.659 : [C {}, C {}] = TagId(1) List.660;
|
||||
ret List.659;
|
||||
else
|
||||
let List.657 : {} = Struct {};
|
||||
let List.656 : [C {}, C {}] = TagId(0) List.657;
|
||||
ret List.656;
|
||||
|
||||
procedure List.56 (List.241, List.242):
|
||||
let List.637 : {} = Struct {};
|
||||
let List.629 : [C {}, C {}] = CallByName List.111 List.241 List.637 List.242;
|
||||
let List.634 : U8 = 1i64;
|
||||
let List.635 : U8 = GetTagId List.629;
|
||||
let List.636 : Int1 = lowlevel Eq List.634 List.635;
|
||||
if List.636 then
|
||||
let List.630 : Int1 = CallByName Bool.2;
|
||||
ret List.630;
|
||||
else
|
||||
let List.631 : Int1 = CallByName Bool.1;
|
||||
ret List.631;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.627 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.627;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.655 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.655;
|
||||
let List.667 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.667;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.654 : {[<r>C I64, C List *self], [<r>C I64, C List *self]} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.654;
|
||||
let List.666 : {[<r>C I64, C List *self], [<r>C I64, C List *self]} = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.666;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.674 : [<r>C I64, C List *self] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.674;
|
||||
let List.686 : [<r>C I64, C List *self] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.686;
|
||||
|
||||
procedure List.68 (#Attr.2):
|
||||
let List.675 : List {[<r>C I64, C List *self], [<r>C I64, C List *self]} = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.675;
|
||||
let List.687 : List {[<r>C I64, C List *self], [<r>C I64, C List *self]} = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.687;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.671 : List {[<r>C I64, C List *self], [<r>C I64, C List *self]} = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.671;
|
||||
let List.683 : List {[<r>C I64, C List *self], [<r>C I64, C List *self]} = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.683;
|
||||
|
||||
procedure List.80 (#Derived_gen.7, #Derived_gen.8, #Derived_gen.9, #Derived_gen.10, #Derived_gen.11):
|
||||
joinpoint List.642 List.543 List.544 List.545 List.546 List.547:
|
||||
let List.644 : Int1 = CallByName Num.22 List.546 List.547;
|
||||
if List.644 then
|
||||
let List.653 : {[<r>C I64, C List *self], [<r>C I64, C List *self]} = CallByName List.66 List.543 List.546;
|
||||
inc List.653;
|
||||
let List.645 : [C {}, C {}] = CallByName List.243 List.544 List.653 List.545;
|
||||
let List.650 : U8 = 1i64;
|
||||
let List.651 : U8 = GetTagId List.645;
|
||||
let List.652 : Int1 = lowlevel Eq List.650 List.651;
|
||||
if List.652 then
|
||||
let List.548 : {} = UnionAtIndex (Id 1) (Index 0) List.645;
|
||||
let List.648 : U64 = 1i64;
|
||||
let List.647 : U64 = CallByName Num.51 List.546 List.648;
|
||||
jump List.642 List.543 List.548 List.545 List.647 List.547;
|
||||
joinpoint List.654 List.544 List.545 List.546 List.547 List.548:
|
||||
let List.656 : Int1 = CallByName Num.22 List.547 List.548;
|
||||
if List.656 then
|
||||
let List.665 : {[<r>C I64, C List *self], [<r>C I64, C List *self]} = CallByName List.66 List.544 List.547;
|
||||
inc List.665;
|
||||
let List.657 : [C {}, C {}] = CallByName List.244 List.545 List.665 List.546;
|
||||
let List.662 : U8 = 1i64;
|
||||
let List.663 : U8 = GetTagId List.657;
|
||||
let List.664 : Int1 = lowlevel Eq List.662 List.663;
|
||||
if List.664 then
|
||||
let List.549 : {} = UnionAtIndex (Id 1) (Index 0) List.657;
|
||||
let List.660 : U64 = 1i64;
|
||||
let List.659 : U64 = CallByName Num.51 List.547 List.660;
|
||||
jump List.654 List.544 List.549 List.546 List.659 List.548;
|
||||
else
|
||||
dec List.543;
|
||||
let List.549 : {} = UnionAtIndex (Id 0) (Index 0) List.645;
|
||||
let List.649 : [C {}, C {}] = TagId(0) List.549;
|
||||
ret List.649;
|
||||
dec List.544;
|
||||
let List.550 : {} = UnionAtIndex (Id 0) (Index 0) List.657;
|
||||
let List.661 : [C {}, C {}] = TagId(0) List.550;
|
||||
ret List.661;
|
||||
else
|
||||
dec List.543;
|
||||
let List.643 : [C {}, C {}] = TagId(1) List.544;
|
||||
ret List.643;
|
||||
dec List.544;
|
||||
let List.655 : [C {}, C {}] = TagId(1) List.545;
|
||||
ret List.655;
|
||||
in
|
||||
inc #Derived_gen.7;
|
||||
jump List.642 #Derived_gen.7 #Derived_gen.8 #Derived_gen.9 #Derived_gen.10 #Derived_gen.11;
|
||||
jump List.654 #Derived_gen.7 #Derived_gen.8 #Derived_gen.9 #Derived_gen.10 #Derived_gen.11;
|
||||
|
||||
procedure Num.148 (Num.225, Num.226):
|
||||
let Num.288 : Int1 = CallByName Num.22 Num.225 Num.226;
|
||||
|
@ -138,7 +138,7 @@ procedure Num.51 (#Attr.2, #Attr.3):
|
|||
let Num.284 : U64 = lowlevel NumAddWrap #Attr.2 #Attr.3;
|
||||
ret Num.284;
|
||||
|
||||
procedure Test.1 (#Derived_gen.0):
|
||||
procedure Test.1 (#Derived_gen.6):
|
||||
joinpoint Test.26 Test.6:
|
||||
let Test.65 : [<r>C I64, C List *self] = StructAtIndex 1 Test.6;
|
||||
let Test.66 : U8 = 0i64;
|
||||
|
@ -220,7 +220,7 @@ procedure Test.1 (#Derived_gen.0):
|
|||
let Test.44 : {[<r>C I64, C List *self], [<r>C I64, C List *self]} = Struct {Test.45, Test.46};
|
||||
jump Test.26 Test.44;
|
||||
in
|
||||
jump Test.26 #Derived_gen.0;
|
||||
jump Test.26 #Derived_gen.6;
|
||||
|
||||
procedure Test.15 (Test.16, Test.17):
|
||||
let Test.36 : {[<r>C I64, C List *self], [<r>C I64, C List *self]} = Struct {Test.16, Test.17};
|
||||
|
|
|
@ -1,33 +1,33 @@
|
|||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : [<rnu><null>, C {[<rnu>C *self, <null>], *self}] = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : [<rnu><null>, C {[<rnu>C *self, <null>], *self}] = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.637 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.637;
|
||||
let List.649 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.649;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : [<rnu>C *self, <null>] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : [<rnu>C *self, <null>] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.96 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : [<rnu>C *self, <null>] = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : [<rnu><null>, C {[<rnu>C *self, <null>], *self}] = CallByName Test.7 List.171 List.635;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : [<rnu>C *self, <null>] = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : [<rnu><null>, C {[<rnu>C *self, <null>], *self}] = CallByName Test.7 List.172 List.647;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.0;
|
||||
jump List.629 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
jump List.641 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
18
crates/compiler/test_mono/generated/list_append.txt
generated
18
crates/compiler/test_mono/generated/list_append.txt
generated
|
@ -1,16 +1,16 @@
|
|||
procedure List.4 (List.131, List.132):
|
||||
let List.629 : U64 = 1i64;
|
||||
let List.627 : List I64 = CallByName List.70 List.131 List.629;
|
||||
let List.626 : List I64 = CallByName List.71 List.627 List.132;
|
||||
ret List.626;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.641 : U64 = 1i64;
|
||||
let List.639 : List I64 = CallByName List.70 List.132 List.641;
|
||||
let List.638 : List I64 = CallByName List.71 List.639 List.133;
|
||||
ret List.638;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.630 : List I64 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.630;
|
||||
let List.642 : List I64 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.642;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.628 : List I64 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.628;
|
||||
let List.640 : List I64 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.640;
|
||||
|
||||
procedure Test.0 ():
|
||||
let Test.2 : List I64 = Array [1i64];
|
||||
|
|
|
@ -1,16 +1,16 @@
|
|||
procedure List.4 (List.131, List.132):
|
||||
let List.629 : U64 = 1i64;
|
||||
let List.627 : List I64 = CallByName List.70 List.131 List.629;
|
||||
let List.626 : List I64 = CallByName List.71 List.627 List.132;
|
||||
ret List.626;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.641 : U64 = 1i64;
|
||||
let List.639 : List I64 = CallByName List.70 List.132 List.641;
|
||||
let List.638 : List I64 = CallByName List.71 List.639 List.133;
|
||||
ret List.638;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.630 : List I64 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.630;
|
||||
let List.642 : List I64 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.642;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.628 : List I64 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.628;
|
||||
let List.640 : List I64 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.640;
|
||||
|
||||
procedure Test.1 (Test.2):
|
||||
let Test.6 : I64 = 42i64;
|
||||
|
|
|
@ -1,25 +1,25 @@
|
|||
procedure List.3 (List.123, List.124, List.125):
|
||||
let List.629 : {List I64, I64} = CallByName List.64 List.123 List.124 List.125;
|
||||
let List.628 : List I64 = StructAtIndex 0 List.629;
|
||||
ret List.628;
|
||||
procedure List.3 (List.124, List.125, List.126):
|
||||
let List.641 : {List I64, I64} = CallByName List.64 List.124 List.125 List.126;
|
||||
let List.640 : List I64 = StructAtIndex 0 List.641;
|
||||
ret List.640;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.627 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.627;
|
||||
let List.639 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.639;
|
||||
|
||||
procedure List.64 (List.120, List.121, List.122):
|
||||
let List.634 : U64 = CallByName List.6 List.120;
|
||||
let List.631 : Int1 = CallByName Num.22 List.121 List.634;
|
||||
if List.631 then
|
||||
let List.632 : {List I64, I64} = CallByName List.67 List.120 List.121 List.122;
|
||||
ret List.632;
|
||||
procedure List.64 (List.121, List.122, List.123):
|
||||
let List.646 : U64 = CallByName List.6 List.121;
|
||||
let List.643 : Int1 = CallByName Num.22 List.122 List.646;
|
||||
if List.643 then
|
||||
let List.644 : {List I64, I64} = CallByName List.67 List.121 List.122 List.123;
|
||||
ret List.644;
|
||||
else
|
||||
let List.630 : {List I64, I64} = Struct {List.120, List.122};
|
||||
ret List.630;
|
||||
let List.642 : {List I64, I64} = Struct {List.121, List.123};
|
||||
ret List.642;
|
||||
|
||||
procedure List.67 (#Attr.2, #Attr.3, #Attr.4):
|
||||
let List.633 : {List I64, I64} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.633;
|
||||
let List.645 : {List I64, I64} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.645;
|
||||
|
||||
procedure Num.19 (#Attr.2, #Attr.3):
|
||||
let Num.281 : U64 = lowlevel NumAdd #Attr.2 #Attr.3;
|
||||
|
|
28
crates/compiler/test_mono/generated/list_get.txt
generated
28
crates/compiler/test_mono/generated/list_get.txt
generated
|
@ -1,22 +1,22 @@
|
|||
procedure List.2 (List.115, List.116):
|
||||
let List.632 : U64 = CallByName List.6 List.115;
|
||||
let List.628 : Int1 = CallByName Num.22 List.116 List.632;
|
||||
if List.628 then
|
||||
let List.630 : I64 = CallByName List.66 List.115 List.116;
|
||||
let List.629 : [C {}, C I64] = TagId(1) List.630;
|
||||
ret List.629;
|
||||
procedure List.2 (List.116, List.117):
|
||||
let List.644 : U64 = CallByName List.6 List.116;
|
||||
let List.640 : Int1 = CallByName Num.22 List.117 List.644;
|
||||
if List.640 then
|
||||
let List.642 : I64 = CallByName List.66 List.116 List.117;
|
||||
let List.641 : [C {}, C I64] = TagId(1) List.642;
|
||||
ret List.641;
|
||||
else
|
||||
let List.627 : {} = Struct {};
|
||||
let List.626 : [C {}, C I64] = TagId(0) List.627;
|
||||
ret List.626;
|
||||
let List.639 : {} = Struct {};
|
||||
let List.638 : [C {}, C I64] = TagId(0) List.639;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.633 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.633;
|
||||
let List.645 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.645;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.631 : I64 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.631;
|
||||
let List.643 : I64 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.643;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.281 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
8
crates/compiler/test_mono/generated/list_len.txt
generated
8
crates/compiler/test_mono/generated/list_len.txt
generated
|
@ -1,10 +1,10 @@
|
|||
procedure List.6 (#Attr.2):
|
||||
let List.626 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.626;
|
||||
let List.638 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.627 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.627;
|
||||
let List.639 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.639;
|
||||
|
||||
procedure Num.19 (#Attr.2, #Attr.3):
|
||||
let Num.281 : U64 = lowlevel NumAdd #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,66 +1,66 @@
|
|||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.638 : U64 = 0i64;
|
||||
let List.639 : U64 = CallByName List.6 List.167;
|
||||
let List.637 : List Str = CallByName List.96 List.167 List.168 List.169 List.638 List.639;
|
||||
ret List.637;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.650 : U64 = 0i64;
|
||||
let List.651 : U64 = CallByName List.6 List.168;
|
||||
let List.649 : List Str = CallByName List.97 List.168 List.169 List.170 List.650 List.651;
|
||||
ret List.649;
|
||||
|
||||
procedure List.2 (List.115, List.116):
|
||||
let List.632 : U64 = CallByName List.6 List.115;
|
||||
let List.628 : Int1 = CallByName Num.22 List.116 List.632;
|
||||
if List.628 then
|
||||
let List.630 : Str = CallByName List.66 List.115 List.116;
|
||||
inc List.630;
|
||||
let List.629 : [C {}, C Str] = TagId(1) List.630;
|
||||
ret List.629;
|
||||
procedure List.2 (List.116, List.117):
|
||||
let List.644 : U64 = CallByName List.6 List.116;
|
||||
let List.640 : Int1 = CallByName Num.22 List.117 List.644;
|
||||
if List.640 then
|
||||
let List.642 : Str = CallByName List.66 List.116 List.117;
|
||||
inc List.642;
|
||||
let List.641 : [C {}, C Str] = TagId(1) List.642;
|
||||
ret List.641;
|
||||
else
|
||||
let List.627 : {} = Struct {};
|
||||
let List.626 : [C {}, C Str] = TagId(0) List.627;
|
||||
ret List.626;
|
||||
let List.639 : {} = Struct {};
|
||||
let List.638 : [C {}, C Str] = TagId(0) List.639;
|
||||
ret List.638;
|
||||
|
||||
procedure List.279 (List.280, List.281, List.277):
|
||||
let List.649 : Str = CallByName Test.3 List.281;
|
||||
let List.648 : List Str = CallByName List.71 List.280 List.649;
|
||||
ret List.648;
|
||||
procedure List.280 (List.281, List.282, List.278):
|
||||
let List.661 : Str = CallByName Test.3 List.282;
|
||||
let List.660 : List Str = CallByName List.71 List.281 List.661;
|
||||
ret List.660;
|
||||
|
||||
procedure List.5 (List.276, List.277):
|
||||
let List.278 : U64 = CallByName List.6 List.276;
|
||||
let List.635 : List Str = CallByName List.68 List.278;
|
||||
let List.634 : List Str = CallByName List.18 List.276 List.635 List.277;
|
||||
ret List.634;
|
||||
procedure List.5 (List.277, List.278):
|
||||
let List.279 : U64 = CallByName List.6 List.277;
|
||||
let List.647 : List Str = CallByName List.68 List.279;
|
||||
let List.646 : List Str = CallByName List.18 List.277 List.647 List.278;
|
||||
ret List.646;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.633 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.633;
|
||||
let List.645 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.645;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.631 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.631;
|
||||
let List.643 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.643;
|
||||
|
||||
procedure List.68 (#Attr.2):
|
||||
let List.651 : List Str = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.651;
|
||||
let List.663 : List Str = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.663;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.650 : List Str = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.650;
|
||||
let List.662 : List Str = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.662;
|
||||
|
||||
procedure List.96 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.640 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.642 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.642 then
|
||||
let List.646 : Str = CallByName List.66 List.170 List.173;
|
||||
inc List.646;
|
||||
let List.175 : List Str = CallByName List.279 List.171 List.646 List.172;
|
||||
dec List.646;
|
||||
let List.645 : U64 = 1i64;
|
||||
let List.644 : U64 = CallByName Num.51 List.173 List.645;
|
||||
jump List.640 List.170 List.175 List.172 List.644 List.174;
|
||||
procedure List.97 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.652 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.654 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.654 then
|
||||
let List.658 : Str = CallByName List.66 List.171 List.174;
|
||||
inc List.658;
|
||||
let List.176 : List Str = CallByName List.280 List.172 List.658 List.173;
|
||||
dec List.658;
|
||||
let List.657 : U64 = 1i64;
|
||||
let List.656 : U64 = CallByName Num.51 List.174 List.657;
|
||||
jump List.652 List.171 List.176 List.173 List.656 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.0;
|
||||
jump List.640 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
jump List.652 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,65 +1,65 @@
|
|||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.638 : U64 = 0i64;
|
||||
let List.639 : U64 = CallByName List.6 List.167;
|
||||
let List.637 : List Str = CallByName List.96 List.167 List.168 List.169 List.638 List.639;
|
||||
ret List.637;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.650 : U64 = 0i64;
|
||||
let List.651 : U64 = CallByName List.6 List.168;
|
||||
let List.649 : List Str = CallByName List.97 List.168 List.169 List.170 List.650 List.651;
|
||||
ret List.649;
|
||||
|
||||
procedure List.2 (List.115, List.116):
|
||||
let List.632 : U64 = CallByName List.6 List.115;
|
||||
let List.628 : Int1 = CallByName Num.22 List.116 List.632;
|
||||
if List.628 then
|
||||
let List.630 : Str = CallByName List.66 List.115 List.116;
|
||||
inc List.630;
|
||||
let List.629 : [C {}, C Str] = TagId(1) List.630;
|
||||
ret List.629;
|
||||
procedure List.2 (List.116, List.117):
|
||||
let List.644 : U64 = CallByName List.6 List.116;
|
||||
let List.640 : Int1 = CallByName Num.22 List.117 List.644;
|
||||
if List.640 then
|
||||
let List.642 : Str = CallByName List.66 List.116 List.117;
|
||||
inc List.642;
|
||||
let List.641 : [C {}, C Str] = TagId(1) List.642;
|
||||
ret List.641;
|
||||
else
|
||||
let List.627 : {} = Struct {};
|
||||
let List.626 : [C {}, C Str] = TagId(0) List.627;
|
||||
ret List.626;
|
||||
let List.639 : {} = Struct {};
|
||||
let List.638 : [C {}, C Str] = TagId(0) List.639;
|
||||
ret List.638;
|
||||
|
||||
procedure List.279 (List.280, List.281, List.277):
|
||||
let List.649 : Str = CallByName Test.3 List.281;
|
||||
let List.648 : List Str = CallByName List.71 List.280 List.649;
|
||||
ret List.648;
|
||||
procedure List.280 (List.281, List.282, List.278):
|
||||
let List.661 : Str = CallByName Test.3 List.282;
|
||||
let List.660 : List Str = CallByName List.71 List.281 List.661;
|
||||
ret List.660;
|
||||
|
||||
procedure List.5 (List.276, List.277):
|
||||
let List.278 : U64 = CallByName List.6 List.276;
|
||||
let List.635 : List Str = CallByName List.68 List.278;
|
||||
let List.634 : List Str = CallByName List.18 List.276 List.635 List.277;
|
||||
ret List.634;
|
||||
procedure List.5 (List.277, List.278):
|
||||
let List.279 : U64 = CallByName List.6 List.277;
|
||||
let List.647 : List Str = CallByName List.68 List.279;
|
||||
let List.646 : List Str = CallByName List.18 List.277 List.647 List.278;
|
||||
ret List.646;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.633 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.633;
|
||||
let List.645 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.645;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.631 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.631;
|
||||
let List.643 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.643;
|
||||
|
||||
procedure List.68 (#Attr.2):
|
||||
let List.651 : List Str = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.651;
|
||||
let List.663 : List Str = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.663;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.650 : List Str = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.650;
|
||||
let List.662 : List Str = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.662;
|
||||
|
||||
procedure List.96 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.640 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.642 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.642 then
|
||||
let List.646 : Str = CallByName List.66 List.170 List.173;
|
||||
inc List.646;
|
||||
let List.175 : List Str = CallByName List.279 List.171 List.646 List.172;
|
||||
let List.645 : U64 = 1i64;
|
||||
let List.644 : U64 = CallByName Num.51 List.173 List.645;
|
||||
jump List.640 List.170 List.175 List.172 List.644 List.174;
|
||||
procedure List.97 (#Derived_gen.3, #Derived_gen.4, #Derived_gen.5, #Derived_gen.6, #Derived_gen.7):
|
||||
joinpoint List.652 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.654 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.654 then
|
||||
let List.658 : Str = CallByName List.66 List.171 List.174;
|
||||
inc List.658;
|
||||
let List.176 : List Str = CallByName List.280 List.172 List.658 List.173;
|
||||
let List.657 : U64 = 1i64;
|
||||
let List.656 : U64 = CallByName Num.51 List.174 List.657;
|
||||
jump List.652 List.171 List.176 List.173 List.656 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.0;
|
||||
jump List.640 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
inc #Derived_gen.3;
|
||||
jump List.652 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5 #Derived_gen.6 #Derived_gen.7;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,66 +1,66 @@
|
|||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.630 : U64 = 0i64;
|
||||
let List.631 : U64 = CallByName List.6 List.167;
|
||||
let List.629 : List U8 = CallByName List.96 List.167 List.168 List.169 List.630 List.631;
|
||||
ret List.629;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.642 : U64 = 0i64;
|
||||
let List.643 : U64 = CallByName List.6 List.168;
|
||||
let List.641 : List U8 = CallByName List.97 List.168 List.169 List.170 List.642 List.643;
|
||||
ret List.641;
|
||||
|
||||
procedure List.279 (List.280, List.281, List.277):
|
||||
let List.645 : U8 = GetTagId List.277;
|
||||
joinpoint List.646 List.643:
|
||||
let List.642 : List U8 = CallByName List.71 List.280 List.643;
|
||||
ret List.642;
|
||||
procedure List.280 (List.281, List.282, List.278):
|
||||
let List.657 : U8 = GetTagId List.278;
|
||||
joinpoint List.658 List.655:
|
||||
let List.654 : List U8 = CallByName List.71 List.281 List.655;
|
||||
ret List.654;
|
||||
in
|
||||
switch List.645:
|
||||
switch List.657:
|
||||
case 0:
|
||||
let List.647 : U8 = CallByName Test.4 List.281 List.277;
|
||||
jump List.646 List.647;
|
||||
let List.659 : U8 = CallByName Test.4 List.282 List.278;
|
||||
jump List.658 List.659;
|
||||
|
||||
case 1:
|
||||
let List.647 : U8 = CallByName Test.6 List.281 List.277;
|
||||
jump List.646 List.647;
|
||||
let List.659 : U8 = CallByName Test.6 List.282 List.278;
|
||||
jump List.658 List.659;
|
||||
|
||||
default:
|
||||
let List.647 : U8 = CallByName Test.8 List.281;
|
||||
jump List.646 List.647;
|
||||
let List.659 : U8 = CallByName Test.8 List.282;
|
||||
jump List.658 List.659;
|
||||
|
||||
|
||||
procedure List.5 (List.276, List.277):
|
||||
let List.278 : U64 = CallByName List.6 List.276;
|
||||
let List.627 : List U8 = CallByName List.68 List.278;
|
||||
let List.626 : List U8 = CallByName List.18 List.276 List.627 List.277;
|
||||
ret List.626;
|
||||
procedure List.5 (List.277, List.278):
|
||||
let List.279 : U64 = CallByName List.6 List.277;
|
||||
let List.639 : List U8 = CallByName List.68 List.279;
|
||||
let List.638 : List U8 = CallByName List.18 List.277 List.639 List.278;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.640 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.640;
|
||||
let List.652 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.652;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.639 : U8 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.639;
|
||||
let List.651 : U8 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.651;
|
||||
|
||||
procedure List.68 (#Attr.2):
|
||||
let List.648 : List U8 = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.648;
|
||||
let List.660 : List U8 = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.660;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.644 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.644;
|
||||
let List.656 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.656;
|
||||
|
||||
procedure List.96 (#Derived_gen.3, #Derived_gen.4, #Derived_gen.5, #Derived_gen.6, #Derived_gen.7):
|
||||
joinpoint List.632 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.634 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.634 then
|
||||
let List.638 : U8 = CallByName List.66 List.170 List.173;
|
||||
let List.175 : List U8 = CallByName List.279 List.171 List.638 List.172;
|
||||
let List.637 : U64 = 1i64;
|
||||
let List.636 : U64 = CallByName Num.51 List.173 List.637;
|
||||
jump List.632 List.170 List.175 List.172 List.636 List.174;
|
||||
procedure List.97 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.644 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.646 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.646 then
|
||||
let List.650 : U8 = CallByName List.66 List.171 List.174;
|
||||
let List.176 : List U8 = CallByName List.280 List.172 List.650 List.173;
|
||||
let List.649 : U64 = 1i64;
|
||||
let List.648 : U64 = CallByName Num.51 List.174 List.649;
|
||||
jump List.644 List.171 List.176 List.173 List.648 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.3;
|
||||
jump List.632 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5 #Derived_gen.6 #Derived_gen.7;
|
||||
inc #Derived_gen.0;
|
||||
jump List.644 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
|
||||
procedure Num.19 (#Attr.2, #Attr.3):
|
||||
let Num.283 : U8 = lowlevel NumAdd #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,25 +1,25 @@
|
|||
procedure List.3 (List.123, List.124, List.125):
|
||||
let List.627 : {List I64, I64} = CallByName List.64 List.123 List.124 List.125;
|
||||
let List.626 : List I64 = StructAtIndex 0 List.627;
|
||||
ret List.626;
|
||||
procedure List.3 (List.124, List.125, List.126):
|
||||
let List.639 : {List I64, I64} = CallByName List.64 List.124 List.125 List.126;
|
||||
let List.638 : List I64 = StructAtIndex 0 List.639;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.633 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.633;
|
||||
let List.645 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.645;
|
||||
|
||||
procedure List.64 (List.120, List.121, List.122):
|
||||
let List.632 : U64 = CallByName List.6 List.120;
|
||||
let List.629 : Int1 = CallByName Num.22 List.121 List.632;
|
||||
if List.629 then
|
||||
let List.630 : {List I64, I64} = CallByName List.67 List.120 List.121 List.122;
|
||||
ret List.630;
|
||||
procedure List.64 (List.121, List.122, List.123):
|
||||
let List.644 : U64 = CallByName List.6 List.121;
|
||||
let List.641 : Int1 = CallByName Num.22 List.122 List.644;
|
||||
if List.641 then
|
||||
let List.642 : {List I64, I64} = CallByName List.67 List.121 List.122 List.123;
|
||||
ret List.642;
|
||||
else
|
||||
let List.628 : {List I64, I64} = Struct {List.120, List.122};
|
||||
ret List.628;
|
||||
let List.640 : {List I64, I64} = Struct {List.121, List.123};
|
||||
ret List.640;
|
||||
|
||||
procedure List.67 (#Attr.2, #Attr.3, #Attr.4):
|
||||
let List.631 : {List I64, I64} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.631;
|
||||
let List.643 : {List I64, I64} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.643;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.281 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,11 +1,11 @@
|
|||
procedure List.28 (#Attr.2, #Attr.3):
|
||||
let List.628 : List I64 = lowlevel ListSortWith { xs: `#Attr.#arg1` } #Attr.2 Num.46 #Attr.3;
|
||||
ret List.628;
|
||||
let List.640 : List I64 = lowlevel ListSortWith { xs: `#Attr.#arg1` } #Attr.2 Num.46 #Attr.3;
|
||||
ret List.640;
|
||||
|
||||
procedure List.59 (List.382):
|
||||
let List.627 : {} = Struct {};
|
||||
let List.626 : List I64 = CallByName List.28 List.382 List.627;
|
||||
ret List.626;
|
||||
procedure List.59 (List.383):
|
||||
let List.639 : {} = Struct {};
|
||||
let List.638 : List I64 = CallByName List.28 List.383 List.639;
|
||||
ret List.638;
|
||||
|
||||
procedure Num.46 (#Attr.2, #Attr.3):
|
||||
let Num.281 : U8 = lowlevel NumCompare #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,41 +1,41 @@
|
|||
procedure List.2 (List.115, List.116):
|
||||
let List.648 : U64 = CallByName List.6 List.115;
|
||||
let List.645 : Int1 = CallByName Num.22 List.116 List.648;
|
||||
if List.645 then
|
||||
let List.647 : I64 = CallByName List.66 List.115 List.116;
|
||||
let List.646 : [C {}, C I64] = TagId(1) List.647;
|
||||
ret List.646;
|
||||
procedure List.2 (List.116, List.117):
|
||||
let List.660 : U64 = CallByName List.6 List.116;
|
||||
let List.657 : Int1 = CallByName Num.22 List.117 List.660;
|
||||
if List.657 then
|
||||
let List.659 : I64 = CallByName List.66 List.116 List.117;
|
||||
let List.658 : [C {}, C I64] = TagId(1) List.659;
|
||||
ret List.658;
|
||||
else
|
||||
let List.644 : {} = Struct {};
|
||||
let List.643 : [C {}, C I64] = TagId(0) List.644;
|
||||
ret List.643;
|
||||
let List.656 : {} = Struct {};
|
||||
let List.655 : [C {}, C I64] = TagId(0) List.656;
|
||||
ret List.655;
|
||||
|
||||
procedure List.3 (List.123, List.124, List.125):
|
||||
let List.635 : {List I64, I64} = CallByName List.64 List.123 List.124 List.125;
|
||||
let List.634 : List I64 = StructAtIndex 0 List.635;
|
||||
ret List.634;
|
||||
procedure List.3 (List.124, List.125, List.126):
|
||||
let List.647 : {List I64, I64} = CallByName List.64 List.124 List.125 List.126;
|
||||
let List.646 : List I64 = StructAtIndex 0 List.647;
|
||||
ret List.646;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.633 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.633;
|
||||
let List.645 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.645;
|
||||
|
||||
procedure List.64 (List.120, List.121, List.122):
|
||||
let List.632 : U64 = CallByName List.6 List.120;
|
||||
let List.629 : Int1 = CallByName Num.22 List.121 List.632;
|
||||
if List.629 then
|
||||
let List.630 : {List I64, I64} = CallByName List.67 List.120 List.121 List.122;
|
||||
ret List.630;
|
||||
procedure List.64 (List.121, List.122, List.123):
|
||||
let List.644 : U64 = CallByName List.6 List.121;
|
||||
let List.641 : Int1 = CallByName Num.22 List.122 List.644;
|
||||
if List.641 then
|
||||
let List.642 : {List I64, I64} = CallByName List.67 List.121 List.122 List.123;
|
||||
ret List.642;
|
||||
else
|
||||
let List.628 : {List I64, I64} = Struct {List.120, List.122};
|
||||
ret List.628;
|
||||
let List.640 : {List I64, I64} = Struct {List.121, List.123};
|
||||
ret List.640;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.641 : I64 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.641;
|
||||
let List.653 : I64 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.653;
|
||||
|
||||
procedure List.67 (#Attr.2, #Attr.3, #Attr.4):
|
||||
let List.631 : {List I64, I64} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.631;
|
||||
let List.643 : {List I64, I64} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.643;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.283 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,25 +1,25 @@
|
|||
procedure List.3 (List.123, List.124, List.125):
|
||||
let List.635 : {List U64, U64} = CallByName List.64 List.123 List.124 List.125;
|
||||
let List.634 : List U64 = StructAtIndex 0 List.635;
|
||||
ret List.634;
|
||||
procedure List.3 (List.124, List.125, List.126):
|
||||
let List.647 : {List U64, U64} = CallByName List.64 List.124 List.125 List.126;
|
||||
let List.646 : List U64 = StructAtIndex 0 List.647;
|
||||
ret List.646;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.633 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.633;
|
||||
let List.645 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.645;
|
||||
|
||||
procedure List.64 (List.120, List.121, List.122):
|
||||
let List.632 : U64 = CallByName List.6 List.120;
|
||||
let List.629 : Int1 = CallByName Num.22 List.121 List.632;
|
||||
if List.629 then
|
||||
let List.630 : {List U64, U64} = CallByName List.67 List.120 List.121 List.122;
|
||||
ret List.630;
|
||||
procedure List.64 (List.121, List.122, List.123):
|
||||
let List.644 : U64 = CallByName List.6 List.121;
|
||||
let List.641 : Int1 = CallByName Num.22 List.122 List.644;
|
||||
if List.641 then
|
||||
let List.642 : {List U64, U64} = CallByName List.67 List.121 List.122 List.123;
|
||||
ret List.642;
|
||||
else
|
||||
let List.628 : {List U64, U64} = Struct {List.120, List.122};
|
||||
ret List.628;
|
||||
let List.640 : {List U64, U64} = Struct {List.121, List.123};
|
||||
ret List.640;
|
||||
|
||||
procedure List.67 (#Attr.2, #Attr.3, #Attr.4):
|
||||
let List.631 : {List U64, U64} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.631;
|
||||
let List.643 : {List U64, U64} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.643;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.281 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -1,52 +1,52 @@
|
|||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.630 : U64 = 0i64;
|
||||
let List.631 : U64 = CallByName List.6 List.167;
|
||||
let List.629 : List [<rnnu>C List *self] = CallByName List.96 List.167 List.168 List.169 List.630 List.631;
|
||||
ret List.629;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.642 : U64 = 0i64;
|
||||
let List.643 : U64 = CallByName List.6 List.168;
|
||||
let List.641 : List [<rnnu>C List *self] = CallByName List.97 List.168 List.169 List.170 List.642 List.643;
|
||||
ret List.641;
|
||||
|
||||
procedure List.279 (List.280, List.281, List.277):
|
||||
let List.643 : [<rnnu>C List *self] = CallByName Test.2 List.281;
|
||||
let List.642 : List [<rnnu>C List *self] = CallByName List.71 List.280 List.643;
|
||||
ret List.642;
|
||||
procedure List.280 (List.281, List.282, List.278):
|
||||
let List.655 : [<rnnu>C List *self] = CallByName Test.2 List.282;
|
||||
let List.654 : List [<rnnu>C List *self] = CallByName List.71 List.281 List.655;
|
||||
ret List.654;
|
||||
|
||||
procedure List.5 (List.276, List.277):
|
||||
let List.278 : U64 = CallByName List.6 List.276;
|
||||
let List.627 : List [<rnnu>C List *self] = CallByName List.68 List.278;
|
||||
let List.626 : List [<rnnu>C List *self] = CallByName List.18 List.276 List.627 List.277;
|
||||
ret List.626;
|
||||
procedure List.5 (List.277, List.278):
|
||||
let List.279 : U64 = CallByName List.6 List.277;
|
||||
let List.639 : List [<rnnu>C List *self] = CallByName List.68 List.279;
|
||||
let List.638 : List [<rnnu>C List *self] = CallByName List.18 List.277 List.639 List.278;
|
||||
ret List.638;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.640 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.640;
|
||||
let List.652 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.652;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.639 : [<rnnu>C List *self] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.639;
|
||||
let List.651 : [<rnnu>C List *self] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.651;
|
||||
|
||||
procedure List.68 (#Attr.2):
|
||||
let List.645 : List [<rnnu>C List *self] = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.645;
|
||||
let List.657 : List [<rnnu>C List *self] = lowlevel ListWithCapacity #Attr.2;
|
||||
ret List.657;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.644 : List [<rnnu>C List *self] = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.644;
|
||||
let List.656 : List [<rnnu>C List *self] = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.656;
|
||||
|
||||
procedure List.96 (#Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4, #Derived_gen.5):
|
||||
joinpoint List.632 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.634 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.634 then
|
||||
let List.638 : [<rnnu>C List *self] = CallByName List.66 List.170 List.173;
|
||||
inc List.638;
|
||||
let List.175 : List [<rnnu>C List *self] = CallByName List.279 List.171 List.638 List.172;
|
||||
let List.637 : U64 = 1i64;
|
||||
let List.636 : U64 = CallByName Num.51 List.173 List.637;
|
||||
jump List.632 List.170 List.175 List.172 List.636 List.174;
|
||||
procedure List.97 (#Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4, #Derived_gen.5):
|
||||
joinpoint List.644 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.646 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.646 then
|
||||
let List.650 : [<rnnu>C List *self] = CallByName List.66 List.171 List.174;
|
||||
inc List.650;
|
||||
let List.176 : List [<rnnu>C List *self] = CallByName List.280 List.172 List.650 List.173;
|
||||
let List.649 : U64 = 1i64;
|
||||
let List.648 : U64 = CallByName Num.51 List.174 List.649;
|
||||
jump List.644 List.171 List.176 List.173 List.648 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.1;
|
||||
jump List.632 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5;
|
||||
jump List.644 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.282 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
56
crates/compiler/test_mono/generated/rigids.txt
generated
56
crates/compiler/test_mono/generated/rigids.txt
generated
|
@ -1,41 +1,41 @@
|
|||
procedure List.2 (List.115, List.116):
|
||||
let List.648 : U64 = CallByName List.6 List.115;
|
||||
let List.645 : Int1 = CallByName Num.22 List.116 List.648;
|
||||
if List.645 then
|
||||
let List.647 : I64 = CallByName List.66 List.115 List.116;
|
||||
let List.646 : [C {}, C I64] = TagId(1) List.647;
|
||||
ret List.646;
|
||||
procedure List.2 (List.116, List.117):
|
||||
let List.660 : U64 = CallByName List.6 List.116;
|
||||
let List.657 : Int1 = CallByName Num.22 List.117 List.660;
|
||||
if List.657 then
|
||||
let List.659 : I64 = CallByName List.66 List.116 List.117;
|
||||
let List.658 : [C {}, C I64] = TagId(1) List.659;
|
||||
ret List.658;
|
||||
else
|
||||
let List.644 : {} = Struct {};
|
||||
let List.643 : [C {}, C I64] = TagId(0) List.644;
|
||||
ret List.643;
|
||||
let List.656 : {} = Struct {};
|
||||
let List.655 : [C {}, C I64] = TagId(0) List.656;
|
||||
ret List.655;
|
||||
|
||||
procedure List.3 (List.123, List.124, List.125):
|
||||
let List.635 : {List I64, I64} = CallByName List.64 List.123 List.124 List.125;
|
||||
let List.634 : List I64 = StructAtIndex 0 List.635;
|
||||
ret List.634;
|
||||
procedure List.3 (List.124, List.125, List.126):
|
||||
let List.647 : {List I64, I64} = CallByName List.64 List.124 List.125 List.126;
|
||||
let List.646 : List I64 = StructAtIndex 0 List.647;
|
||||
ret List.646;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.633 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.633;
|
||||
let List.645 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.645;
|
||||
|
||||
procedure List.64 (List.120, List.121, List.122):
|
||||
let List.632 : U64 = CallByName List.6 List.120;
|
||||
let List.629 : Int1 = CallByName Num.22 List.121 List.632;
|
||||
if List.629 then
|
||||
let List.630 : {List I64, I64} = CallByName List.67 List.120 List.121 List.122;
|
||||
ret List.630;
|
||||
procedure List.64 (List.121, List.122, List.123):
|
||||
let List.644 : U64 = CallByName List.6 List.121;
|
||||
let List.641 : Int1 = CallByName Num.22 List.122 List.644;
|
||||
if List.641 then
|
||||
let List.642 : {List I64, I64} = CallByName List.67 List.121 List.122 List.123;
|
||||
ret List.642;
|
||||
else
|
||||
let List.628 : {List I64, I64} = Struct {List.120, List.122};
|
||||
ret List.628;
|
||||
let List.640 : {List I64, I64} = Struct {List.121, List.123};
|
||||
ret List.640;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.641 : I64 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.641;
|
||||
let List.653 : I64 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.653;
|
||||
|
||||
procedure List.67 (#Attr.2, #Attr.3, #Attr.4):
|
||||
let List.631 : {List I64, I64} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.631;
|
||||
let List.643 : {List I64, I64} = lowlevel ListReplaceUnsafe #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.643;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.283 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
|
@ -30,57 +30,57 @@ procedure Encode.26 (Encode.107, Encode.108):
|
|||
ret Encode.110;
|
||||
|
||||
procedure List.13 (#Attr.2, #Attr.3):
|
||||
let List.652 : List Str = lowlevel ListPrepend #Attr.2 #Attr.3;
|
||||
ret List.652;
|
||||
let List.664 : List Str = lowlevel ListPrepend #Attr.2 #Attr.3;
|
||||
ret List.664;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : List U8 = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : List U8 = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.4 (List.131, List.132):
|
||||
let List.648 : U64 = 1i64;
|
||||
let List.647 : List U8 = CallByName List.70 List.131 List.648;
|
||||
let List.646 : List U8 = CallByName List.71 List.647 List.132;
|
||||
ret List.646;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.660 : U64 = 1i64;
|
||||
let List.659 : List U8 = CallByName List.70 List.132 List.660;
|
||||
let List.658 : List U8 = CallByName List.71 List.659 List.133;
|
||||
ret List.658;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.651 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.651;
|
||||
let List.663 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.663;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
let List.648 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.642 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.642;
|
||||
let List.654 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.654;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.640 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.640;
|
||||
let List.652 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.652;
|
||||
|
||||
procedure List.8 (#Attr.2, #Attr.3):
|
||||
let List.650 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.650;
|
||||
let List.662 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.662;
|
||||
|
||||
procedure List.96 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : Str = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : List U8 = CallByName Test.66 List.171 List.635 List.172;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.12, #Derived_gen.13, #Derived_gen.14, #Derived_gen.15, #Derived_gen.16):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : Str = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : List U8 = CallByName Test.66 List.172 List.647 List.173;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.0;
|
||||
jump List.629 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
inc #Derived_gen.12;
|
||||
jump List.641 #Derived_gen.12 #Derived_gen.13 #Derived_gen.14 #Derived_gen.15 #Derived_gen.16;
|
||||
|
||||
procedure Num.127 (#Attr.2):
|
||||
let Num.282 : U8 = lowlevel NumIntCast #Attr.2;
|
||||
|
|
|
@ -88,92 +88,92 @@ procedure Encode.26 (Encode.107, Encode.108):
|
|||
ret Encode.110;
|
||||
|
||||
procedure List.13 (#Attr.2, #Attr.3):
|
||||
let List.652 : List [C {}, C {}, C Str] = lowlevel ListPrepend #Attr.2 #Attr.3;
|
||||
ret List.652;
|
||||
let List.664 : List [C {}, C {}, C Str] = lowlevel ListPrepend #Attr.2 #Attr.3;
|
||||
ret List.664;
|
||||
|
||||
procedure List.13 (#Attr.2, #Attr.3):
|
||||
let List.680 : List Str = lowlevel ListPrepend #Attr.2 #Attr.3;
|
||||
ret List.680;
|
||||
let List.692 : List Str = lowlevel ListPrepend #Attr.2 #Attr.3;
|
||||
ret List.692;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.627 : U64 = 0i64;
|
||||
let List.628 : U64 = CallByName List.6 List.167;
|
||||
let List.626 : List U8 = CallByName List.96 List.167 List.168 List.169 List.627 List.628;
|
||||
ret List.626;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.639 : U64 = 0i64;
|
||||
let List.640 : U64 = CallByName List.6 List.168;
|
||||
let List.638 : List U8 = CallByName List.97 List.168 List.169 List.170 List.639 List.640;
|
||||
ret List.638;
|
||||
|
||||
procedure List.18 (List.167, List.168, List.169):
|
||||
let List.654 : U64 = 0i64;
|
||||
let List.655 : U64 = CallByName List.6 List.167;
|
||||
let List.653 : List U8 = CallByName List.96 List.167 List.168 List.169 List.654 List.655;
|
||||
ret List.653;
|
||||
procedure List.18 (List.168, List.169, List.170):
|
||||
let List.666 : U64 = 0i64;
|
||||
let List.667 : U64 = CallByName List.6 List.168;
|
||||
let List.665 : List U8 = CallByName List.97 List.168 List.169 List.170 List.666 List.667;
|
||||
ret List.665;
|
||||
|
||||
procedure List.4 (List.131, List.132):
|
||||
let List.675 : U64 = 1i64;
|
||||
let List.674 : List U8 = CallByName List.70 List.131 List.675;
|
||||
let List.673 : List U8 = CallByName List.71 List.674 List.132;
|
||||
ret List.673;
|
||||
procedure List.4 (List.132, List.133):
|
||||
let List.687 : U64 = 1i64;
|
||||
let List.686 : List U8 = CallByName List.70 List.132 List.687;
|
||||
let List.685 : List U8 = CallByName List.71 List.686 List.133;
|
||||
ret List.685;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.651 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.651;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.678 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.678;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.636 : [C {}, C {}, C Str] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.636;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.663 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
let List.663 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.663;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.690 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.690;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.648 : [C {}, C {}, C Str] = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.648;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.675 : Str = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.675;
|
||||
|
||||
procedure List.70 (#Attr.2, #Attr.3):
|
||||
let List.669 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.669;
|
||||
let List.681 : List U8 = lowlevel ListReserve #Attr.2 #Attr.3;
|
||||
ret List.681;
|
||||
|
||||
procedure List.71 (#Attr.2, #Attr.3):
|
||||
let List.667 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.667;
|
||||
let List.679 : List U8 = lowlevel ListAppendUnsafe #Attr.2 #Attr.3;
|
||||
ret List.679;
|
||||
|
||||
procedure List.8 (#Attr.2, #Attr.3):
|
||||
let List.677 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.677;
|
||||
let List.689 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3;
|
||||
ret List.689;
|
||||
|
||||
procedure List.96 (#Derived_gen.23, #Derived_gen.24, #Derived_gen.25, #Derived_gen.26, #Derived_gen.27):
|
||||
joinpoint List.656 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.658 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.658 then
|
||||
let List.662 : Str = CallByName List.66 List.170 List.173;
|
||||
inc List.662;
|
||||
let List.175 : List U8 = CallByName Test.66 List.171 List.662 List.172;
|
||||
let List.661 : U64 = 1i64;
|
||||
let List.660 : U64 = CallByName Num.51 List.173 List.661;
|
||||
jump List.656 List.170 List.175 List.172 List.660 List.174;
|
||||
procedure List.97 (#Derived_gen.38, #Derived_gen.39, #Derived_gen.40, #Derived_gen.41, #Derived_gen.42):
|
||||
joinpoint List.668 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.670 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.670 then
|
||||
let List.674 : Str = CallByName List.66 List.171 List.174;
|
||||
inc List.674;
|
||||
let List.176 : List U8 = CallByName Test.66 List.172 List.674 List.173;
|
||||
let List.673 : U64 = 1i64;
|
||||
let List.672 : U64 = CallByName Num.51 List.174 List.673;
|
||||
jump List.668 List.171 List.176 List.173 List.672 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.23;
|
||||
jump List.656 #Derived_gen.23 #Derived_gen.24 #Derived_gen.25 #Derived_gen.26 #Derived_gen.27;
|
||||
inc #Derived_gen.38;
|
||||
jump List.668 #Derived_gen.38 #Derived_gen.39 #Derived_gen.40 #Derived_gen.41 #Derived_gen.42;
|
||||
|
||||
procedure List.96 (#Derived_gen.46, #Derived_gen.47, #Derived_gen.48, #Derived_gen.49, #Derived_gen.50):
|
||||
joinpoint List.629 List.170 List.171 List.172 List.173 List.174:
|
||||
let List.631 : Int1 = CallByName Num.22 List.173 List.174;
|
||||
if List.631 then
|
||||
let List.635 : [C {}, C {}, C Str] = CallByName List.66 List.170 List.173;
|
||||
inc List.635;
|
||||
let List.175 : List U8 = CallByName Test.66 List.171 List.635 List.172;
|
||||
let List.634 : U64 = 1i64;
|
||||
let List.633 : U64 = CallByName Num.51 List.173 List.634;
|
||||
jump List.629 List.170 List.175 List.172 List.633 List.174;
|
||||
procedure List.97 (#Derived_gen.46, #Derived_gen.47, #Derived_gen.48, #Derived_gen.49, #Derived_gen.50):
|
||||
joinpoint List.641 List.171 List.172 List.173 List.174 List.175:
|
||||
let List.643 : Int1 = CallByName Num.22 List.174 List.175;
|
||||
if List.643 then
|
||||
let List.647 : [C {}, C {}, C Str] = CallByName List.66 List.171 List.174;
|
||||
inc List.647;
|
||||
let List.176 : List U8 = CallByName Test.66 List.172 List.647 List.173;
|
||||
let List.646 : U64 = 1i64;
|
||||
let List.645 : U64 = CallByName Num.51 List.174 List.646;
|
||||
jump List.641 List.171 List.176 List.173 List.645 List.175;
|
||||
else
|
||||
dec List.170;
|
||||
ret List.171;
|
||||
dec List.171;
|
||||
ret List.172;
|
||||
in
|
||||
inc #Derived_gen.46;
|
||||
jump List.629 #Derived_gen.46 #Derived_gen.47 #Derived_gen.48 #Derived_gen.49 #Derived_gen.50;
|
||||
jump List.641 #Derived_gen.46 #Derived_gen.47 #Derived_gen.48 #Derived_gen.49 #Derived_gen.50;
|
||||
|
||||
procedure Num.127 (#Attr.2):
|
||||
let Num.286 : U8 = lowlevel NumIntCast #Attr.2;
|
||||
|
|
|
@ -2,81 +2,81 @@ procedure Bool.11 (#Attr.2, #Attr.3):
|
|||
let Bool.23 : Int1 = lowlevel Eq #Attr.2 #Attr.3;
|
||||
ret Bool.23;
|
||||
|
||||
procedure List.111 (List.540, List.541, List.542):
|
||||
let List.644 : U64 = 0i64;
|
||||
let List.645 : U64 = CallByName List.6 List.540;
|
||||
let List.643 : [C U64, C U64] = CallByName List.80 List.540 List.541 List.542 List.644 List.645;
|
||||
ret List.643;
|
||||
procedure List.112 (List.541, List.542, List.543):
|
||||
let List.656 : U64 = 0i64;
|
||||
let List.657 : U64 = CallByName List.6 List.541;
|
||||
let List.655 : [C U64, C U64] = CallByName List.80 List.541 List.542 List.543 List.656 List.657;
|
||||
ret List.655;
|
||||
|
||||
procedure List.26 (List.208, List.209, List.210):
|
||||
let List.637 : [C U64, C U64] = CallByName List.111 List.208 List.209 List.210;
|
||||
let List.640 : U8 = 1i64;
|
||||
let List.641 : U8 = GetTagId List.637;
|
||||
let List.642 : Int1 = lowlevel Eq List.640 List.641;
|
||||
if List.642 then
|
||||
let List.211 : U64 = UnionAtIndex (Id 1) (Index 0) List.637;
|
||||
ret List.211;
|
||||
else
|
||||
let List.212 : U64 = UnionAtIndex (Id 0) (Index 0) List.637;
|
||||
procedure List.26 (List.209, List.210, List.211):
|
||||
let List.649 : [C U64, C U64] = CallByName List.112 List.209 List.210 List.211;
|
||||
let List.652 : U8 = 1i64;
|
||||
let List.653 : U8 = GetTagId List.649;
|
||||
let List.654 : Int1 = lowlevel Eq List.652 List.653;
|
||||
if List.654 then
|
||||
let List.212 : U64 = UnionAtIndex (Id 1) (Index 0) List.649;
|
||||
ret List.212;
|
||||
else
|
||||
let List.213 : U64 = UnionAtIndex (Id 0) (Index 0) List.649;
|
||||
ret List.213;
|
||||
|
||||
procedure List.38 (List.396, List.397):
|
||||
let List.636 : U64 = CallByName List.6 List.396;
|
||||
let List.398 : U64 = CallByName Num.77 List.636 List.397;
|
||||
let List.626 : List U8 = CallByName List.43 List.396 List.398;
|
||||
ret List.626;
|
||||
procedure List.38 (List.397, List.398):
|
||||
let List.648 : U64 = CallByName List.6 List.397;
|
||||
let List.399 : U64 = CallByName Num.77 List.648 List.398;
|
||||
let List.638 : List U8 = CallByName List.43 List.397 List.399;
|
||||
ret List.638;
|
||||
|
||||
procedure List.43 (List.394, List.395):
|
||||
let List.634 : U64 = CallByName List.6 List.394;
|
||||
let List.633 : U64 = CallByName Num.77 List.634 List.395;
|
||||
let List.628 : {U64, U64} = Struct {List.395, List.633};
|
||||
let List.627 : List U8 = CallByName List.49 List.394 List.628;
|
||||
ret List.627;
|
||||
procedure List.43 (List.395, List.396):
|
||||
let List.646 : U64 = CallByName List.6 List.395;
|
||||
let List.645 : U64 = CallByName Num.77 List.646 List.396;
|
||||
let List.640 : {U64, U64} = Struct {List.396, List.645};
|
||||
let List.639 : List U8 = CallByName List.49 List.395 List.640;
|
||||
ret List.639;
|
||||
|
||||
procedure List.49 (List.472, List.473):
|
||||
let List.630 : U64 = StructAtIndex 1 List.473;
|
||||
let List.631 : U64 = StructAtIndex 0 List.473;
|
||||
let List.629 : List U8 = CallByName List.72 List.472 List.630 List.631;
|
||||
ret List.629;
|
||||
procedure List.49 (List.473, List.474):
|
||||
let List.642 : U64 = StructAtIndex 1 List.474;
|
||||
let List.643 : U64 = StructAtIndex 0 List.474;
|
||||
let List.641 : List U8 = CallByName List.72 List.473 List.642 List.643;
|
||||
ret List.641;
|
||||
|
||||
procedure List.6 (#Attr.2):
|
||||
let List.635 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.635;
|
||||
let List.647 : U64 = lowlevel ListLenU64 #Attr.2;
|
||||
ret List.647;
|
||||
|
||||
procedure List.66 (#Attr.2, #Attr.3):
|
||||
let List.658 : U8 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.658;
|
||||
let List.670 : U8 = lowlevel ListGetUnsafe #Attr.2 #Attr.3;
|
||||
ret List.670;
|
||||
|
||||
procedure List.72 (#Attr.2, #Attr.3, #Attr.4):
|
||||
let List.632 : List U8 = lowlevel ListSublist #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.632;
|
||||
let List.644 : List U8 = lowlevel ListSublist #Attr.2 #Attr.3 #Attr.4;
|
||||
ret List.644;
|
||||
|
||||
procedure List.80 (#Derived_gen.0, #Derived_gen.1, #Derived_gen.2, #Derived_gen.3, #Derived_gen.4):
|
||||
joinpoint List.646 List.543 List.544 List.545 List.546 List.547:
|
||||
let List.648 : Int1 = CallByName Num.22 List.546 List.547;
|
||||
if List.648 then
|
||||
let List.657 : U8 = CallByName List.66 List.543 List.546;
|
||||
let List.649 : [C U64, C U64] = CallByName Test.3 List.544 List.657;
|
||||
let List.654 : U8 = 1i64;
|
||||
let List.655 : U8 = GetTagId List.649;
|
||||
let List.656 : Int1 = lowlevel Eq List.654 List.655;
|
||||
if List.656 then
|
||||
let List.548 : U64 = UnionAtIndex (Id 1) (Index 0) List.649;
|
||||
let List.652 : U64 = 1i64;
|
||||
let List.651 : U64 = CallByName Num.51 List.546 List.652;
|
||||
jump List.646 List.543 List.548 List.545 List.651 List.547;
|
||||
joinpoint List.658 List.544 List.545 List.546 List.547 List.548:
|
||||
let List.660 : Int1 = CallByName Num.22 List.547 List.548;
|
||||
if List.660 then
|
||||
let List.669 : U8 = CallByName List.66 List.544 List.547;
|
||||
let List.661 : [C U64, C U64] = CallByName Test.3 List.545 List.669;
|
||||
let List.666 : U8 = 1i64;
|
||||
let List.667 : U8 = GetTagId List.661;
|
||||
let List.668 : Int1 = lowlevel Eq List.666 List.667;
|
||||
if List.668 then
|
||||
let List.549 : U64 = UnionAtIndex (Id 1) (Index 0) List.661;
|
||||
let List.664 : U64 = 1i64;
|
||||
let List.663 : U64 = CallByName Num.51 List.547 List.664;
|
||||
jump List.658 List.544 List.549 List.546 List.663 List.548;
|
||||
else
|
||||
dec List.543;
|
||||
let List.549 : U64 = UnionAtIndex (Id 0) (Index 0) List.649;
|
||||
let List.653 : [C U64, C U64] = TagId(0) List.549;
|
||||
ret List.653;
|
||||
dec List.544;
|
||||
let List.550 : U64 = UnionAtIndex (Id 0) (Index 0) List.661;
|
||||
let List.665 : [C U64, C U64] = TagId(0) List.550;
|
||||
ret List.665;
|
||||
else
|
||||
dec List.543;
|
||||
let List.647 : [C U64, C U64] = TagId(1) List.544;
|
||||
ret List.647;
|
||||
dec List.544;
|
||||
let List.659 : [C U64, C U64] = TagId(1) List.545;
|
||||
ret List.659;
|
||||
in
|
||||
inc #Derived_gen.0;
|
||||
jump List.646 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
jump List.658 #Derived_gen.0 #Derived_gen.1 #Derived_gen.2 #Derived_gen.3 #Derived_gen.4;
|
||||
|
||||
procedure Num.22 (#Attr.2, #Attr.3):
|
||||
let Num.284 : Int1 = lowlevel NumLt #Attr.2 #Attr.3;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue