bf.cul
· 1.7 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) ;
: eval (run '[) -> (ran '[) ;
: (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 ']) ;
: eval (run ']) -> (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 | |
21 | : (shift bits right) (left '*) -> (right '*) ; |
22 | : (shift bits right) (left ?bit) -> (right ?bit) (shift bits right) ; |
23 | |
24 | |
25 | |
26 | : eval (run '>) (right '*) -> (left '*) (shift bits left) eval ; |
27 | : (shift bits left) (right '*) -> (right '*) ; |
28 | : (shift bits left) (right ?bit) -> (left ?bit) (shift bits left) ; |
29 | |
30 | |
31 | |
32 | : eval (run '[) (left "*00000000") -> |
33 | (left "*00000000") (ran '[) (jump past matching bracket) ; |
34 | : eval (run '[) -> (ran '[) ; |
35 | |
36 | : (jump past matching bracket) (balance '[) (run ']) -> |
37 | (ran ']) (jump past matching bracket) ; |
38 | : (jump past matching bracket) (run '[) -> |
39 | (ran '[) (balance '[) (jump past matching bracket) ; |
40 | : (jump past matching bracket) (run ']) -> |
41 | (ran ']) eval ; |
42 | |
43 | |
44 | |
45 | : eval (run ']) (left "*00000000") -> (left "*00000000") (ran ']) ; |
46 | : eval (run ']) -> (jump backwards to matching bracket) ; |
47 | |
48 | : (jump backwards to matching bracket) (balance ']) (ran '[) -> |
49 | (run '[) (jump backwards to matching bracket) ; |
50 | : (jump backwards to matching bracket) (ran ']) -> |
51 | (run ']) (balance ']) (jump backwards to matching bracket) ; |
52 | : (jump backwards to matching bracket) (ran '[) -> |
53 | (run '[) eval ; |