version 1.151, 2006/01/29 18:34:33
|
version 1.155, 2006/02/18 22:58:04
|
Line 1771 Ghost state drop
|
Line 1771 Ghost state drop
|
?DO dup T c@ H I T c! H 1+ |
?DO dup T c@ H I T c! H 1+ |
tchar +LOOP drop ; |
tchar +LOOP drop ; |
|
|
|
: tcallot ( char size -- ) |
|
0 ?DO dup T c, H tchar +LOOP drop ; |
|
|
: td, ( d -- ) |
: td, ( d -- ) |
\G Store a host value as one cell into the target |
\G Store a host value as one cell into the target |
there tcell X allot TD! ; |
there tcell X allot TD! ; |
Line 2570 Cond: MAXI
|
Line 2573 Cond: MAXI
|
(THeader (:) ; |
(THeader (:) ; |
|
|
: :noname ( -- colon-sys ) |
: :noname ( -- colon-sys ) |
X cfalign there |
switchrom X cfalign there |
\ define a nameless ghost |
\ define a nameless ghost |
here ghostheader dup last-header-ghost ! dup to lastghost |
here ghostheader dup last-header-ghost ! dup to lastghost |
(:) ; |
(:) ; |
Line 2822 by Create
|
Line 2825 by Create
|
|
|
: u, ( n -- udp ) |
: u, ( n -- udp ) |
current-region >r user-region activate |
current-region >r user-region activate |
X here swap X , tup@ - |
X here swap X , tup@ - |
r> activate ; |
r> activate ; |
|
|
: au, ( n -- udp ) |
: au, ( n -- udp ) |
Line 2863 by User
|
Line 2866 by User
|
|
|
[THEN] |
[THEN] |
|
|
|
T has? rom H [IF] |
|
Builder (Value) |
|
Build: ( n -- ) ;Build |
|
by: :dovalue ( target-body-addr -- n ) T @ @ H ;DO |
|
|
|
Builder Value |
|
Build: T here 0 A, H switchram T align here swap ! , H ;Build |
|
by (Value) |
|
|
|
Builder AValue |
|
Build: T here 0 A, H switchram T align here swap ! A, H ;Build |
|
by (Value) |
|
[ELSE] |
Builder (Value) |
Builder (Value) |
Build: ( n -- ) ;Build |
Build: ( n -- ) ;Build |
by: :docon ( target-body-addr -- n ) T @ H ;DO |
by: :docon ( target-body-addr -- n ) T @ H ;DO |
Line 2874 by (Value)
|
Line 2890 by (Value)
|
Builder AValue |
Builder AValue |
BuildSmart: T A, H ;Build |
BuildSmart: T A, H ;Build |
by (Value) |
by (Value) |
|
[THEN] |
|
|
Defer texecute |
Defer texecute |
|
|
Builder Defer |
Builder Defer |
BuildSmart: ( -- ) [T'] noop T A, H ;Build |
T has? rom H [IF] |
by: :dodefer ( ghost -- ) X @ texecute ;DO |
Build: ( -- ) T here 0 A, H switchram T align here swap ! H [T'] noop T A, H ( switchrom ) ;Build |
|
by: :dodefer ( ghost -- ) X @ X @ texecute ;DO |
|
[ELSE] |
|
BuildSmart: ( -- ) [T'] noop T A, H ;Build |
|
by: :dodefer ( ghost -- ) X @ texecute ;DO |
|
[THEN] |
|
|
Builder interpret/compile: |
Builder interpret/compile: |
Build: ( inter comp -- ) swap T A, A, H ;Build-immediate |
Build: ( inter comp -- ) swap T A, A, H ;Build-immediate |
Line 3212 Cond: ABORT" if, ahead, there [char]
|
Line 3234 Cond: ABORT" if, ahead, there [char]
|
>r then, r> compile ALiteral compile c(abort") then, ;Cond |
>r then, r> compile ALiteral compile c(abort") then, ;Cond |
[THEN] |
[THEN] |
|
|
|
X has? rom [IF] |
|
Cond: IS T ' >body @ H compile ALiteral compile ! ;Cond |
|
: IS T >address ' >body @ ! H ; |
|
Cond: TO T ' >body @ H compile ALiteral compile ! ;Cond |
|
: TO T ' >body @ ! H ; |
|
[ELSE] |
Cond: IS T ' >body H compile ALiteral compile ! ;Cond |
Cond: IS T ' >body H compile ALiteral compile ! ;Cond |
: IS T >address ' >body ! H ; |
: IS T >address ' >body ! H ; |
Cond: TO T ' >body H compile ALiteral compile ! ;Cond |
Cond: TO T ' >body H compile ALiteral compile ! ;Cond |
: TO T ' >body ! H ; |
: TO T ' >body ! H ; |
|
[THEN] |
|
|
Cond: defers T ' >body @ compile, H ;Cond |
Cond: defers T ' >body @ compile, H ;Cond |
|
|
Line 3269 tchar 8 = 78 and or
|
Line 3298 tchar 8 = 78 and or
|
magic 7 + c! |
magic 7 + c! |
|
|
: save-cross ( "image-name" "binary-name" -- ) |
: save-cross ( "image-name" "binary-name" -- ) |
s" ec" X $has? IF .regions THEN |
.regions \ s" ec" X $has? IF .regions THEN |
bl parse ." Saving to " 2dup type cr |
bl parse ." Saving to " 2dup type cr |
w/o bin create-file throw >r |
w/o bin create-file throw >r |
s" header" X $has? IF |
s" header" X $has? IF |