aboutsummaryrefslogtreecommitdiffstats
path: root/roms/openbios/forth/lib/preprocessor.fs
blob: 89d478cff7ef0b9cd49e3a21a1a18fa80671add6 (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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
\ tag: Forth preprocessor
\ 
\ Forth preprocessor
\ 
\ Copyright (C) 2003, 2004 Samuel Rydh
\ 
\ See the file "COPYING" for further information about
\ the copyright and warranty status of this work.
\ 

0 value prep-wid
0 value prep-dict
0 value prep-here

: ([IF])
  begin
    begin parse-word dup 0= while
      2drop refill
    repeat

    2dup " [IF]" strcmp 0= if 1 throw then
    2dup " [IFDEF]" strcmp 0= if 1 throw then
    2dup " [ELSE]" strcmp 0= if 2 throw then
    2dup " [THEN]" strcmp 0= if 3 throw then
    " \\" strcmp 0= if linefeed parse 2drop then
  again
;

: [IF] ( flag -- )
  if exit then
  1 begin
    ['] ([IF]) catch case
      \ EOF (FIXME: this does not work)
      \ -1 of ." Missing [THEN]" abort exit endof
      \ [IF]
      1 of 1+ endof
      \ [ELSE]
      2 of dup 1 = if 1- then endof
      \ [THEN]
      3 of 1- endof
    endcase
  dup 0 <=
  until drop
; immediate

: [ELSE] 0 [ ['] [IF] , ] ; immediate
: [THEN] ; immediate

:noname
  0 to prep-wid
  0 to prep-dict
; initializer

: [IFDEF] ( <word> -- )
  prep-wid if
    parse-word prep-wid search-wordlist dup if nip then
  else 0 then
  [ ['] [IF] , ]
; immediate

: [DEFINE] ( <word> -- )
  parse-word here get-current >r >r
  prep-dict 0= if
    2000 alloc-mem here!
    here to prep-dict
    wordlist to prep-wid
    here to prep-here
  then
  prep-wid set-current prep-here here!
  $create
  here to prep-here
  r> r> set-current here!
; immediate

: [0] 0 ; immediate
: [1] 1 ; immediate