aboutsummaryrefslogtreecommitdiff
path: root/examples/fib.fwd
diff options
context:
space:
mode:
authorKimplul <kimi.h.kuparinen@gmail.com>2024-12-06 18:14:40 +0200
committerKimplul <kimi.h.kuparinen@gmail.com>2024-12-06 18:14:40 +0200
commite5fda1c96af409065fedbe032b0f7908d9f312ac (patch)
tree9558506a84f45c3b3e24c0cfd4ae5e43c973d04a /examples/fib.fwd
parent471ef9b710f88765d871ab079f8485ba0268201d (diff)
downloadfwd-e5fda1c96af409065fedbe032b0f7908d9f312ac.tar.gz
fwd-e5fda1c96af409065fedbe032b0f7908d9f312ac.zip
add types to parser
+ No actual type checking is implemented as of yet, but with references and pointers I should be able to start playing around with checking move semantics and so on + Might at some point also look into type propagation for let, annoying to have to specify the same thing twice.
Diffstat (limited to 'examples/fib.fwd')
-rw-r--r--examples/fib.fwd12
1 files changed, 6 insertions, 6 deletions
diff --git a/examples/fib.fwd b/examples/fib.fwd
index 8b0e055..4eb2e60 100644
--- a/examples/fib.fwd
+++ b/examples/fib.fwd
@@ -5,19 +5,19 @@
* bifurcating nature of fibonacci just gets mapped to a linear sequence of
* calls? */
-fib(n, res)
+fib(int n, (int) res)
{
- fwd_if(n < 2) => {
+ if n < 2 {
res(1);
- } => {
- fib(n - 1) => f1;
- fib(n - 2) => f2;
+ } else {
+ fib(n - 1) => int f1;
+ fib(n - 2) => int f2;
res(f1 + f2);
}
}
main()
{
- fib(6) => n;
+ fib(6) => int n;
fwd_println(n);
}