32 lines
613 B
Nix
32 lines
613 B
Nix
with import ./lib.nix;
|
|
|
|
let {
|
|
|
|
range = first: last:
|
|
if builtins.lessThan last first
|
|
then []
|
|
else [first] ++ range (builtins.add first 1) last;
|
|
|
|
/* Supposedly tail recursive version:
|
|
|
|
range_ = accum: first: last:
|
|
if first == last then ([first] ++ accum)
|
|
else range_ ([first] ++ accum) (builtins.add first 1) last;
|
|
|
|
range = range_ [];
|
|
*/
|
|
|
|
x = 12;
|
|
|
|
body = sum
|
|
[ (sum (range 1 50))
|
|
(123 + 456)
|
|
(0 + -10 + -(-11) + -x)
|
|
(10 - 7 - -2)
|
|
(10 - (6 - -1))
|
|
(10 - 1 + 2)
|
|
(3 * 4 * 5)
|
|
(56088 / 123 / 2)
|
|
(3 + 4 * const 5 0 - 6 / id 2)
|
|
];
|
|
}
|