ade9ba91cb
The relevant changes for FreeBSD (excerpt from the release note): * Newly implemented CORE EXT words: CASE, OF, ENDOF, and ENDCASE. Also added FALLTHROUGH, which works like ENDOF but jumps to the instruction just after the next OF. * Bugfix: John-Hopkins locals syntax now accepts | and -- in the comment (between the first -- and the }.) * Bugfix: Changed vmGetWord0() to make Purify happier. The resulting code is no slower, no larger, and slightly more robust.
106 lines
2.4 KiB
Forth
106 lines
2.4 KiB
Forth
\ #if FICL_WANT_LOCALS
|
|
\ ** ficl/softwords/jhlocal.fr
|
|
\ ** stack comment style local syntax...
|
|
\ { a b c | cleared -- d e }
|
|
\ variables before the "|" are initialized in reverse order
|
|
\ from the stack. Those after the "|" are zero initialized.
|
|
\ Anything between "--" and "}" is treated as comment
|
|
\ Uses locals...
|
|
\ locstate: 0 = looking for | or -- or }}
|
|
\ 1 = found |
|
|
\ 2 = found --
|
|
\ 3 = found }
|
|
\ 4 = end of line
|
|
\
|
|
\ revised 2 June 2000 - { | a -- } now works correctly
|
|
\
|
|
\ $FreeBSD$
|
|
|
|
hide
|
|
|
|
0 constant zero
|
|
|
|
|
|
: ?-- ( c-addr u -- c-addr u flag )
|
|
2dup s" --" compare 0= ;
|
|
: ?} ( c-addr u -- c-addr u flag )
|
|
2dup s" }" compare 0= ;
|
|
: ?| ( c-addr u -- c-addr u flag )
|
|
2dup s" |" compare 0= ;
|
|
|
|
\ examine name - if it's a 2local (starts with "2:"),
|
|
\ nibble the prefix (the "2:") off the name and push true.
|
|
\ Otherwise push false
|
|
\ Problem if the local is named "2:" - we fall off the end...
|
|
: ?2loc ( c-addr u -- c-addr u flag )
|
|
over dup c@ [char] 2 =
|
|
swap 1+ c@ [char] : = and
|
|
if
|
|
2 - swap char+ char+ swap \ dcs/jws: nibble the '2:'
|
|
true
|
|
else
|
|
false
|
|
endif
|
|
;
|
|
|
|
: ?delim ( c-addr u -- state | c-addr u 0 )
|
|
?| if 2drop 1 exit endif
|
|
?-- if 2drop 2 exit endif
|
|
?} if 2drop 3 exit endif
|
|
dup 0=
|
|
if 2drop 4 exit endif
|
|
0
|
|
;
|
|
|
|
set-current
|
|
|
|
: {
|
|
0 dup locals| locstate |
|
|
|
|
\ stack locals until we hit a delimiter
|
|
begin
|
|
parse-word \ ( nLocals c-addr u )
|
|
?delim dup to locstate
|
|
0= while
|
|
rot 1+ \ ( c-addr u ... c-addr u nLocals )
|
|
repeat
|
|
|
|
\ now unstack the locals
|
|
0 ?do
|
|
?2loc if (2local) else (local) endif
|
|
loop \ ( )
|
|
|
|
\ zero locals until -- or }
|
|
locstate 1 = if
|
|
begin
|
|
parse-word
|
|
?delim dup to locstate
|
|
0= while
|
|
?2loc if
|
|
postpone zero postpone zero (2local)
|
|
else
|
|
postpone zero (local)
|
|
endif
|
|
repeat
|
|
endif
|
|
|
|
0 0 (local)
|
|
|
|
\ toss words until }
|
|
\ (explicitly allow | and -- in the comment)
|
|
locstate 2 = if
|
|
begin
|
|
parse-word
|
|
?delim dup to locstate
|
|
3 < while
|
|
locstate 0= if 2drop endif
|
|
repeat
|
|
endif
|
|
|
|
locstate 3 <> abort" syntax error in { } local line"
|
|
; immediate compile-only
|
|
|
|
previous
|
|
\ #endif
|
|
|