aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorGustav Sörnäs <gustav@sornas.net>2021-01-20 22:34:34 +0100
committerGustav Sörnäs <gustav@sornas.net>2021-01-20 22:34:34 +0100
commit9b8c64e6e9713441c1aa573cbdf137d5e4a424a8 (patch)
treedd7f9013c7614bf337c4ec309c7a436854d3edd0 /src
parent5d43ce4ab4b9c8d3ca8a0cb21f99b25e87e58fb4 (diff)
parent4a035f7aaa3220295afb8cd483fee5deb8f4edc3 (diff)
downloadsylt-9b8c64e6e9713441c1aa573cbdf137d5e4a424a8.tar.gz
Merge remote-tracking branch 'origin/main' into wip-close
Diffstat (limited to 'src')
-rw-r--r--src/lib.rs62
1 files changed, 61 insertions, 1 deletions
diff --git a/src/lib.rs b/src/lib.rs
index 971e42c..82905de 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -164,7 +164,67 @@ mod tests {
res <=> 1",
);
+ test_multiple!(
+ fun,
+ simplest: "f := fn {}
+ f()",
+ param_1: "f := fn a: int {}
+ f(1)",
+ return_1: "f := fn -> int {
+ ret 1
+ }
+ f() <=> 1",
+ param_and_return: "f := fn a: int -> int {
+ ret a * 2
+ }
+ f(1) <=> 2
+ f(5) <=> 10",
+ param_2: "add := fn a: int, b: int -> int {
+ ret a + b
+ }
+ add(1, 1) <=> 2
+ add(10, 20) <=> 30",
+ calls_inside_calls: "one := fn -> int {
+ ret 1
+ }
+ add := fn a: int, b: int -> int {
+ ret a + b
+ }
+ add(one(), one()) <=> 2
+ add(add(one(), one()), one()) <=> 3
+ add(one(), add(one(), one())) <=> 3",
+ passing_functions: "g := fn -> int {
+ ret 1
+ }
+ f := fn inner: fn -> int -> int {
+ ret inner()
+ }
+ f(g) <=> 1",
+ passing_functions_mixed: "g := fn a: int -> int {
+ ret a * 2
+ }
+ f := fn inner: fn int -> int, a: int -> int {
+ ret inner(a)
+ }
+ f(g, 2) <=> 4",
+ multiple_returns: "f := fn a: int -> int {
+ if a == 1 {
+ ret 2
+ } else {
+ ret 3
+ }
+ }
+ f(0) <=> 3
+ f(1) <=> 2
+ f(2) <=> 3",
+ precedence: "f := fn a: int, b: int -> int {
+ ret a + b
+ }
+ 1 + f(2, 3) <=> 6
+ 2 * f(2, 3) <=> 10
+ f(2, 3) - (2 + 3) <=> 0"
+ );
+
test_file!(scoping, "tests/scoping.tdy");
test_file!(for_, "tests/for.tdy");
- test_file!(fun, "tests/fun.tdy");
}