aboutsummaryrefslogtreecommitdiffstats
path: root/test.fp
blob: 498a3eb496fd56c1cd53a24732ba53e7829bebd7 (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
(
  ; core utilities
  ($x ^x ^x)          $dup
  ($_)                $drop
  ($x $y ^x ^y)       $swap
  ($a $b $c ^b ^a ^c) $rot
  (sub)               $-
  (0 swap - -)        $+
  (())                $nil
  (nil eq)            $null?
  ($x x)              $force
  (10 emit)           $cr
  (dup car swap cdr)  $carcdr

  ; if-stmt
  ($c $t $f c ^f ^t rot cswap $_ force) $if
  ($f $t $c $fn ^f ^t ^c fn)     $endif

  ; range
  ($self $start $end
    ^if (^start ^end eq)
      ^nil
      (^start ^end ^start 1 + self swap cons)
    endif
  ) $range

  ($self $func $list
    ^if (^list null?)
      nil
      (^list carcdr swap func ^func self)
    endif
  ) $foreach

  58 48 range
  ^emit foreach cr
)