CPM: Move load/thru/... words that were still in vf-io.fth to vf-blk.fth.

Also route load call from include via deferred include-load. like in MSDOS.
And move loading vf-bufs.fth to the end of v4thblk.fth, so that vf-bufs
can override include-load after it has been initialized in vf-file.fth.
This commit is contained in:
Philip Zembrod 2024-11-11 23:28:38 +01:00
parent 3d597fb324
commit 26cc7a839a
7 changed files with 36 additions and 24 deletions

View File

@ -183,7 +183,7 @@ test-std.log: \
test-blk.log: \
$(patsubst %, $(cpmfilesdir)/%, v4thblk.com sfileint.fth \
sblkint.fth logfile.fth core.fr) \
sblkint.fth log2file.fb core.fr) \
$(patsubst tests/%, $(cpmfilesdir)/%, $(wildcard tests/*.fth) \
tests/empty.fb) | emu
./emulator/run-in-runcpm.sh \

View File

@ -5,10 +5,10 @@ Target definitions $100 here!
include vf-core.fth
include vf-io.fth
include vf-bufs.fth
include vf-sys.fth
include vf-bdos.fth
include vf-file.fth
include vf-bufs.fth
include vf-end.fth
cr .( unresolved: ) .unresolved ( ' .blk is .status )

View File

@ -212,3 +212,25 @@ Target Dos also
l/s 0 DO
cr I 2 .r space scr @ block I c/l * + c/l -trailing type
LOOP cr ;
Variable loadfile
: (load ( blk offset -- )
isfile push loadfile push fromfile push blk push >in push
>in ! blk ! isfile@ loadfile ! .status interpret ;
: load ( blk --) ?dup 0=exit 0 (load ;
' load IS include-load
\ *** Block No. 85, Hexblock 55
\ +load thru +thru --> rdepth depth 20Oct86
: +load ( offset --) blk @ + load ;
: thru ( from to --) 1+ swap DO I load LOOP ;
: +thru ( off0 off1 --) 1+ swap DO I +load LOOP ;
: --> 1 blk +! >in off .status ; immediate

View File

@ -1,4 +1,6 @@
Target Dos also
: cr+ex@ ( fcb -- cr+256*ex )
dup &34 + c@ swap &14 + c@ $100 * + ;
: cr+ex! ( cr+256*ex fcb -- )
@ -61,10 +63,14 @@
| : interpret-via-tib
BEGIN freadline >r .status >in off interpret r> UNTIL ;
Defer include-load
| : block-not-implemented 1 abort" block file access not implemented" ;
' block-not-implemented IS include-load
: include-isfile ( -- )
increc push 0 isfile@ cr+ex!
isfile@ increadrec Abort" can't read start of file"
probe-for-fb IF 1 load exit THEN
probe-for-fb IF 1 include-load exit THEN
incfile push isfile@ incfile !
savetib >r interpret-via-tib r> restoretib
incfile @ 2+ closefile Abort" error closing file" ;

View File

@ -1,5 +1,7 @@
\ *** Block No. 84, Hexblock 54
Target
\ .status push load 20Oct86
Defer .status ' noop Is .status
@ -8,26 +10,6 @@ Defer .status ' noop Is .status
: push ( addr -- ) r> swap dup >r @ >r pull >r >r ;
restrict
Variable loadfile
: (load ( blk offset -- )
isfile push loadfile push fromfile push blk push >in push
>in ! blk ! isfile@ loadfile ! .status interpret ;
: load ( blk --) ?dup 0=exit 0 (load ;
\ *** Block No. 85, Hexblock 55
\ +load thru +thru --> rdepth depth 20Oct86
: +load ( offset --) blk @ + load ;
: thru ( from to --) 1+ swap DO I load LOOP ;
: +thru ( off0 off1 --) 1+ swap DO I +load LOOP ;
: --> 1 blk +! >in off .status ; immediate
: rdepth ( -- +n) r0 @ rp@ 2+ - 2/ ;
: depth ( -- +n) sp@ s0 @ swap - 2/ ;

View File

@ -1,5 +1,7 @@
\ *** Block No. 104, Hexblock 68
Target
\ endpoints of forget 01Jul86
| : |? ( nfa -- flag ) c@ $20 and ;

View File

@ -1,5 +1,5 @@
include logfile.fth
include log2file.fb \ so that include with block file gets tested
' noop Is .status
logopen