bf.cul
· 1.6 KiB · Text
原始檔案
Playground
: eval (run '+) (left '0) -> (left '1) (ran '+) ;
: eval (run '+) (left '1) -> (right '0) (ran '+) +carry eval ;
: +carry (left '0) -> (left '1) (shift bits left) ;
: +carry (left '*) -> (left '*) (shift bits left) ;
: +carry (left '1) -> (right '0) +carry ;
: eval (run '-) (left '1) -> (left '0) (ran '-) eval ;
: eval (run '-) (left '0) -> (right '1) (ran '-) -carry eval ;
: -carry (left '0) -> (left '1) -carry ;
: -carry (left '1) -> (left '0) (shift bits left) ;
: -carry (left '*) -> (left '*) (shift bits left) ;
: eval (run '<) -> (ran '<) (shift bits right) eval ;
: (shift bits right) (left '*) -> (right '*) ;
: (shift bits right) (left ?bit) -> (right ?bit) (shift bits right) ;
: eval (run '>) (right '*) -> (left '*) (shift bits left) eval ;
: (shift bits left) (right '*) -> (right '*) ;
: (shift bits left) (right ?bit) -> (left ?bit) (shift bits left) ;
: eval (run '[) (left "*00000000") ->
(left "*00000000") (ran [) (jump past matching bracket) ;
: (jump past matching bracket) (balance '[) (run ']) ->
(ran ']) (jump past matching bracket) ;
: (jump past matching bracket) (run '[) ->
(ran '[) (balance '[) (jump past matching bracket) ;
: (jump past matching bracket) (run ']) ->
(ran ']) eval ;
: eval (run ']) (left "*00000000") ->
(left "*00000000") (ran ']) (jump backwards to matching bracket) ;
: (jump backwards to matching bracket) (balance ']) (ran '[) ->
(run '[) (jump backwards to matching bracket) ;
: (jump backwards to matching bracket) (ran ']) ->
(run ']) (balance ']) (jump backwards to matching bracket) ;
: (jump backwards to matching bracket) (ran '[) ->
(run '[) eval ;
1 | : eval (run '+) (left '0) -> (left '1) (ran '+) ; |
2 | : eval (run '+) (left '1) -> (right '0) (ran '+) +carry eval ; |
3 | |
4 | : +carry (left '0) -> (left '1) (shift bits left) ; |
5 | : +carry (left '*) -> (left '*) (shift bits left) ; |
6 | : +carry (left '1) -> (right '0) +carry ; |
7 | |
8 | |
9 | |
10 | : eval (run '-) (left '1) -> (left '0) (ran '-) eval ; |
11 | : eval (run '-) (left '0) -> (right '1) (ran '-) -carry eval ; |
12 | |
13 | : -carry (left '0) -> (left '1) -carry ; |
14 | : -carry (left '1) -> (left '0) (shift bits left) ; |
15 | : -carry (left '*) -> (left '*) (shift bits left) ; |
16 | |
17 | |
18 | |
19 | : eval (run '<) -> (ran '<) (shift bits right) eval ; |
20 | : (shift bits right) (left '*) -> (right '*) ; |
21 | : (shift bits right) (left ?bit) -> (right ?bit) (shift bits right) ; |
22 | |
23 | |
24 | : eval (run '>) (right '*) -> (left '*) (shift bits left) eval ; |
25 | : (shift bits left) (right '*) -> (right '*) ; |
26 | : (shift bits left) (right ?bit) -> (left ?bit) (shift bits left) ; |
27 | |
28 | |
29 | : eval (run '[) (left "*00000000") -> |
30 | (left "*00000000") (ran [) (jump past matching bracket) ; |
31 | : (jump past matching bracket) (balance '[) (run ']) -> |
32 | (ran ']) (jump past matching bracket) ; |
33 | : (jump past matching bracket) (run '[) -> |
34 | (ran '[) (balance '[) (jump past matching bracket) ; |
35 | : (jump past matching bracket) (run ']) -> |
36 | (ran ']) eval ; |
37 | |
38 | |
39 | : eval (run ']) (left "*00000000") -> |
40 | (left "*00000000") (ran ']) (jump backwards to matching bracket) ; |
41 | : (jump backwards to matching bracket) (balance ']) (ran '[) -> |
42 | (run '[) (jump backwards to matching bracket) ; |
43 | : (jump backwards to matching bracket) (ran ']) -> |
44 | (run ']) (balance ']) (jump backwards to matching bracket) ; |
45 | : (jump backwards to matching bracket) (ran '[) -> |
46 | (run '[) eval ; |