mirror of
https://github.com/anoma/juvix.git
synced 2024-11-30 14:13:27 +03:00
f2298bd674
An implementation of the translation from JuvixCore to JuvixAsm. After merging this PR, the only remaining step to complete the basic compilation pipeline (#1556) is the compilation of complex pattern matching (#1531). * Fixes several bugs in lambda-lifting. * Fixes several bugs in the RemoveTypeArgs transformation. * Fixes several bugs in the TopEtaExpand transformation. * Adds the ConvertBuiltinTypes transformation which converts the builtin bool inductive type to Core primitive bool. * Adds the `juvix dev core strip` command. * Adds the `juvix dev core asm` command. * Adds the `juvix dev core compile` command. * Adds two groups of tests: - JuvixCore to JuvixAsm translation: translate JuvixCore tests to JuvixAsm and run the results with the JuvixAsm interpreter, - JuvixCore compilation: compile JuvixCore tests to native code and WASM and execute the results. * Closes #1520 * Closes #1549
15 lines
331 B
Plaintext
15 lines
331 B
Plaintext
-- tail recursion
|
|
|
|
def sum' := \x \acc if x = 0 then acc else sum' (x - 1) (x + acc);
|
|
def sum := \x sum' x 0;
|
|
|
|
def fact' := \x \acc if x = 0 then acc else fact' (x - 1) (acc * x);
|
|
def fact := \x fact' x 1;
|
|
|
|
def writeLn := \x write x >> write "\n";
|
|
|
|
writeLn (sum 10000) >>
|
|
writeLn (fact 5) >>
|
|
writeLn (fact 10) >>
|
|
writeLn (fact 12)
|