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
|
\ 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 " [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
|