version 1.107, 2001/09/05 11:01:27
|
version 1.114, 2001/09/12 14:55:54
|
Line 986 Exists-Warnings on
|
Line 986 Exists-Warnings on
|
|
|
Variable reuse-ghosts reuse-ghosts off |
Variable reuse-ghosts reuse-ghosts off |
|
|
1 [IF] \ FIXME: define when vocs are ready |
|
: HeaderGhost ( "name" -- ghost ) |
: HeaderGhost ( "name" -- ghost ) |
>in @ |
>in @ |
bl word count |
bl word count |
Line 1003 Variable reuse-ghosts reuse-ghosts off
|
Line 1002 Variable reuse-ghosts reuse-ghosts off
|
\ defined words, this is a workaround |
\ defined words, this is a workaround |
\ for the redefined \ until vocs work |
\ for the redefined \ until vocs work |
Make-Ghost ; |
Make-Ghost ; |
[THEN] |
|
|
|
|
|
: .ghost ( ghost -- ) >ghostname type ; |
: .ghost ( ghost -- ) >ghostname type ; |
|
|
Line 1046 End-Struct addr-struct
|
Line 1043 End-Struct addr-struct
|
|
|
\ Predefined ghosts 12dec92py |
\ Predefined ghosts 12dec92py |
|
|
|
Ghost - drop \ need a ghost otherwise "-" would be treated as a number |
|
|
Ghost 0= drop |
Ghost 0= drop |
Ghost branch Ghost ?branch 2drop |
Ghost branch Ghost ?branch 2drop |
Ghost (do) Ghost (?do) 2drop |
Ghost (do) Ghost (?do) 2drop |
Line 1060 Ghost '
|
Line 1059 Ghost '
|
Ghost :docol Ghost :doesjump Ghost :dodoes 2drop drop |
Ghost :docol Ghost :doesjump Ghost :dodoes 2drop drop |
Ghost :dovar drop |
Ghost :dovar drop |
Ghost over Ghost = Ghost drop 2drop drop |
Ghost over Ghost = Ghost drop 2drop drop |
Ghost - drop |
|
Ghost 2drop drop |
Ghost 2drop drop |
Ghost 2dup drop |
Ghost 2dup drop |
|
|
Line 1145 true DefaultValue standardthreading
|
Line 1143 true DefaultValue standardthreading
|
s" relocate" T environment? H |
s" relocate" T environment? H |
\ JAW why set NIL to this?! |
\ JAW why set NIL to this?! |
[IF] drop \ SetValue NIL |
[IF] drop \ SetValue NIL |
[ELSE] >ENVIRON T NIL H SetValue relocate |
[ELSE] >ENVIRON X NIL SetValue relocate |
[THEN] |
[THEN] |
|
>TARGET |
|
|
|
0 Constant NIL |
|
|
>CROSS |
>CROSS |
|
|
Line 1227 Variable mirrored-link \ linked
|
Line 1228 Variable mirrored-link \ linked
|
: >rlen cell+ ; |
: >rlen cell+ ; |
: >rstart ; |
: >rstart ; |
|
|
|
: (region) ( addr len region -- ) |
|
\G change startaddress and length of an existing region |
|
>r r@ last-defined-region ! |
|
r@ >rlen ! dup r@ >rstart ! r> >rdp ! ; |
|
|
: region ( addr len -- ) |
: region ( addr len -- ) |
\G create a new region |
\G create a new region |
Line 1240 Variable mirrored-link \ linked
|
Line 1245 Variable mirrored-link \ linked
|
region-link linked 0 , 0 , 0 , bl word count string, |
region-link linked 0 , 0 , 0 , bl word count string, |
ELSE \ store new parameters in region |
ELSE \ store new parameters in region |
bl word drop |
bl word drop |
>body >r r@ last-defined-region ! |
>body (region) |
r@ >rlen ! dup r@ >rstart ! r> >rdp ! |
|
THEN ; |
THEN ; |
|
|
: borders ( region -- startaddr endaddr ) |
: borders ( region -- startaddr endaddr ) |
Line 1359 T has? rom H
|
Line 1363 T has? rom H
|
|
|
\ MakeKernel 22feb99jaw |
\ MakeKernel 22feb99jaw |
|
|
: makekernel ( targetsize -- targetsize ) |
: makekernel ( targetsize -- ) |
dup dictionary >rlen ! setup-target ; |
\G convenience word to setup the memory of the target |
|
\G used by main.fs of the c-engine based systems |
|
100 swap dictionary (region) |
|
setup-target ; |
|
|
>MINIMAL |
>MINIMAL |
: makekernel makekernel ; |
: makekernel makekernel ; |
Line 1640 T has? relocate H
|
Line 1647 T has? relocate H
|
>TARGET |
>TARGET |
|
|
: count dup X c@ swap X char+ swap ; |
: count dup X c@ swap X char+ swap ; |
\ FIXME -1 on 64 bit machines?!?! |
|
: on T -1 swap ! H ; |
: on -1 -1 rot TD! ; |
: off T 0 swap ! H ; |
: off T 0 swap ! H ; |
|
|
: tcmove ( source dest len -- ) |
: tcmove ( source dest len -- ) |
Line 1684 previous
|
Line 1691 previous
|
|
|
: (cm) ( -- addr ) |
: (cm) ( -- addr ) |
T here align H |
T here align H |
-1 colon, ; ' (cm) plugin-of colonmark, |
-1 prim, ; ' (cm) plugin-of colonmark, |
|
|
>TARGET |
>TARGET |
: compile, ( xt -- ) |
: compile, ( xt -- ) |
Line 1774 Defer resolve-warning
|
Line 1781 Defer resolve-warning
|
: prim-resolved ( ghost -- ) |
: prim-resolved ( ghost -- ) |
>link @ prim, ; |
>link @ prim, ; |
|
|
\ FIXME: not activated |
\ FIXME: not used currently |
: does-resolved ( ghost -- ) |
: does-resolved ( ghost -- ) |
dup g>body alit, >do:ghost @ g>body colon, ; |
dup g>body alit, >do:ghost @ g>body colon, ; |
|
|
Line 1814 Defer resolve-warning
|
Line 1821 Defer resolve-warning
|
|
|
\ gexecute ghost, 01nov92py |
\ gexecute ghost, 01nov92py |
|
|
\ FIXME cleanup |
|
\ : is-resolved ( ghost -- ) |
|
\ >link @ colon, ; \ compile-call |
|
|
|
: (gexecute) ( ghost -- ) |
: (gexecute) ( ghost -- ) |
dup >comp @ EXECUTE ; |
dup >comp @ EXECUTE ; |
|
|
Line 1828 Defer resolve-warning
|
Line 1831 Defer resolve-warning
|
: addr, ( ghost -- ) |
: addr, ( ghost -- ) |
dup forward? IF 1 refered 0 T a, H ELSE >link @ T a, H THEN ; |
dup forward? IF 1 refered 0 T a, H ELSE >link @ T a, H THEN ; |
|
|
\ !! : ghost, ghost gexecute ; |
|
|
|
\ .unresolved 11may93jaw |
\ .unresolved 11may93jaw |
|
|
variable ResolveFlag |
variable ResolveFlag |
Line 2111 Variable last-prim-ghost
|
Line 2112 Variable last-prim-ghost
|
|
|
Defer setup-prim-semantics |
Defer setup-prim-semantics |
|
|
: aprim ( -- ) |
: mapprim ( "forthname" "asmlabel" -- ) |
THeader -1 aprim-nr +! aprim-nr @ T A, H |
THeader -1 aprim-nr +! aprim-nr @ T A, H |
asmprimname, |
asmprimname, |
setup-prim-semantics ; |
setup-prim-semantics ; |
|
|
: aprim: ( -- ) |
: mapprim: ( "forthname" "asmlabel" -- ) |
-1 aprim-nr +! aprim-nr @ |
-1 aprim-nr +! aprim-nr @ |
Ghost tuck swap resolve <do:> swap tuck >magic ! |
Ghost tuck swap resolve <do:> swap tuck >magic ! |
asmprimname, ; |
asmprimname, ; |
Line 2376 Cond: MAXI
|
Line 2377 Cond: MAXI
|
\ by the way: defining a second interpreter (a compiler-)loop |
\ by the way: defining a second interpreter (a compiler-)loop |
\ is not allowed if a system should be ans conform |
\ is not allowed if a system should be ans conform |
|
|
|
: (:) ( ghost -- ) |
|
\ common factor of : and :noname. Prepare ;Resolve and start definition |
|
;Resolve ! there ;Resolve cell+ ! |
|
docol, ]comp colon-start depth T ] H ; |
|
|
: : ( -- colon-sys ) \ Name |
: : ( -- colon-sys ) \ Name |
defempty? |
defempty? |
constflag off \ don't let this flag work over colon defs |
constflag off \ don't let this flag work over colon defs |
\ just to go sure nothing unwanted happens |
\ just to go sure nothing unwanted happens |
>in @ skip? IF drop skip-defs EXIT THEN >in ! |
>in @ skip? IF drop skip-defs EXIT THEN >in ! |
(THeader ;Resolve ! there ;Resolve cell+ ! |
(THeader (:) ; |
docol, ]comp colon-start depth T ] H ; |
|
|
|
: :noname ( -- colon-sys ) |
: :noname ( -- colon-sys ) |
X cfalign |
X cfalign there |
\ FIXME: cleanup!!!!!!!! |
\ define a nameless ghost |
\ idtentical to : with dummy ghost?! |
here ghostheader dup last-header-ghost ! dup to lastghost |
here ghostheader dup ;Resolve ! dup last-header-ghost ! to lastghost |
(:) ; |
there ;Resolve cell+ ! |
|
there docol, ]comp |
|
colon-start depth T ] H ; |
|
|
|
Cond: EXIT ( -- ) compile ;S ;Cond |
Cond: EXIT ( -- ) compile ;S ;Cond |
|
|
Line 2456 Cond: DOES>
|
Line 2458 Cond: DOES>
|
depth T ] H ; |
depth T ] H ; |
|
|
>CROSS |
>CROSS |
\ Creation 01nov92py |
\ Creation 01nov92py |
|
|
\ Builder 11may93jaw |
\ Builder 11may93jaw |
|
|
|
0 Value built |
|
|
: Builder ( Create-xt do-ghost "name" -- ) |
: Builder ( Create-xt do-ghost "name" -- ) |
\ builds up a builder in current vocabulary |
\ builds up a builder in current vocabulary |
\ create-xt is executed when word is interpreted |
\ create-xt is executed when word is interpreted |
\ do:-xt is executed when the created word from builder is executed |
\ do:-xt is executed when the created word from builder is executed |
\ for do:-xt an additional entry after the normal ghost-entrys is used |
\ for do:-xt an additional entry after the normal ghost-entrys is used |
|
|
Make-Ghost ( Create-xt do-ghost ghost ) |
ghost to built |
dup >created on |
built >created @ 0= IF |
rot swap ( do-ghost Create-xt ghost ) |
built >created on |
tuck >exec ! |
['] prim-resolved built >comp ! |
tuck >do:ghost ! |
THEN ; |
['] prim-resolved over >comp ! |
|
drop ; |
|
|
|
: gdoes, ( ghost -- ) |
: gdoes, ( ghost -- ) |
\ makes the codefield for a word that is built |
\ makes the codefield for a word that is built |
Line 2492 Cond: DOES>
|
Line 2494 Cond: DOES>
|
|
|
: takeover-x-semantics ( S constructor-ghost new-ghost -- ) |
: takeover-x-semantics ( S constructor-ghost new-ghost -- ) |
\g stores execution semantic and compilation semantic in the built word |
\g stores execution semantic and compilation semantic in the built word |
\g if the word already has a semantic (concerns S", IS, .", DOES>) |
|
\g then keep it |
|
swap >do:ghost @ |
swap >do:ghost @ |
\ we use the >exec2 field for the semantic of a crated word, |
\ we use the >exec2 field for the semantic of a created word, |
\ so predefined semantics e.g. for .... |
\ using exec or exec2 makes no difference for normal cross-compilation |
\ FIXME: find an example in the normal kernel!!! |
\ but is usefull for instant where the exec field is already |
|
\ defined (e.g. Vocabularies) |
2dup >exec @ swap >exec2 ! |
2dup >exec @ swap >exec2 ! |
>comp @ swap >comp ! ; |
>comp @ swap >comp ! ; |
\ old version of this: |
|
\ >exec dup @ ['] NoExec = |
|
\ IF swap >do:ghost @ >exec @ swap ! ELSE 2drop THEN ; |
|
|
|
: TCreate ( <name> -- ) |
: TCreate ( <name> -- ) |
create-forward-warn |
create-forward-warn |
Line 2537 Cond: DOES>
|
Line 2535 Cond: DOES>
|
postpone TCreate |
postpone TCreate |
[ [THEN] ] ; |
[ [THEN] ] ; |
|
|
|
: ;Build |
|
postpone ; built >exec ! ; immediate |
|
|
: gdoes> ( ghost -- addr flag ) |
: gdoes> ( ghost -- addr flag ) |
executed-ghost @ |
executed-ghost @ g>body ; |
\ FIXME: cleanup |
|
\ compiling? ABORT" CROSS: Executing gdoes> while compiling" |
|
\ ?! compiling? IF gexecute true EXIT THEN |
|
g>body ( false ) ; |
|
|
|
\ DO: ;DO 11may93jaw |
\ DO: ;DO 11may93jaw |
\ changed to ?EXIT 10may93jaw |
|
|
|
: DO: ( -- do-ghost [xt] [colon-sys] ) |
: do:ghost! ( ghost -- ) built >do:ghost ! ; |
here ghostheader |
: doexec! ( xt -- ) built >do:ghost @ >exec ! ; |
:noname postpone gdoes> ( postpone ?EXIT ) ; |
|
|
|
: by: ( -- do-ghost [xt] [colon-sys] ) \ name |
: DO: ( -- [xt] [colon-sys] ) |
Ghost |
here ghostheader do:ghost! |
:noname postpone gdoes> ( postpone ?EXIT ) ; |
:noname postpone gdoes> ; |
|
|
|
: by: ( -- [xt] [colon-sys] ) \ name |
|
Ghost do:ghost! |
|
:noname postpone gdoes> ; |
|
|
: ;DO ( do-ghost [xt] [colon-sys] -- do-ghost ) |
: ;DO ( [xt] [colon-sys] -- ) |
postpone ; ( S addr xt ) |
postpone ; doexec! ; immediate |
over >exec ! ; immediate |
|
|
|
: by ( -- do-ghost ) \ Name |
: by ( -- ) \ Name |
Ghost >do:ghost @ ; |
Ghost >do:ghost @ do:ghost! ; |
|
|
: compile: ( do-ghost -- do-ghost [xt] [colon-sys] ) |
: compile: ( --[xt] [colon-sys] ) |
\G defines a compile time action for created words |
\G defines a compile time action for created words |
\G by this builder |
\G by this builder |
:noname ; |
:noname ; |
|
|
: ;compile ( do-ghost [xt] [colon-sys] -- do-ghost ) |
: ;compile ( [xt] [colon-sys] -- ) |
postpone ; over >comp ! ; immediate |
postpone ; built >do:ghost @ >comp ! ; immediate |
|
|
|
|
|
|
>TARGET |
|
\ Variables and Constants 05dec92py |
\ Variables and Constants 05dec92py |
|
|
Build: ( n -- ) ; |
|
by: :docon ( target-body-addr -- n ) T @ H ;DO |
|
Builder (Constant) |
Builder (Constant) |
|
Build: ( n -- ) ;Build |
|
by: :docon ( target-body-addr -- n ) T @ H ;DO |
|
|
Build: ( n -- ) T , H ; |
|
by (Constant) |
|
Builder Constant |
Builder Constant |
|
Build: ( n -- ) T , H ;Build |
Build: ( n -- ) T A, H ; |
|
by (Constant) |
by (Constant) |
|
|
Builder AConstant |
Builder AConstant |
|
Build: ( n -- ) T A, H ;Build |
|
by (Constant) |
|
|
Build: ( d -- ) T , , H ; |
|
DO: ( ghost -- d ) T dup cell+ @ swap @ H ;DO |
|
Builder 2Constant |
Builder 2Constant |
|
Build: ( d -- ) T , , H ;Build |
|
DO: ( ghost -- d ) T dup cell+ @ swap @ H ;DO |
|
|
BuildSmart: ; |
|
by: :dovar ( target-body-addr -- addr ) ;DO |
|
Builder Create |
Builder Create |
|
BuildSmart: ;Build |
|
by: :dovar ( target-body-addr -- addr ) ;DO |
|
|
|
Builder Variable |
T has? rom H [IF] |
T has? rom H [IF] |
Build: ( -- ) T here 0 A, H switchram T align here swap ! 0 , H ( switchrom ) ; |
Build: ( -- ) T here 0 A, H switchram T align here swap ! 0 , H ( switchrom ) ;Build |
by (Constant) |
by (Constant) |
Builder Variable |
|
[ELSE] |
[ELSE] |
Build: T 0 , H ; |
Build: T 0 , H ;Build |
by Create |
by Create |
Builder Variable |
|
[THEN] |
[THEN] |
|
|
|
Builder 2Variable |
T has? rom H [IF] |
T has? rom H [IF] |
Build: ( -- ) T here 0 A, H switchram T align here swap ! 0 , 0 , H ( switchrom ) ; |
Build: ( -- ) T here 0 A, H switchram T align here swap ! 0 , 0 , H ( switchrom ) ;Build |
by (Constant) |
by (Constant) |
Builder 2Variable |
|
[ELSE] |
[ELSE] |
Build: T 0 , 0 , H ; |
Build: T 0 , 0 , H ;Build |
by Create |
by Create |
Builder 2Variable |
|
[THEN] |
[THEN] |
|
|
|
Builder AVariable |
T has? rom H [IF] |
T has? rom H [IF] |
Build: ( -- ) T here 0 A, H switchram T align here swap ! 0 A, H ( switchrom ) ; |
Build: ( -- ) T here 0 A, H switchram T align here swap ! 0 A, H ( switchrom ) ;Build |
by (Constant) |
by (Constant) |
Builder AVariable |
|
[ELSE] |
[ELSE] |
Build: T 0 A, H ; |
Build: T 0 A, H ;Build |
by Create |
by Create |
Builder AVariable |
|
[THEN] |
[THEN] |
|
|
\ User variables 04may94py |
\ User variables 04may94py |
|
|
>CROSS |
|
|
|
Variable tup 0 tup ! |
Variable tup 0 tup ! |
Variable tudp 0 tudp ! |
Variable tudp 0 tudp ! |
|
|
Line 2640 Variable tudp 0 tudp !
|
Line 2630 Variable tudp 0 tudp !
|
tup @ tudp @ + T A! H |
tup @ tudp @ + T A! H |
tudp @ dup T cell+ H tudp ! ; |
tudp @ dup T cell+ H tudp ! ; |
|
|
>TARGET |
|
|
|
Build: 0 u, X , ; |
|
by: :douser ( ghost -- up-addr ) X @ tup @ + ;DO |
|
Builder User |
Builder User |
|
Build: 0 u, X , ;Build |
|
by: :douser ( ghost -- up-addr ) X @ tup @ + ;DO |
|
|
Build: 0 u, X , 0 u, drop ; |
|
by User |
|
Builder 2User |
Builder 2User |
|
Build: 0 u, X , 0 u, drop ;Build |
Build: 0 au, X , ; |
|
by User |
by User |
|
|
Builder AUser |
Builder AUser |
|
Build: 0 au, X , ;Build |
|
by User |
|
|
|
Builder (Value) |
|
Build: ( n -- ) ;Build |
|
by: :docon ( target-body-addr -- n ) T @ H ;DO |
|
|
BuildSmart: T , H ; |
|
by (Constant) |
|
Builder Value |
Builder Value |
|
BuildSmart: T , H ;Build |
|
by (Value) |
|
|
BuildSmart: T A, H ; |
|
by (Constant) |
|
Builder AValue |
Builder AValue |
|
BuildSmart: T A, H ;Build |
|
by (Value) |
|
|
Defer texecute |
Defer texecute |
|
|
BuildSmart: ( -- ) [T'] noop T A, H ; |
|
by: :dodefer ( ghost -- ) X @ texecute ;DO |
|
Builder Defer |
Builder Defer |
|
BuildSmart: ( -- ) [T'] noop T A, H ;Build |
|
by: :dodefer ( ghost -- ) X @ texecute ;DO |
|
|
Build: ( inter comp -- ) swap T immediate A, A, H ; |
|
DO: ( ghost -- ) ABORT" CROSS: Don't execute" ;DO |
|
Builder interpret/compile: |
Builder interpret/compile: |
|
Build: ( inter comp -- ) swap T immediate A, A, H ;Build |
|
DO: ( ghost -- ) ABORT" CROSS: Don't execute" ;DO |
|
|
\ Sturctures 23feb95py |
\ Sturctures 23feb95py |
|
|
>CROSS |
|
: nalign ( addr1 n -- addr2 ) |
: nalign ( addr1 n -- addr2 ) |
\ addr2 is the aligned version of addr1 wrt the alignment size n |
\ addr2 is the aligned version of addr1 wrt the alignment size n |
1- tuck + swap invert and ; |
1- tuck + swap invert and ; |
>TARGET |
|
|
|
Build: ; |
|
by: :dofield T @ H + ;DO |
|
Builder (Field) |
Builder (Field) |
|
Build: ;Build |
|
by: :dofield T @ H + ;DO |
|
|
|
Builder Field |
Build: ( align1 offset1 align size "name" -- align2 offset2 ) |
Build: ( align1 offset1 align size "name" -- align2 offset2 ) |
rot dup T , H ( align1 align size offset1 ) |
rot dup T , H ( align1 align size offset1 ) |
+ >r nalign r> ; |
+ >r nalign r> ;Build |
by (Field) |
by (Field) |
Builder Field |
|
|
|
|
>TARGET |
: struct T 1 chars 0 H ; |
: struct T 1 chars 0 H ; |
: end-struct T 2Constant H ; |
: end-struct T 2Constant H ; |
|
|
: cell% ( n -- size align ) |
: cell% ( n -- size align ) |
T 1 cells H dup ; |
T 1 cells H dup ; |
|
>CROSS |
|
|
\ Input-Methods 01py |
\ Input-Methods 01py |
|
|
Build: ( m v -- m' v ) dup T , cell+ H ; |
|
DO: abort" Not in cross mode" ;DO |
|
Builder input-method |
Builder input-method |
|
Build: ( m v -- m' v ) dup T , cell+ H ;Build |
Build: ( m v size -- m v' ) over T , H + ; |
|
DO: abort" Not in cross mode" ;DO |
DO: abort" Not in cross mode" ;DO |
|
|
Builder input-var |
Builder input-var |
|
Build: ( m v size -- m v' ) over T , H + ;Build |
|
DO: abort" Not in cross mode" ;DO |
|
|
|
\ Peephole optimization 05sep01jaw |
|
|
|
\ this section defines different compilation |
|
\ actions for created words |
|
\ this will help the peephole optimizer |
|
\ I (jaw) took this from bernds lates cross-compiler |
|
\ changes but seperated it from the original |
|
\ Builder words. The final plan is to put this |
|
\ into a seperate file, together with the peephole |
|
\ optimizer for cross |
|
|
|
|
|
T has? peephole H [IF] |
|
|
|
>CROSS |
|
: (callc) compile call T >body a, H ; ' (callc) plugin-of colon, |
|
|
|
\ if we want this, we have to spilt aconstant |
|
\ and constant!! |
|
\ Builder (Constant) |
|
\ compile: g>body X @ lit, ;compile |
|
|
|
Builder (Constant) |
|
compile: g>body alit, compile @ ;compile |
|
|
|
Builder (Value) |
|
compile: g>body alit, compile @ ;compile |
|
|
|
\ this changes also Variable, AVariable and 2Variable |
|
Builder Create |
|
\ compile: g>body alit, ;compile |
|
|
|
Builder User |
|
compile: g>body compile useraddr T @ , H ;compile |
|
|
|
Builder Defer |
|
compile: g>body alit, compile @ compile execute ;compile |
|
|
|
Builder (Field) |
|
compile: g>body T @ H lit, compile + ;compile |
|
|
|
[THEN] |
|
|
\ structural conditionals 17dec92py |
\ structural conditionals 17dec92py |
|
|
Line 2981 magic 7 + c!
|
Line 3014 magic 7 + c!
|
: save-cross ( "image-name" "binary-name" -- ) |
: save-cross ( "image-name" "binary-name" -- ) |
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 |
TNIL IF |
s" header" X $has? IF |
s" #! " r@ write-file throw |
s" #! " r@ write-file throw |
bl parse r@ write-file throw |
bl parse r@ write-file throw |
s" --image-file" r@ write-file throw |
s" --image-file" r@ write-file throw |
Line 2997 magic 7 + c!
|
Line 3030 magic 7 + c!
|
THEN |
THEN |
image @ there |
image @ there |
r@ write-file throw \ write image |
r@ write-file throw \ write image |
TNIL IF |
s" relocate" X $has? IF |
bit$ @ there 1- tcell>bit rshift 1+ |
bit$ @ there 1- tcell>bit rshift 1+ |
r@ write-file throw \ write tags |
r@ write-file throw \ write tags |
THEN |
THEN |
Line 3008 magic 7 + c!
|
Line 3041 magic 7 + c!
|
swap >image swap r@ write-file throw |
swap >image swap r@ write-file throw |
r> close-file throw ; |
r> close-file throw ; |
|
|
1 [IF] |
\ save-asm-region 29aug01jaw |
|
|
Variable name-ptr |
Variable name-ptr |
Create name-buf 200 chars allot |
Create name-buf 200 chars allot |
Line 3062 Create name-buf 200 chars allot
|
Line 3095 Create name-buf 200 chars allot
|
THEN |
THEN |
@nb ; |
@nb ; |
|
|
|
\ FIXME why disabled?! |
: label-from-ghostnameXX ( ghost -- addr len ) |
: label-from-ghostnameXX ( ghost -- addr len ) |
\ same as (label-from-ghostname) but caches generated names |
\ same as (label-from-ghostname) but caches generated names |
dup >asm-name @ ?dup IF nip count EXIT THEN |
dup >asm-name @ ?dup IF nip count EXIT THEN |
Line 3215 Variable outfile-fd
|
Line 3249 Variable outfile-fd
|
: save-asm-region ( region adr len -- ) |
: save-asm-region ( region adr len -- ) |
create-outfile (save-asm-region) close-outfile ; |
create-outfile (save-asm-region) close-outfile ; |
|
|
[THEN] |
|
|
|
\ \ minimal definitions |
\ \ minimal definitions |
|
|
>MINIMAL also minimal |
>MINIMAL also minimal |
Line 3228 Variable outfile-fd
|
Line 3260 Variable outfile-fd
|
\ \ [IF] [ELSE] [THEN] ... 14sep97jaw |
\ \ [IF] [ELSE] [THEN] ... 14sep97jaw |
|
|
\ it is useful to define our own structures and not to rely |
\ it is useful to define our own structures and not to rely |
\ on the words in the compiler |
\ on the words in the host system |
\ The words in the compiler might be defined with vocabularies |
\ The words in the host system might be defined with vocabularies |
\ this doesn't work with our self-made compile-loop |
\ this doesn't work with our self-made compile-loop |
|
|
Create parsed 20 chars allot \ store word we parsed |
Create parsed 20 chars allot \ store word we parsed |
Line 3485 UNLOCK >CROSS
|
Line 3517 UNLOCK >CROSS
|
[IFDEF] extend-cross extend-cross [THEN] |
[IFDEF] extend-cross extend-cross [THEN] |
|
|
LOCK |
LOCK |
|
|
|
|
|
|