version 1.114, 2001/09/12 14:55:54
|
version 1.117, 2002/01/04 20:31:53
|
Line 202 Create bases 10 , 2 , A , 100 ,
|
Line 202 Create bases 10 , 2 , A , 100 ,
|
|
|
[THEN] |
[THEN] |
|
|
|
\ this provides assert( and struct stuff |
|
\GFORTH [IFUNDEF] assert1( |
|
\GFORTH also forth definitions require assert.fs previous |
|
\GFORTH [THEN] |
|
|
|
>CROSS |
|
|
hex \ the defualt base for the cross-compiler is hex !! |
hex \ the defualt base for the cross-compiler is hex !! |
\ Warnings off |
\ Warnings off |
|
|
Line 705 Plugin branchtoresolve, ( branch-addr --
|
Line 712 Plugin branchtoresolve, ( branch-addr --
|
Plugin branchtomark, ( -- target-addr ) \ marks a branch destination |
Plugin branchtomark, ( -- target-addr ) \ marks a branch destination |
|
|
Plugin colon, ( tcfa -- ) \ compiles call to tcfa at current position |
Plugin colon, ( tcfa -- ) \ compiles call to tcfa at current position |
|
Plugin xt, ( tcfa -- ) \ compiles xt |
Plugin prim, ( tcfa -- ) \ compiles primitive invocation |
Plugin prim, ( tcfa -- ) \ compiles primitive invocation |
Plugin colonmark, ( -- addr ) \ marks a colon call |
Plugin colonmark, ( -- addr ) \ marks a colon call |
Plugin colon-resolve ( tcfa addr -- ) |
Plugin colon-resolve ( tcfa addr -- ) |
Line 1007 Variable reuse-ghosts reuse-ghosts off
|
Line 1015 Variable reuse-ghosts reuse-ghosts off
|
|
|
\ ' >ghostname ALIAS @name |
\ ' >ghostname ALIAS @name |
|
|
|
: findghost ( "ghostname" -- ghost ) |
|
bl word gfind 0= ABORT" CROSS: Ghost don't exists" ; |
|
|
: [G'] ( -- ghost : name ) |
: [G'] ( -- ghost : name ) |
\G ticks a ghost and returns its address |
\G ticks a ghost and returns its address |
\ bl word gfind 0= ABORT" CROSS: Ghost don't exists" |
findghost |
ghost state @ IF postpone literal THEN ; immediate |
state @ IF postpone literal THEN ; immediate |
|
|
: g>xt ( ghost -- xt ) |
: g>xt ( ghost -- xt ) |
\G Returns the xt (cfa) of a ghost. Issues a warning if undefined. |
\G Returns the xt (cfa) of a ghost. Issues a warning if undefined. |
Line 1061 Ghost :dovar drop
|
Line 1072 Ghost :dovar drop
|
Ghost over Ghost = Ghost drop 2drop drop |
Ghost over Ghost = Ghost drop 2drop drop |
Ghost 2drop drop |
Ghost 2drop drop |
Ghost 2dup drop |
Ghost 2dup drop |
|
Ghost state drop |
|
Ghost call drop |
|
Ghost @ drop |
|
Ghost useraddr drop |
|
Ghost execute drop |
|
Ghost + drop |
|
Ghost (C") drop |
|
Ghost decimal drop |
|
Ghost hex drop |
|
|
\ \ Parameter for target systems 06oct92py |
\ \ Parameter for target systems 06oct92py |
|
|
Line 1677 previous
|
Line 1695 previous
|
>CROSS |
>CROSS |
|
|
: (cc) T a, H ; ' (cc) plugin-of colon, |
: (cc) T a, H ; ' (cc) plugin-of colon, |
|
: (xt) T a, H ; ' (xt) plugin-of xt, |
: (prim) T a, H ; ' (prim) plugin-of prim, |
: (prim) T a, H ; ' (prim) plugin-of prim, |
|
|
: (cr) >tempdp ]comp prim, comp[ tempdp> ; ' (cr) plugin-of colon-resolve |
: (cr) >tempdp ]comp xt, comp[ tempdp> ; ' (cr) plugin-of colon-resolve |
: (ar) T ! H ; ' (ar) plugin-of addr-resolve |
: (ar) T ! H ; ' (ar) plugin-of addr-resolve |
: (dr) ( ghost res-pnt target-addr addr ) |
: (dr) ( ghost res-pnt target-addr addr ) |
>tempdp drop over |
>tempdp drop over |
Line 1691 previous
|
Line 1710 previous
|
|
|
: (cm) ( -- addr ) |
: (cm) ( -- addr ) |
T here align H |
T here align H |
-1 prim, ; ' (cm) plugin-of colonmark, |
-1 xt, ; ' (cm) plugin-of colonmark, |
|
|
>TARGET |
>TARGET |
: compile, ( xt -- ) |
: compile, ( xt -- ) |
Line 1783 Defer resolve-warning
|
Line 1802 Defer resolve-warning
|
|
|
\ FIXME: not used currently |
\ 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>xt 0 t>body - colon, ; |
|
|
: (is-forward) ( ghost -- ) |
: (is-forward) ( ghost -- ) |
colonmark, 0 (refered) ; \ compile space for call |
colonmark, 0 (refered) ; \ compile space for call |
Line 1947 Variable to-doc to-doc on
|
Line 1966 Variable to-doc to-doc on
|
\ Target TAGS creation |
\ Target TAGS creation |
|
|
s" kernel.TAGS" r/w create-file throw value tag-file-id |
s" kernel.TAGS" r/w create-file throw value tag-file-id |
|
s" kernel.tags" r/w create-file throw value vi-tag-file-id |
\ contains the file-id of the tags file |
\ contains the file-id of the tags file |
|
|
Create tag-beg 2 c, 7F c, bl c, |
Create tag-beg 2 c, 7F c, bl c, |
Create tag-end 2 c, bl c, 01 c, |
Create tag-end 2 c, bl c, 01 c, |
Create tag-bof 1 c, 0C c, |
Create tag-bof 1 c, 0C c, |
|
Create tag-tab 1 c, 09 c, |
|
|
2variable last-loadfilename 0 0 last-loadfilename 2! |
2variable last-loadfilename 0 0 last-loadfilename 2! |
|
|
Line 1965 Create tag-bof 1 c, 0C c,
|
Line 1986 Create tag-bof 1 c, 0C c,
|
s" ,0" tag-file-id write-line throw |
s" ,0" tag-file-id write-line throw |
THEN ; |
THEN ; |
|
|
: cross-tag-entry ( -- ) |
: cross-gnu-tag-entry ( -- ) |
tlast @ 0<> \ not an anonymous (i.e. noname) header |
tlast @ 0<> \ not an anonymous (i.e. noname) header |
IF |
IF |
put-load-file-name |
put-load-file-name |
source >in @ min tag-file-id write-file throw |
source >in @ min tag-file-id write-file throw |
tag-beg count tag-file-id write-file throw |
tag-beg count tag-file-id write-file throw |
tlast @ >image count 1F and tag-file-id write-file throw |
Last-Header-Ghost @ >ghostname tag-file-id write-file throw |
tag-end count tag-file-id write-file throw |
tag-end count tag-file-id write-file throw |
base @ decimal sourceline# 0 <# #s #> tag-file-id write-file throw |
base @ decimal sourceline# 0 <# #s #> tag-file-id write-file throw |
\ >in @ 0 <# #s [char] , hold #> tag-file-id write-line throw |
\ >in @ 0 <# #s [char] , hold #> tag-file-id write-line throw |
Line 1979 Create tag-bof 1 c, 0C c,
|
Line 2000 Create tag-bof 1 c, 0C c,
|
base ! |
base ! |
THEN ; |
THEN ; |
|
|
|
: cross-vi-tag-entry ( -- ) |
|
tlast @ 0<> \ not an anonymous (i.e. noname) header |
|
IF |
|
sourcefilename vi-tag-file-id write-file throw |
|
tag-tab count vi-tag-file-id write-file throw |
|
Last-Header-Ghost @ >ghostname vi-tag-file-id write-file throw |
|
tag-tab count vi-tag-file-id write-file throw |
|
s" /^" vi-tag-file-id write-file throw |
|
source vi-tag-file-id write-file throw |
|
s" $/" vi-tag-file-id write-line throw |
|
THEN ; |
|
|
|
: cross-tag-entry ( -- ) |
|
cross-gnu-tag-entry |
|
cross-vi-tag-entry ; |
|
|
\ Check for words |
\ Check for words |
|
|
Defer skip? ' false IS skip? |
Defer skip? ' false IS skip? |
Line 2087 Variable aprim-nr -20 aprim-nr !
|
Line 2124 Variable aprim-nr -20 aprim-nr !
|
: copy-execution-semantics ( ghost-from ghost-dest -- ) |
: copy-execution-semantics ( ghost-from ghost-dest -- ) |
>r |
>r |
dup >exec @ r@ >exec ! |
dup >exec @ r@ >exec ! |
|
dup >comp @ r@ >comp ! |
dup >exec2 @ r@ >exec2 ! |
dup >exec2 @ r@ >exec2 ! |
dup >exec-compile @ r@ >exec-compile ! |
dup >exec-compile @ r@ >exec-compile ! |
dup >ghost-xt @ r@ >ghost-xt ! |
dup >ghost-xt @ r@ >ghost-xt ! |
Line 2133 Defer setup-prim-semantics
|
Line 2171 Defer setup-prim-semantics
|
Variable prim# |
Variable prim# |
: first-primitive ( n -- ) prim# ! ; |
: first-primitive ( n -- ) prim# ! ; |
: Primitive ( -- ) \ name |
: Primitive ( -- ) \ name |
>in @ skip? IF 2drop EXIT THEN >in ! |
>in @ skip? IF drop EXIT THEN >in ! |
dup 0< s" prims" T $has? H 0= and |
s" prims" T $has? H 0= |
IF |
IF |
.sourcepos ." needs prim: " >in @ bl word count type >in ! cr |
.sourcepos ." needs prim: " >in @ bl word count type >in ! cr |
THEN |
THEN |
Line 2177 Comment ( Comment \
|
Line 2215 Comment ( Comment \
|
\ compile 10may93jaw |
\ compile 10may93jaw |
|
|
: compile ( "name" -- ) \ name |
: compile ( "name" -- ) \ name |
\ bl word gfind 0= ABORT" CROSS: Can't compile " |
findghost |
ghost |
|
dup >exec-compile @ ?dup |
dup >exec-compile @ ?dup |
IF nip compile, |
IF nip compile, |
ELSE postpone literal postpone gexecute THEN ; immediate restrict |
ELSE postpone literal postpone gexecute THEN ; immediate restrict |
Line 2200 Cond: ['] T ' H alit, ;Cond
|
Line 2237 Cond: ['] T ' H alit, ;Cond
|
|
|
: [T'] |
: [T'] |
\ returns the target-cfa of a ghost, or compiles it as literal |
\ returns the target-cfa of a ghost, or compiles it as literal |
postpone [G'] state @ IF postpone g>xt ELSE g>xt THEN ; immediate |
postpone [G'] |
|
state @ IF postpone g>xt ELSE g>xt THEN ; immediate |
|
|
\ \ threading modell 13dec92py |
\ \ threading modell 13dec92py |
\ modularized 14jun97jaw |
\ modularized 14jun97jaw |
Line 2325 Cond: MAXI
|
Line 2363 Cond: MAXI
|
;Cond |
;Cond |
|
|
>CROSS |
>CROSS |
|
|
\ Target compiling loop 12dec92py |
\ Target compiling loop 12dec92py |
\ ">tib trick thrown out 10may93jaw |
\ ">tib trick thrown out 10may93jaw |
\ number? defined at the top 11may93jaw |
\ number? defined at the top 11may93jaw |
Line 2345 Cond: MAXI
|
Line 2384 Cond: MAXI
|
IF 0> IF swap lit, THEN lit, discard |
IF 0> IF swap lit, THEN lit, discard |
ELSE 2drop restore-input throw Ghost gexecute THEN ; |
ELSE 2drop restore-input throw Ghost gexecute THEN ; |
|
|
>TARGET |
|
\ : ; DOES> 13dec92py |
\ : ; DOES> 13dec92py |
\ ] 9may93py/jaw |
\ ] 9may93py/jaw |
|
|
|
>CROSS |
|
|
: compiling-state ( -- ) |
: compiling-state ( -- ) |
\G set states to compililng |
\G set states to compililng |
Compiling comp-state ! |
Compiling comp-state ! |
Line 2363 Cond: MAXI
|
Line 2403 Cond: MAXI
|
IF >ghost-xt @ execute X off ELSE drop THEN |
IF >ghost-xt @ execute X off ELSE drop THEN |
Interpreting comp-state ! ; |
Interpreting comp-state ! ; |
|
|
|
>TARGET |
|
|
: ] |
: ] |
compiling-state |
compiling-state |
BEGIN |
BEGIN |
Line 2426 Cond: [ ( -- ) interpreting-state ;Cond
|
Line 2468 Cond: [ ( -- ) interpreting-state ;Cond
|
|
|
>CROSS |
>CROSS |
|
|
Create GhostDummy ghostheader |
0 Value created |
<res> GhostDummy >magic ! |
|
|
|
: !does ( does-action -- ) |
: !does ( does-action -- ) |
\ !! zusammenziehen und dodoes, machen! |
|
tlastcfa @ [G'] :dovar killref |
tlastcfa @ [G'] :dovar killref |
\ tlastcfa @ dup there >r tdp ! compile :dodoes r> tdp ! T cell+ ! H ; |
>space here >r ghostheader space> |
\ !! geht so nicht, da dodoes, ghost will! |
r@ created >do:ghost ! r@ swap resolve |
GhostDummy >link ! GhostDummy |
r> tlastcfa @ >tempdp dodoes, tempdp> ; |
tlastcfa @ >tempdp dodoes, tempdp> ; |
|
|
|
|
|
Defer instant-interpret-does>-hook |
Defer instant-interpret-does>-hook |
|
|
: resolve-does>-part ( -- ) |
: resolve-does>-part ( -- ) |
\ resolve words made by builders |
\ resolve words made by builders |
Last-Header-Ghost @ >do:ghost @ ?dup |
Last-Header-Ghost @ >do:ghost @ ?dup |
IF there resolve |
IF there resolve THEN ; |
\ TODO: set special DOES> resolver action here |
|
THEN ; |
|
|
|
>TARGET |
>TARGET |
Cond: DOES> |
Cond: DOES> |
Line 2454 Cond: DOES>
|
Line 2490 Cond: DOES>
|
;Cond |
;Cond |
|
|
: DOES> switchrom doeshandler, T here H !does |
: DOES> switchrom doeshandler, T here H !does |
|
['] does-resolved created >comp ! |
instant-interpret-does>-hook |
instant-interpret-does>-hook |
depth T ] H ; |
depth T ] H ; |
|
|
Line 2473 Cond: DOES>
|
Line 2510 Cond: DOES>
|
ghost to built |
ghost to built |
built >created @ 0= IF |
built >created @ 0= IF |
built >created on |
built >created on |
['] prim-resolved built >comp ! |
|
THEN ; |
THEN ; |
|
|
: gdoes, ( ghost -- ) |
: gdoes, ( ghost -- ) |
Line 2493 Cond: DOES>
|
Line 2529 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 |
swap >do:ghost @ |
swap >do:ghost @ 2dup swap >do:ghost ! |
\ we use the >exec2 field for the semantic of a created word, |
\ we use the >exec2 field for the semantic of a created word, |
\ using exec or exec2 makes no difference for normal cross-compilation |
\ using exec or exec2 makes no difference for normal cross-compilation |
\ but is usefull for instant where the exec field is already |
\ but is usefull for instant where the exec field is already |
Line 2506 Cond: DOES>
|
Line 2542 Cond: DOES>
|
create-forward-warn |
create-forward-warn |
IF ['] reswarn-forward IS resolve-warning THEN |
IF ['] reswarn-forward IS resolve-warning THEN |
executed-ghost @ (Theader |
executed-ghost @ (Theader |
dup >created on |
dup >created on dup to created |
2dup takeover-x-semantics hereresolve gdoes, ; |
2dup takeover-x-semantics hereresolve gdoes, ; |
|
|
: RTCreate ( <name> -- ) |
: RTCreate ( <name> -- ) |
Line 2715 T has? peephole H [IF]
|
Line 2751 T has? peephole H [IF]
|
|
|
>CROSS |
>CROSS |
: (callc) compile call T >body a, H ; ' (callc) plugin-of colon, |
: (callc) compile call T >body a, H ; ' (callc) plugin-of colon, |
|
: (prim) dup 0< IF ( $4000 - ) ELSE |
|
." wrong usage of (prim) " |
|
dup gdiscover IF .ghost ELSE . THEN cr -2 throw THEN |
|
T a, H ; ' (prim) plugin-of prim, |
|
|
\ if we want this, we have to spilt aconstant |
\ if we want this, we have to spilt aconstant |
\ and constant!! |
\ and constant!! |
Line 2729 compile: g>body alit, compile @ ;compile
|
Line 2769 compile: g>body alit, compile @ ;compile
|
|
|
\ this changes also Variable, AVariable and 2Variable |
\ this changes also Variable, AVariable and 2Variable |
Builder Create |
Builder Create |
\ compile: g>body alit, ;compile |
compile: g>body alit, ;compile |
|
|
Builder User |
Builder User |
compile: g>body compile useraddr T @ , H ;compile |
compile: g>body compile useraddr T @ , H ;compile |
Line 2740 compile: g>body alit, compile @ compile
|
Line 2780 compile: g>body alit, compile @ compile
|
Builder (Field) |
Builder (Field) |
compile: g>body T @ H lit, compile + ;compile |
compile: g>body T @ H lit, compile + ;compile |
|
|
|
Builder interpret/compile: |
|
compile: does-resolved ;compile |
|
|
|
Builder input-method |
|
compile: does-resolved ;compile |
|
|
|
Builder input-var |
|
compile: does-resolved ;compile |
|
|
[THEN] |
[THEN] |
|
|
\ structural conditionals 17dec92py |
\ structural conditionals 17dec92py |