1
0
mirror of https://github.com/mgcaret/of816.git synced 2025-01-16 14:30:34 +00:00

simplify temp def stuff a little

This commit is contained in:
mgcaret 2020-01-05 21:12:49 -08:00
parent e9ab1c0eb4
commit aca5015e1c

View File

@ -6052,13 +6052,15 @@ dword dTEMPCOLON,":TEMP"
eword eword
; word to end temporary colon definition and run it ; word to end temporary colon definition and run it
; called whenever control-flow-ending words are executed
; and a temporary definition is open
; ( xt xt' -- ) ; ( xt xt' -- )
hword dTEMPSEMI,"$;TEMP",F_IMMED|F_CONLY hword dTEMPSEMIQ,"$;TEMP?",F_IMMED|F_CONLY
ENTER ENTER
.dword dTMPDEF ; ( -- a-addr ) .dword dTMPDEF ; ( -- a-addr )
.dword FETCH ; ( a-addr -- c-addr ) 0 if not in temp def .dword FETCH ; ( a-addr -- x ) 0 if not in temp def
.dword _IF ; ( c-addr -- ) .dword _IF ; ( x -- )
.dword csmm ; something is wrong .dword notmp ; if not in temp def
dosemi: .dword DEPTH ; ( -- u1 ) dosemi: .dword DEPTH ; ( -- u1 )
.dword dCSDEPTH ; ( u1 -- u1 c-addr1 ) verify stack depth is what it should be .dword dCSDEPTH ; ( u1 -- u1 c-addr1 ) verify stack depth is what it should be
.dword FETCH ; ( u1 c-addr1 -- u1 u2 ) .dword FETCH ; ( u1 c-addr1 -- u1 u2 )
@ -6066,7 +6068,7 @@ dosemi: .dword DEPTH ; ( -- u1 )
.dword _IFFALSE ; ( f -- ) .dword _IFFALSE ; ( f -- )
.dword tmpdone ; true branch, finish up temp def .dword tmpdone ; true branch, finish up temp def
.dword TWODROP .dword TWODROP
EXIT notmp: EXIT
tmpdone: ;SLIT "Ending temp def... " tmpdone: ;SLIT "Ending temp def... "
;.dword TYPE ;.dword TYPE
.dword DEPTH ; ( -- u1 ) .dword DEPTH ; ( -- u1 )
@ -6102,16 +6104,6 @@ csmm: .dword STATEI ; ( -- )
JUMP dofree JUMP dofree
eword eword
; Maybe close temporary definition
hword dTEMPSEMIQ,"$;TEMP?"
ENTER
.dword dTMPDEF
.dword FETCH
.dword _IFFALSE
.dword dTEMPSEMI::dosemi ; we are doing a temp def, maybe close and run
EXIT
eword
; ( xt -- ) make definition at xt visible ; ( xt -- ) make definition at xt visible
hword UNSMUDGE,"UNSMUDGE" hword UNSMUDGE,"UNSMUDGE"
ENTER ENTER
@ -6133,7 +6125,7 @@ dword SEMI,";",F_IMMED|F_CONLY
.dword FETCH .dword FETCH
.dword _IF .dword _IF
.dword :+ .dword :+
.dword dTEMPSEMI ; if it is, do that instead .dword dTEMPSEMIQ ; if it is, do that instead
EXIT EXIT
: .dword _COMP_LIT ; compile EXIT into current def : .dword _COMP_LIT ; compile EXIT into current def
EXIT ; NOTE: not really EXITing here EXIT ; NOTE: not really EXITing here