version 1.44, 1999/05/17 13:13:27
|
version 1.45, 2000/07/14 08:55:15
|
Line 214 print-token !
|
Line 214 print-token !
|
|
|
char a char z .. char A char Z .. union char _ singleton union charclass letter |
char a char z .. char A char Z .. union char _ singleton union charclass letter |
char 0 char 9 .. charclass digit |
char 0 char 9 .. charclass digit |
bl singleton charclass blank |
bl singleton tab-char over add-member charclass white |
tab-char singleton charclass tab |
|
nl-char singleton eof-char over add-member complement charclass nonl |
nl-char singleton eof-char over add-member complement charclass nonl |
nl-char singleton eof-char over add-member char : over add-member complement charclass nocolonnl |
nl-char singleton eof-char over add-member char : over add-member complement charclass nocolonnl |
bl 1+ maxchar .. charclass nowhite |
bl 1+ maxchar .. charclass nowhite |
Line 265 Variable c-flag
|
Line 264 Variable c-flag
|
|
|
(( ` \ comment-body nl )) <- comment ( -- ) |
(( ` \ comment-body nl )) <- comment ( -- ) |
|
|
(( {{ effect-in }} (( {{ start }} c-name {{ end 2 pick item-name 2! item-descr + }} blank ** )) ** {{ effect-in-end ! }} |
(( {{ effect-in }} (( {{ start }} c-name {{ end 2 pick item-name 2! item-descr + }} white ** )) ** {{ effect-in-end ! }} |
` - ` - blank ** |
` - ` - white ** |
{{ effect-out }} (( {{ start }} c-name {{ end 2 pick item-name 2! item-descr + }} blank ** )) ** {{ effect-out-end ! }} |
{{ effect-out }} (( {{ start }} c-name {{ end 2 pick item-name 2! item-descr + }} white ** )) ** {{ effect-out-end ! }} |
)) <- stack-effect ( -- ) |
)) <- stack-effect ( -- ) |
|
|
(( {{ s" " doc 2! s" " forth-code 2! }} |
(( {{ s" " doc 2! s" " forth-code 2! }} |
(( comment || nl )) ** |
(( comment || nl )) ** |
(( {{ line @ name-line ! filename 2@ name-filename 2! }} |
(( {{ line @ name-line ! filename 2@ name-filename 2! }} |
{{ start }} name {{ end 2dup forth-name 2! c-name 2! }} tab ++ |
{{ start }} name {{ end 2dup forth-name 2! c-name 2! }} white ++ |
{{ start }} stack-effect {{ end stack-string 2! }} tab ++ |
` ( white ** {{ start }} stack-effect {{ end stack-string 2! }} ` ) white ** |
{{ start }} name {{ end wordset 2! }} tab ** |
{{ start }} name {{ end wordset 2! }} white ** |
(( {{ start }} c-name {{ end c-name 2! }} )) ?? nl |
(( {{ start }} c-name {{ end c-name 2! }} )) ?? nl |
)) |
)) |
(( ` " ` " {{ start }} (( noquote ++ ` " )) ++ {{ end 1- doc 2! }} ` " nl )) ?? |
(( ` " ` " {{ start }} (( noquote ++ ` " )) ++ {{ end 1- doc 2! }} ` " nl )) ?? |
Line 611 set-current
|
Line 610 set-current
|
item-descr +loop ; |
item-descr +loop ; |
|
|
: output-c ( -- ) |
: output-c ( -- ) |
." I_" c-name 2@ type ." : /* " forth-name 2@ type ." ( " stack-string 2@ type ." ) */" cr |
." I_" c-name 2@ type ." : /* " forth-name 2@ type ." ( " stack-string 2@ type ." ) */" cr |
." /* " doc 2@ type ." */" cr |
." /* " doc 2@ type ." */" cr |
." NAME(" [char] " emit forth-name 2@ type [char] " emit ." )" cr \ debugging |
." NAME(" [char] " emit forth-name 2@ type [char] " emit ." )" cr \ debugging |
." {" cr |
." {" cr |