summaryrefslogtreecommitdiff
path: root/fib.kpl
blob: a650f8878cd67e54f29989b13b975cf42ca31f52 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37

/*
    Fibonacci sequence
    n can be any numeric type
*/

`export fib : Fn[n] $ (
    t : `type n
    ? {
        |(t = Int_signed; t = Float) {
            ? n <= 0 { `return 0 }
        }
        t = Int_unsigned {
            ? n = 0 { `return 0 }
        }
        { `panic "invalid type for n" }
    }
    ? {
        n < 3 { 2 }
        { `sync(fib; n - 1) + fib `sync n - 2 }
    }
)

`export fib_string Fn[n] $ (
    "#MAGENTA#fib#(#CYAN#%#) #WHITE#=# #GREEN#%#\n" `format (n; fib `sync n)
)

`is_main Fn $ (
    ( args ) : `use "sys"
    ? 3 != `length args {
        `return `error String $ (
            "#BOLD#RED#Got %#\n" `format `join args
            "#BOLD#WHITE#Usage % % <n>#\n" `format (args `get 0; args `get 1)
         )
    }
    `print fib_string `sync U64 $ args `get -1
)