• R/O
  • HTTP
  • SSH
  • HTTPS

Tags
No Tags

Frequently used words (click to add to your profile)

javac++androidlinuxc#windowsobjective-ccocoa誰得qtpythonphprubygameguibathyscaphec計画中(planning stage)翻訳omegatframeworktwitterdomtestvb.netdirectxゲームエンジンbtronarduinopreviewer

Functions for working with the idealized calendar of Planet Xhilr


File Info

Rev. c9ca731a29c3838146d1e7e85626e1273ae7ca7f
크기 75,694 bytes
Time 2017-06-17 10:35:04
Author Joel Matthew Rees
Log Message

UD/MOD double integer division in M6800 assembler within figForth.
The assembler I use to assemble it is here:
https://sourceforge.net/p/asm68c/wiki/Home/
and it can be run on Joe H Allen's exorsim v. 1.1.
Surprisingly, the High-level Forth version is only around twice as slow as the assembler-level version (because it only uses right-shifts).

Content

*	OPT PRT

* fig-FORTH FOR 6800
* ASSEMBLY SOURCE LISTING

* RELEASE 1
* MAY 1979
* WITH COMPILER SECURITY
* AND VARIABLE LENGTH NAMES

* RELEASE 1.00.01
* May 2013
* Modified for Joe Allen's EXORSIM, JMR

* This public domain publication is provided
* through the courtesy of:
* FORTH
* INTEREST
* GROUP
* fig

* P.O. Box 8231 - San Jose, CA 95155 - (408) 277-0668
* Further distribution must include this notice.
	PAGE
	NAM	Copyright:FORTH Interest Group
	OPT	GEN,PAG
* filename FTH7.21
* === FORTH-6800 06-06-79 21:OO


* The following constitutes the original license:
*=====================LICENSE====================
* This listing is in the PUBLIC DOMAIN and 
* may be freely copied or published with the
* restriction that a credit line is printed
* with the material, crediting the
* authors and the FORTH INTEREST GROUP.

* === by Dave Lion,
* ===  with help from
* === Bob Smith,
* === LaFarr Stuart,
* === The Forth Interest Group
* === PO Box 1105
* === San Carlos, CA 94070
* ===  and
* === Unbounded Computing
* === 1134-K Aster Ave.
* === Sunnyvale, CA 94086
*===================END-LICENSE==================
* Note that the assertion of attribution terms contradicts with a 
* pure assignment to the public domain.
* Because of the terms, copyright should be understood 
* to be asserted by the authors.
* Attribution, according to the above, should be understood
* to be required.
*
* === Modifications for Joe Allen's EXORSIM by Joel Rees, Reiisi Kenkyuu
* Modifications copyright Joel Rees, 2013.
* Permission to use, modify, distribute, and publish the modifications 
* is extended under the attribution terms given above,
* with the explicitly affirmed obligation to retain intact 
* all authorship and copyright notices, and license notices.
*
* Note that, under my (Joel Rees) recollection and understanding of the 
* legal/political context of the original context of publication, 
* right to use source code in one's possession was not considered 
* deniable in any practical or meaningful sense. 
* (Laws such as the DMCA had been proposed by certain advocates for 
* the concept of intellectual property under other names, 
* but were considered unenforceable and impracticable, 
* thus contrary to the purpose of law,
* a waste of resources, and the height of discourtesy 
* by the general community of software practicioners at the time,
* to the best of my understanding and recollection.) 
* Thus, the lack of explicit mention of a right to use in the terms of 
* the effective license should in no wise be considered to imply a 
* witholding thereof.
* ===
*
*  This version was developed on an AMI EVK 300 PROTO
*  system using an ACIA for the I/O. All terminal 1/0
*  is done in three subroutines:
*   PEMIT  ( word # 182 )
*   PKEY   (        183 )
*   PQTERM (        184 )
*
*  The FORTH words for disc related I/O follow the model
*  of the FORTH Interest Group, but have not been
*  tested using a real disc.
*
*  Addresses in this implementation reflect the fact that,
*  on the development system, it was convenient to
*  write-protect memory at hex 1000, and leave the first
*  4K bytes write-enabled. As a consequence, code from
*  location $1000 to lable ZZZZ could be put in ROM.
*  Minor deviations from the model were made in the
*  initialization and words ?STACK and FORGET
*  in order to do this.
*


*
NBLK	EQU	4	# of disc buffer blocks for virtual memory
* MEMEND	EQU	132*NBLK+$3000 end of ram
MEMEND	EQU	132*NBLK+$4000+132 end of ram with some breathing room
*  each block is 132 bytes in size,
*  holding 128 characters
*
* MEMTOP	EQU	$3FFF	absolute end of all ram
MEMTOP	EQU	$7FFF	putative absolute end of all ram
* ACIAC	EQU	$FBCE	the ACIA control address and
ACIAC	EQU	$FCF4	the ACIA control address and
ACIAD	EQU	ACIAC+1	data address for PROTO
	PAGE
*  MEMORY MAP for this (not) 16K system:
*  ( positioned so that systems with 4k byte write-
*   protected segments can write protect FORTH )
*
* addr.		contents		pointer	init by
* ****	*******************************	*******	******
* 3FFF	(6FFF)					HI
*	substitute for disc mass memory
* 3210	(5294)					LO,MEMEND
* 320F	(5293)
* 	4 buffer sectors of VIRTUAL MEMORY
* 3000	(5084)					FIRST
* >>>>>> memory from here up must be RAM <<<<<<
*
* 27FF	(37FF, but 38XX, with debugging code included the the "ROMable" image.)
* 	6k of romable "FORTH"		<== IP	ABORT
*					<== W
*	the VIRTUAL FORTH MACHINE
*
* 1004 <<< WARM START ENTRY >>> (2004)
* 1000 <<< COLD START ENTRY >>> (2000)
*
* >>>>>> memory from here down must be RAM <<<<<<
*  FFE	(1FF0) RETURN STACK base		<== RP	RINIT
*
*  FB4	(less than 1EB4)
*	INPUT LINE BUFFER
*	holds up to 132 characters
*	and is scanned upward by IN
*	starting at TIB
*  F30	(1E00)				<== IN	TIB
*  F2F	(1DF0) DATA STACK			<== SP	SP0,SINIT
*    |	grows downward from F2F
*    v
*  - -
*    |
*    I	DICTIONARY grows upward
* 
*  183	(183) end of ram-dictionary.		<== DP	DPINIT
*	"TASK"
*
*  150	(150) "FORTH" ( a word )		<=, <== CONTEXT
*					`==== CURRENT
*  148	(148) start of ram-dictionary.
*
*  100	(100) user #l table of variables	<= UP	DPINIT
*   F0	(B0) registers & pointers for the virtual machine
* 	scratch area used by various words
*   E0	(A0) lowest address used by FORTH
*
* 0000
	PAGE
***
*
* CONVENTIONS USED IN THIS PROGRAM ARE AS FOLLOWS :
*
* IP points to the current instruction ( pre-increment mode )
* RP points to second free byte (first free word) in return stack
* SP (hardware SP) points to first free byte in data stack
*
*	when A and B hold one 16 bit FORTH data word,
*	A contains the high byte, B, the low byte.
***




*	ORG	$E0	variables
	ORG	$A0	variables


N	RMB	10	used as scratch by (FIND),ENCLOSE,CMOVE,EMIT,KEY,
*				SP@,SWAP,DOES>,COLD


*	These locations are used by the TRACE routine :

TRLIM	RMB	1	the count for tracing without user intervention
TRACEM	RMB	1	non-zero = trace mode
BRKPT	RMB	2	the breakpoint address at which
*			the program will go into trace mode
VECT	RMB	2	vector to machine code
*	(only needed if the TRACE routine is resident)


*	Registers used by the FORTH virtual machine:
*	Starting at $OOFO ($00B0):


W	RMB	2	the instruction register points to 6800 code
IP	RMB	2	the instruction pointer points to pointer to 6800 code
RP	RMB	2	the return stack pointer
UP	RMB	2	the pointer to base of current user's 'USER' table
*		( altered during multi-tasking )
*
* For the tracer:
	RMB 4
TRASP	RMB 2
TRAVEC	RMB 2
TRAA	RMB 1
TRAB	RMB 1
*
	PAGE
*	This system is shown with one user, but additional users
*	may be added by allocating additional user tables:
*	UORIG2 RMB 64 data table for user #2
*
*
*	Some of this stuff gets initialized during
*	COLD start and WARM start:
* 	[ names correspond to FORTH words of similar (no X) name ]
*
	ORG	$100
*	ORG	$1100
UORIG	RMB	6	3 reserved variables
XSPZER	RMB	2	initial top of data stack for this user
XRZERO	RMB	2	initial top of return stack
XTIB	RMB	2	start of terminal input buffer
XWIDTH	RMB	2	name field width
XWARN	RMB	2	warning message mode (0 = no disc)
XFENCE	RMB	2	fence for FORGET
XDP	RMB	2	dictionary pointer
XVOCL	RMB	2	vocabulary linking
XBLK	RMB	2	disc block being accessed
XIN	RMB	2	scan pointer into the block
XOUT	RMB	2	cursor position
XSCR	RMB	2	disc screen being accessed ( O=terminal )
XOFSET	RMB	2	disc sector offset for multi-disc
XCONT	RMB	2	last word in primary search vocabulary
XCURR	RMB	2	last word in extensible vocabulary
XSTATE	RMB	2	flag for 'interpret' or 'compile' modes
XBASE	RMB	2	number base for I/O numeric conversion
XDPL	RMB	2	decimal point place
XFLD	RMB	2	
XCSP	RMB	2	current stack position, for compile checks
XRNUM	RMB	2	
XHLD	RMB	2	
XDELAY	RMB	2	carriage return delay count
XCOLUM	RMB	2	carriage width
IOSTAT	RMB	2	last acia status from write/read
	RMB	2	( 4 spares! )
	RMB	2	
	RMB	2	
	RMB	2	




*
*
*   end of user table, start of common system variables
*
*
*
XUSE	RMB	2
XPREV	RMB	2
	RMB	4	( spares )

	PAGE
*  These things, up through the lable 'REND', are overwritten
*  at time of cold load and should have the same contents
*  as shown here:
*
	FCB	$C5	immediate
	FCC	4,FORTH
	FCB	$C8
	FDB	NOOP-7
FORTH	FDB	DODOES,DOVOC,$81A0,TASK-7
	FDB	0
*
	FCC	"(C) Forth Interest Group, 1979"

	FCB	$84
	FCC	3,TASK
	FCB	$CB
	FDB	FORTH-8
TASK	FDB	DOCOL,SEMIS
* 
REND	EQU	*	( first empty location in dictionary )

	PAGE
*    The FORTH program ( address $1000 ($2000) to $27FF (37FF?) ) is written
*    so that it can be in a ROM, or write-protected if desired
	ORG	$2000

* ######>> screen 3 <<
*
***************************
**  C O L D   E N T R Y  **
***************************
ORIG	NOP
	JMP	CENT
***************************
**  W A R M   E N T R Y  **
***************************
	NOP
	JMP	WENT	warm-start code, keeps current dictionary intact

*
******* startup parmeters **************************
*
	FDB	$6800,0000	cpu & revision
	FDB	0	topmost word in FORTH vocabulary
BACKSP	FDB	$7F	backspace character for editing
UPINIT	FDB	UORIG	initial user area
*SINIT	FDB	ORIG-$D0	initial top of data stack
SINIT	FDB	ORIG-$210	initial top of data stack
*RINIT	FDB	ORIG-2	initial top of return stack
RINIT	FDB	ORIG-$10	initial top of return stack
*	FDB	ORIG-$D0	terminal input buffer
	FDB	ORIG-$200	terminal input buffer
	FDB	31	initial name field width
*	FDB	0	initial warning mode (0 = no disc)
	FDB	1	initial warning mode (because we're simulating disc)
FENCIN	FDB	REND	initial fence
DPINIT	FDB	REND	cold start value for DP
VOCINT	FDB	FORTH+8	
COLINT	FDB	132	initial terminal carriage width
DELINT	FDB	4	initial carriage return delay
****************************************************
*
	PAGE
*
* ######>> screen 13 <<
PULABX	PUL A		24 cycles until 'NEXT'
	PUL B
STABX	STA A	0,X	16 cycles until 'NEXT'
	STA B	1,X
	BRA	NEXT
GETX	LDA A	0,X	18 cycles until 'NEXT'
	LDA B	1,X
PUSHBA	PSH B		8 cycles until 'NEXT'
	PSH A



*
* "NEXT" takes 38 cycles if TRACE is removed,
*
* and 95 cycles if NOT tracing.
*
* = = = = = = =   t h e   v i r t u a l   m a c h i n e   = = = = =
*                                                                 =
NEXT	LDX	IP
	INX		pre-increment mode
	INX
	STX	IP
NEXT2	LDX	0,X	get W which points to CFA of word to be done
NEXT3	STX	W
	LDX	0,X	get VECT which points to executable code
*                                                                 =
* The next instruction could be patched to JMP TRACE              =
* if a TRACE routine is available:                                =
*                                                                 =
* Or add the TRACE routine in-line, since we are assembling it.
	TST TRACEM
	BEQ NEXTGO
	STX TRAVEC
	TSX ; So the funn 6800 stack doesn't beach us.
	STX TRASP
	LDA A #':'
	JSR PEMIT
	LDA A #' '
	JSR PEMIT
	LDX W
	DEX 
	DEX ; allocation link
	DEX ; last char
	LDA A #31
NAMTST	DEX ; length byte?
	LDA B 0,X
	BMI NAMTDN
	DEC A
	BNE NAMTST
NAMTDN	AND B #31 ; It's the length byte whether it wants to be or not.
NAMSHW	INX
	LDA A 0,X
	JSR PEMIT
	DEC B
	BNE NAMSHW
* show the virtual registers
	LDA A #' '
	JSR PEMIT
	LDA A #'@'
	LDX #TRAVEC
	JSR PHEX4F
	LDA A #'W'
	LDX #W
	JSR PHEX4F
	LDA A #'I'
	JSR PHEX4F
	LDA A #'R'
	JSR PHEX4F
	LDA A #'U'
	JSR PHEX4F
	LDA A #'S'
	LDX #TRASP
	BSR PHEX4F
	LDA A #'>'
	TSX 
	BSR PHEX4F
	LDA A #' '
	BSR PHEX4F
* 
	JSR PCR
	LDX TRAVEC
*
NEXTGO	JMP	0,X
	NOP
*	JMP	TRACE	( an alternate for the above )
*                                                                 =
*DBG
PHEX4F	JSR PEMIT
	BSR PHEXX2
	BSR PHEXX2
	LDA A #' '
	JSR PEMIT
	RTS
PHEXX2	LDA A 0,X
	LSR A
	LSR A
	LSR A
	LSR A
	JSR PHEXD
	LDA A 0,X
	JSR PHEXD
	INX
	RTS
PHEXD	AND A #$0F
	CMP A #10
	BLO PHEXDH
	ADD A #7	; 'A'-'9'+1
PHEXDH	ADD A #'0'
	JSR PEMIT
	RTS
*DBG
* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =


	PAGE
*
* ======>>  1  <<
	FCB	$83
	FCC	2,LIT	NOTE: this is different from LITERAL
	FCB	$D4
	FDB	0	link of zero to terminate dictionary scan
LIT	FDB	*+2
	LDX	IP
	INX
	INX
	STX	IP
	LDA A	0,X
	LDA B	1,X
	JMP	PUSHBA
*
* ######>> screen 14 <<
* ======>>  2  <<
*DBG
	FCB	$85
	FCC	4,XCLIT	; for debugging
	FCB	$D4
	FDB	LIT-6	; should never link
*DBG
CLITER	FDB	*+2	 (this is an invisible word, with no header)
	LDX	IP
	INX
	STX	IP
	CLR A
	LDA B	1,X
	JMP	PUSHBA
*
* ======>>  3  <<
	FCB	$87
	FCC	6,EXECUTE
	FCB	$C5
	FDB	LIT-6
EXEC	FDB	*+2
	TSX
	LDX	0,X	get code field address (CFA)
	INS		pop stack
	INS
	JMP	NEXT3
*
* ######>> screen 15 <<
* ======>>  4  <<
	FCB	$86
	FCC	5,BRANCH
	FCB	$C8
	FDB	EXEC-10
BRAN	FDB	ZBYES	Go steal code in ZBRANCH
*
* ======>>  5  <<
	FCB	$87
	FCC	6,0BRANCH
	FCB	$C8
	FDB	BRAN-9
ZBRAN	FDB	*+2
	PULA
	PULB
	ABA
	BNE	ZBNO
	BCS	ZBNO
ZBYES	LDX	IP	Note: code is shared with BRANCH, (+LOOP), (LOOP)
	LDA B	3,X
	LDA A	2,X
	ADD B	IP+1
	ADC A	IP
	STA B	IP+1
	STA A	IP
	JMP	NEXT
ZBNO	LDX	IP	no branch. This code is shared with (+LOOP), (LOOP).
	INX		jump over branch delta
	INX
	STX	IP
	JMP	NEXT
*
* ######>> screen 16 <<
* ======>>  6  <<
	FCB	$86
	FCC	5,(LOOP)
	FCB	$A9
	FDB	ZBRAN-10
XLOOP	FDB	*+2
	CLR A
	LDA B	#1	get set to increment counter by 1
	BRA	XPLOP2	go steal other guy's code!
*
* ======>>  7  <<
	FCB	$87
	FCC	6,(+LOOP)
	FCB	$A9
	FDB	XLOOP-9
XPLOOP	FDB *+2	Note: +LOOP has an un-signed loop counter
	PUL A	get increment
	PUL B
XPLOP2	TST A
	BPL	XPLOF	forward looping
	BSR	XPLOPS
	SEC
	SBC B	5,X
	SBC A	4,X
	BPL	ZBYES
	BRA	XPLONO	fall through
*
* the subroutine :
XPLOPS	LDX	RP
	ADD B	3,X	add it to counter
	ADC A	2,X
	STA B	3,X	store new counter value
	STA A	2,X
	RTS
*
XPLOF	BSR	XPLOPS
	SUB B	5,X
	SBC A	4,X
	BMI	ZBYES
*
XPLONO	INX		done, don't branch back
	INX
	INX
	INX
	STX	RP
	BRA	ZBNO	use ZBRAN to skip over unused delta
*
* ######>> screen 17 <<
* ======>>  8  <<
	FCB	$84
	FCC	3,(DO)
	FCB	$A9
	FDB	XPLOOP-10
XDO	FDB	*+2	This is the RUNTIME DO, not the COMPILING DO
	LDX	RP
	DEX
	DEX
	DEX
	DEX
	STX	RP
	PUL A
	PUL B
	STA A	2,X
	STA B	3,X
	PUL A
	PUL B
	STA A	4,X
	STA B	5,X
	JMP	NEXT
*
* ======>>  9  <<
	FCB	$81	I
	FCB	$C9
	FDB	XDO-7	
I	FDB	*+2
	LDX	RP
	INX
	INX
	JMP	GETX
*
* ######>> screen 18 <<
* ======>>  10  <<
	FCB	$85
	FCC	4,DIGIT
	FCB	$D4
	FDB	I-4
DIGIT	FDB	*+2	NOTE: legal input range is 0-9, A-Z
	TSX
	LDA A	3,X
	SUB A	#$30	ascii zero
	BMI	DIGIT2	IF LESS THAN '0', ILLEGAL
	CMP A	#$A
	BMI	DIGIT0	IF '9' OR LESS
	CMP A	#$11
	BMI	DIGIT2	if less than 'A'
	CMP A	#$2B
	BPL	DIGIT2	if greater than 'Z'
	SUB A	#7	translate 'A' thru 'F'
DIGIT0	CMP A	1,X
	BPL	DIGIT2	if not less than the base
	LDA B	#1	set flag
	STA A	3,X	store digit
DIGIT1	STA B	1,X	store the flag
	JMP	NEXT
DIGIT2	CLR B
	INS
	INS	pop bottom number
	TSX
	STA B	0,X	make sure both bytes are 00
	BRA	DIGIT1
*
* ######>> screen 19 <<
*
* The word format in the dictionary is:
*
* char-count + $80	lowest address
* char 1
* char 2
* 
* char n  + $80
* link high byte \___point to previous word
* link low  byte /
* CFA  high byte \___pnt to 6800 code
* CFA  low  byte /
* parameter fields
*    "
*    "
*    "
*
* ======>>  11  <<
	FCB	$86
	FCC	5,(FIND)
	FCB	$A9
	FDB	DIGIT-8
PFIND	FDB	*+2
	NOP
	NOP
PD	EQU	N	ptr to dict word being checked
PA0	EQU	N+2
PA	EQU	N+4
PC	EQU	N+6
	LDX	#PD
	LDA B	#4
PFIND0	PUL A		loop to get arguments
	STA A	0,X
	INX
	DEC B
	BNE	PFIND0
*
	LDX	PD
PFIND1	LDA B	0,X	get count dict count
	STA B	PC
	AND B	#$3F
	INX
	STX	PD	update PD
	LDX	PA0
	LDA A	0,X	get count from arg
	INX
	STX	PA	intialize PA
	CBA		compare lengths
	BNE	PFIND4
PFIND2	LDX	PA
	LDA A	0,X
	INX
	STX	PA
	LDX	PD
	LDA B	0,X
	INX
	STX	PD
	TST B		is dict entry neg. ?
	BPL	PFIND8
	AND B	#$7F	clear sign
	CBA
	BEQ	FOUND
PFIND3	LDX	0,X	get new link
	BNE	PFIND1	continue if link not=0
*
*	not found :
*
	CLR A
	CLR B
	JMP	PUSHBA
PFIND8	CBA
	BEQ	PFIND2
PFIND4	LDX	PD
PFIND9	LDA B	0,X	scan forward to end of this name
	INX
	BPL	PFIND9
	BRA	PFIND3
*
*	found :
*
FOUND	LDA A	PD	compute CFA
	LDA B	PD+1
	ADD B	#4
	ADC A	#0
	PSH B
	PSH A
	LDA A	PC
	PSH A
	CLR A
	PSH A
	LDA B	#1
	JMP	PUSHBA
*
	PSH A
	CLR A
	PSH A
	LDA B	#1
	JMP	PUSHBA
*
* ######>> screen 20 <<
* ======>>  12  <<
	FCB	$87
	FCC	6,ENCLOSE
	FCB 	$C5
	FDB	PFIND-9
* NOTE :
* FC means offset (bytes) to First Character of next word
* EW  "     "   to End of Word
* NC  "     "   to Next Character to start next enclose at
ENCLOS	FDB	*+2
	INS
	PUL B		now, get the low byte, for an 8-bit delimiter
	TSX
	LDX	0,X
	CLR	N
*	wait for a non-delimiter or a NUL
ENCL2	LDA A	0,X
	BEQ	ENCL6
	CBA		CHECK FOR DELIM
	BNE	ENCL3
	INX
	INC	N
	BRA	ENCL2
*	found first character. Push FC
ENCL3	LDA A	N	found first char.
	PSH A
	CLR A
	PSH A
*	wait for a delimiter or a NUL
ENCL4	LDA A	0,X
	BEQ	ENCL7
	CBA		ckech for delim.
	BEQ	ENCL5
	INX
	INC	N
	BRA	ENCL4
*	found EW. Push it
ENCL5	LDA B	N
	CLR A
	PSH B
	PSH A
*	advance and push NC
	INC B
	JMP	PUSHBA
*	found NUL before non-delimiter, therefore there is no word
ENCL6	LDA B	N	found NUL
	PSH B
	PSH A
	INC B
	BRA	ENCL7+2	
*	found NUL following the word instead of SPACE
ENCL7	LDA B	N
	PSH B		save EW
	PSH A
ENCL8	LDA B	N	save NC
	JMP	PUSHBA

	PAGE
*
* ######>> screen 21 <<
* The next 4 words call system dependant I/O routines
* which are listed after word "-->" ( lable: "arrow" )
* in the dictionary.
*
* ======>>  13  <<
	FCB	$84
	FCC	3,EMIT
	FCB	$D4
	FDB	ENCLOS-10
EMIT	FDB	*+2
	PUL A
	PUL A
	JSR	PEMIT
	LDX	UP
	INC	XOUT+1-UORIG,X
	BNE	*+4
	INC	XOUT-UORIG,X
	JMP	NEXT
*
* ======>>  14  <<
	FCB	$83
	FCC	2,KEY
	FCB	$D9
	FDB	EMIT-7
KEY	FDB	*+2
	JSR	PKEY
	PSH A
	CLR A
	PSH A
	JMP	NEXT
*
* ======>>  15  <<
	FCB	$89
	FCC	8,?TERMINAL
	FCB	$CC
	FDB	KEY-6
QTERM	FDB	*+2
	JSR	PQTER
	CLR B
	JMP	PUSHBA	stack the flag
*
* ======>>  16  <<
	FCB	$82
	FCC	1,CR
	FCB	$D2
	FDB	QTERM-12
CR	FDB	*+2
	JSR	PCR
	JMP	NEXT
*
* ######>> screen 22 <<
* ======>>  17  <<
	FCB	$85
	FCC	4,CMOVE	source, destination, count
	FCB	$C5
	FDB	CR-5
CMOVE	FDB	*+2	takes ( 43+47*count cycles )
	LDX	#N
	LDA B	#6
CMOV1	PUL A
	STA A	0,X	move parameters to scratch area
	INX
	DEC B
	BNE	CMOV1
CMOV2	LDA A	N
	LDA B	N+1
	SUB B	#1
	SBC A	#0
	STA A	N
	STA B	N+1
	BCS	CMOV3
	LDX	N+4
	LDA A	0,X
	INX
	STX	N+4
	LDX	N+2
	STA A	0,X
	INX
	STX	N+2
	BRA	CMOV2
CMOV3	JMP	NEXT
*
* ######>> screen 23 <<
* ======>>  18  <<
	FCB	$82
	FCC	1,U*
	FCB	$AA
	FDB	CMOVE-8
USTAR	FDB	*+2
	BSR	USTARS
	INS
	INS
	JMP	PUSHBA
*
* The following is a subroutine which 
* multiplies top 2 words on stack,
* leaving 32-bit result:  high order word in A,B
* low order word in 2nd word of stack.
*
USTARS	LDA A	#16	bits/word counter
	PSH A
	CLR A
	CLR B
	TSX
USTAR2	ROR	5,X	shift multiplier
	ROR	6,X
	DEC	0,X	done?
	BMI	USTAR4
	BCC	USTAR3
	ADD B	4,X
	ADC A	3,X
USTAR3	ROR A
	ROR B		shift result
	BRA	USTAR2
USTAR4	INS		dump counter
	RTS
*
* ######>> screen 23.1 <<
* ======>>  18.1  << *** NEW DOUBLES
	FCB	$82
	FCC	1,2*
	FCB	$AA
	FDB	USTAR-5
U2STAR	FDB	*+2
	TSX
	LSL	1,X
	ROL	0,X
	JMP	NEXT
* Want to keep the carry!
* Maybe like this:
*	TPA
*	AND A	#1
*	TAB
*	JMP	PUSHBA
* or like this;
*	LDA A	#0	; CLR would clear the carry
*	LDA B	#0
*	BCC	U2STAL
*	COM B
*	COM A
*U2STAL	JMP	NEXT
*
* ======>>  18.3  << *** NEW DOUBLES
	FCB	$83
	FCC	2,U2/
	FCB	$AF
	FDB	U2STAR-5
U2SLAH	FDB	*+2
	TSX
	LSR	0,X
	ROR	1,X
	JMP	NEXT
* Want to keep the carry!
*
* ######>> screen 24 <<
* ======>>  19  <<
	FCB	$82
	FCC	1,U/
	FCB	$AF
	FDB	U2SLAH-6
USLASH	FDB	*+2
* Avoid extra shifts for 32 bit dividend by just doing one cell of dividend.
* Expanding the dividend is straightforward, unlike the divisor.
	LDA A	#17	
	PSH A
	TSX
	LDA A	3,X
	LDA B	4,X
USL1	CMP A	1,X
	BHI	USL3
	BCS	USL2
	CMP B	2,X
	BCC	USL3
USL2	CLC
	BRA	USL4
USL3	SUB B	2,X
	SBC A	1,X
	SEC
USL4	ROL	6,X
	ROL	5,X
	DEC	0,X
	BEQ	USL5
	ROL B
	ROL A
	BCC	USL1
	BRA	USL3
USL5	INS
	INS
	INS
	INS
	INS
	JMP	SWAP+4	reverse quotient & remainder
*
* ######>> screen 25 <<
* ======>>  20  <<
	FCB	$83
	FCC	2,AND
	FCB	$C4
	FDB	USLASH-5
AND	FDB	*+2
	PUL A
	PUL B
	TSX
	AND B	1,X
	AND A	0,X
	JMP	STABX
*
* ======>>  21  <<
	FCB	$82
	FCC	1,OR
	FCB	$D2
	FDB	AND-6
OR	FDB	*+2
	PUL A
	PUL B
	TSX
	ORA B	1,X
	ORA A	0,X
	JMP	STABX
*	
* ======>>  22  <<
	FCB	$83
	FCC	2,XOR
	FCB	$D2
	FDB	OR-5
XOR	FDB	*+2
	PUL A
	PUL B
	TSX
	EOR B	1,X
	EOR A	0,X
	JMP	STABX
*
* ######>> screen 26 <<
* ======>>  23  <<
	FCB	$83
	FCC	2,SP@
	FCB	$C0
	FDB	XOR-6
SPAT	FDB	*+2
	TSX
	STX	N	scratch area
	LDX	#N
	JMP	GETX
*
* ======>>  24  <<
	FCB	$83
	FCC	2,SP!
	FCB	$A1
	FDB	SPAT-6
SPSTOR	FDB	*+2
	LDX	UP
	LDX	XSPZER-UORIG,X
	TXS		watch it ! X and S are not equal.
	JMP	NEXT
* ======>>  25  <<
	FCB	$83
	FCC	2,RP!
	FCB	$A1
	FDB	SPSTOR-6
RPSTOR	FDB	*+2
	LDX	RINIT	initialize from rom constant
	STX	RP
	JMP	NEXT
*
* ======>>  26  <<
	FCB	$82
	FCC	1,;S
	FCB	$D3
	FDB	RPSTOR-6
SEMIS	FDB	*+2
	LDX	RP
	INX
	INX
	STX	RP
	LDX	0,X	get address we have just finished.
	JMP	NEXT+2	increment the return address & do next word
*
* ######>> screen 27 <<
* ======>>  27  <<
	FCB	$85
	FCC	4,LEAVE
	FCB	$C5
	FDB	SEMIS-5
LEAVE	FDB	*+2
	LDX	RP
	LDA A	2,X
	LDA B	3,X
	STA A	4,X
	STA B	5,X
	JMP	NEXT
*
* ======>>  28  <<
	FCB	$82
	FCC	1,>R
	FCB	$D2
	FDB	LEAVE-8
TOR	FDB	*+2
	LDX	RP
	DEX
	DEX
	STX	RP
	PUL A
	PUL B
	STA A	2,X
	STA B	3,X
	JMP	NEXT
*
* ======>>  29  <<
	FCB	$82
	FCC	1,R>
	FCB	$BE
	FDB	TOR-5
FROMR	FDB	*+2
	LDX	RP
	LDA A	2,X
	LDA B	3,X
	INX
	INX
	STX	RP
	JMP	PUSHBA
*
* ======>>  30  <<
	FCB	$81	R
	FCB	$D2
	FDB	FROMR-5
R	FDB	*+2
	LDX	RP
	INX
	INX
	JMP	GETX
*
* ######>> screen 28 <<
* ======>>  31  <<
	FCB	$82
	FCC	1,0=
	FCB	$BD
	FDB	R-4
ZEQU	FDB	*+2
	TSX
	CLR A
	CLR B
	LDX	0,X
	BNE	ZEQU2
	INC B
ZEQU2	TSX
	JMP	STABX
*
* ======>>  32  <<
	FCB	$82
	FCC	1,0<
	FCB	$BC
	FDB	ZEQU-5
ZLESS	FDB	*+2
	TSX
	LDA A	#$80	check the sign bit
	AND A	0,X
	BEQ	ZLESS2
	CLR A		if neg.
	LDA B #1
	JMP	STABX
ZLESS2	CLR B
	JMP	STABX
*
* ######>> screen 29 <<
* ======>>  33  <<
	FCB	$81	'+'
	FCB	$AB
	FDB	ZLESS-5
PLUS	FDB	*+2
	PUL A
	PUL B
	TSX
	ADD B	1,X
	ADC A	0,X
	JMP	STABX
*
* ======>>  34  <<
	FCB	$82
	FCC	1,D+
	FCB	$AB
	FDB	PLUS-4
DPLUS	FDB	*+2
	TSX
	CLC
	LDA B	#4
DPLUS2	LDA A	3,X
	ADC A	7,X
	STA A	7,X
	DEX
	DEC B
	BNE	DPLUS2
	INS
	INS
	INS
	INS
	JMP	NEXT
*
* ======>>  35  <<
	FCB	$85
	FCC	4,MINUS
	FCB	$D3
	FDB	DPLUS-5
MINUS	FDB	*+2
	TSX
	NEG	1,X
	BCC	MINUS2
	NEG	0,X
	BRA	MINUS3
MINUS2	COM	0,X
MINUS3	JMP	NEXT
*
* ======>>  36  <<
	FCB	$86
	FCC	5,DMINUS
	FCB	$D3
	FDB	MINUS-8
DMINUS	FDB	*+2
	TSX
	COM	0,X
	COM	1,X
	COM	2,X
	NEG	3,X
	BNE	DMINX
	INC	2,X
	BNE	DMINX
	INC	1,X
	BNE	DMINX
	INC	0,X
DMINX	JMP	NEXT
*
* ######>> screen 30 <<
* ======>>  37  <<
	FCB	$84
	FCC	3,OVER
	FCB	$D2
	FDB	DMINUS-9
OVER	FDB	*+2
	TSX
	LDA A	2,X
	LDA B	3,X
	JMP	PUSHBA
*
* ======>>  38  <<
	FCB	$84
	FCC	3,DROP
	FCB	$D0
	FDB	OVER-7
DROP	FDB	*+2
	INS
	INS
	JMP	NEXT
*
* ======>>  39  <<
	FCB	$84
	FCC	3,SWAP
	FCB	$D0
	FDB	DROP-7
SWAP	FDB	*+2
	PUL A
	PUL B
	TSX
	LDX	0,X
	INS
	INS
	PSH B
	PSH A
	STX	N
	LDX	#N
	JMP	GETX
*
* ======>>  40  <<
	FCB	$83
	FCC	2,DUP
	FCB	$D0
	FDB	SWAP-7
DUP	FDB	*+2
	PUL A
	PUL B
	PSH B
	PSH A
	JMP PUSHBA
*
* ######>> screen 31 <<
* ======>>  41  <<
	FCB	$82
	FCC	1,+!
	FCB	$A1
	FDB	DUP-6
PSTORE	FDB	*+2
	TSX
	LDX	0,X
	INS
	INS
	PUL A		get stack data
	PUL B
	ADD B	1,X	add & store low byte
	STA B	1,X
	ADC A	0,X	add & store hi byte
	STA A	0,X
	JMP	NEXT
*
* ======>>  42  <<
	FCB	$86
	FCC	5,TOGGLE
	FCB	$C5
	FDB	PSTORE-5
TOGGLE	FDB	DOCOL,OVER,CAT,XOR,SWAP,CSTORE
	FDB	SEMIS
*
* ######>> screen 32 <<
* ======>>  43  <<
	FCB	$81	@
	FCB	$C0
	FDB	TOGGLE-9
AT	FDB	*+2
	TSX
	LDX	0,X	get address
	INS
	INS
	JMP	GETX
*
* ======>>  44  <<
	FCB	$82
	FCC	1,C@
	FCB	$C0
	FDB	AT-4
CAT	FDB	*+2
	TSX
	LDX	0,X
	CLR A
	LDA B	0,X
	INS
	INS
	JMP	PUSHBA
*
* ======>>  45  <<
	FCB	$81
	FCB	$A1
	FDB	CAT-5
STORE	FDB	*+2
	TSX
	LDX	0,X	get address
	INS
	INS
	JMP	PULABX
*
* ======>>  46  <<
	FCB	$82
	FCC	1,C!
	FCB	$A1
	FDB	STORE-4
CSTORE	FDB	*+2
	TSX
	LDX	0,X	get address
	INS
	INS
	INS
	PUL B
	STA B	0,X
	JMP	NEXT
	PAGE
*
* ######>> screen 33 <<
* ======>>  47  <<
	FCB	$C1	: immediate
	FCB	$BA
	FDB	CSTORE-5
COLON	FDB	DOCOL,QEXEC,SCSP,CURENT,AT,CONTXT,STORE
	FDB	CREATE,RBRAK
	FDB	PSCODE

* Here is the IP pusher for allowing
* nested words in the virtual machine:
* ( ;S is the equivalent un-nester )

DOCOL	LDX	RP	make room in the stack
	DEX
	DEX
	STX	RP
	LDA A	IP
	LDA B	IP+1	
	STA A	2,X	Store address of the high level word
	STA B	3,X	that we are starting to execute
	LDX	W	Get first sub-word of that definition
	JMP	NEXT+2	and execute it
*
* ======>>  48  <<
	FCB	$C1	;   imnediate code
	FCB	$BB
	FDB	COLON-4
SEMI	FDB	DOCOL,QCSP,COMPIL,SEMIS,SMUDGE,LBRAK
	FDB	SEMIS
*
* ######>> screen 34 <<
* ======>>  49  <<
	FCB	$88
	FCC	7,CONSTANT
	FCB	$D4
	FDB	SEMI-4
CON	FDB	DOCOL,CREATE,SMUDGE,COMMA,PSCODE
DOCON	LDX	W
	LDA A	2,X	
	LDA B	3,X	A & B now contain the constant
	JMP	PUSHBA
*
* ======>>  50  <<
	FCB	$88
	FCC	7,VARIABLE
	FCB	$C5
	FDB	CON-11
VAR	FDB	DOCOL,CON,PSCODE
DOVAR	LDA A	W
	LDA B	W+1
	ADD B	#2
	ADC A	#0	A,B now contain the address of the variable
	JMP	PUSHBA
*
* ======>>  51  <<
	FCB	$84
	FCC	3,USER
	FCB	$D2
	FDB	VAR-11
USER	FDB	DOCOL,CON,PSCODE
DOUSER	LDX	W	get offset  into user's table
	LDA A	2,X
	LDA B	3,X
	ADD B	UP+1	add to users base address
	ADC A	UP
	JMP	PUSHBA	push address of user's variable
*
* ######>> screen 35 <<
* ======>>  52  <<
	FCB	$81
	FCB	$B0	0
	FDB	USER-7
ZERO	FDB	DOCON
	FDB	0000
*
* ======>>  53  <<
	FCB	$81
	FCB	$B1	1
	FDB	ZERO-4
ONE	FDB	DOCON
	FDB	1
*
* ======>>  54  <<
	FCB	$81
	FCB	$B2	2
	FDB	ONE-4
TWO	FDB	DOCON
	FDB	2
*
* ======>>  55  <<
	FCB	$81
	FCB	$B3	3
	FDB	TWO-4
THREE	FDB	DOCON
	FDB	3
*
* ======>>  56  <<
	FCB	$82
	FCC	1,BL
	FCB	$CC
	FDB	THREE-4
BL	FDB	DOCON	ascii blank
	FDB	$20
*
* ======>>  57  <<
	FCB	$85
	FCC	4,FIRST
	FCB	$D4
	FDB	BL-5
FIRST	FDB	DOCON
	FDB	MEMEND-528	(132 * NBLK)
*
* ======>>  58  <<
	FCB	$85
	FCC	4,LIMIT	( the end of memory +1 )
	FCB	$D4
	FDB	FIRST-8
LIMIT	FDB	DOCON
	FDB	MEMEND
*
* ======>>  59  <<
	FCB	$85
	FCC	4,B/BUF	(bytes/buffer)
	FCB	$C6
	FDB	LIMIT-8
BBUF	FDB	DOCON
	FDB	128
*
* ======>>  60  <<
	FCB	$85
	FCC	4,B/SCR	(blocks/screen)
	FCB	$D2
	FDB	BBUF-8
BSCR	FDB	DOCON
	FDB	8
*	blocks/screen = 1024 / "B/BUF" = 8
*
* ======>>  61  <<
	FCB	$87
	FCC	6,+ORIGIN
	FCB	$CE
	FDB	BSCR-8
PORIG	FDB	DOCOL,LIT,ORIG,PLUS
	FDB	SEMIS
*
* ######>> screen 36 <<
* ======>>  62  <<
	FCB	$82
	FCC	1,S0
	FCB	$B0
	FDB	PORIG-10
SZERO	FDB	DOUSER
	FDB	XSPZER-UORIG
*
* ======>>  63  <<
	FCB	$82
	FCC	1,R0
	FCB	$B0
	FDB	SZERO-5
RZERO	FDB	DOUSER
	FDB	XRZERO-UORIG
*
* ======>>  64  <<
	FCB	$83
	FCC	2,TIB
	FCB	$C2
	FDB	RZERO-5
TIB	FDB	DOUSER
	FDB	XTIB-UORIG
*
* ======>>  65  <<
	FCB	$85
	FCC	4,WIDTH
	FCB	$C8
	FDB	TIB-6
WIDTH	FDB	DOUSER
	FDB	XWIDTH-UORIG
*
* ======>>  66  <<
	FCB	$87
	FCC	6,WARNING
	FCB	$C7
	FDB	WIDTH-8
WARN	FDB	DOUSER
	FDB	XWARN-UORIG
*
* ======>>  67  <<
	FCB	$85
	FCC	4,FENCE
	FCB	$C5
	FDB	WARN-10
FENCE	FDB	DOUSER
	FDB	XFENCE-UORIG
*
* ======>>  68  <<
	FCB	$82
	FCC	1,DP	points to first free byte at end of dictionary
	FCB	$D0
	FDB	FENCE-8
DP	FDB	DOUSER
	FDB	XDP-UORIG
*
* ======>>  68.5  <<
	FCB	$88
	FCC	7,VOC-LINK
	FCB	$CB
	FDB	DP-5
VOCLIN	FDB	DOUSER
	FDB	XVOCL-UORIG
*
* ======>>  69  <<
	FCB	$83
	FCC	2,BLK
	FCB	$CB
	FDB	VOCLIN-11
BLK	FDB	DOUSER
	FDB	XBLK-UORIG
*
* ======>>  70  <<
	FCB	$82
	FCC	1,IN	scan pointer for input line buffer
	FCB	$CE
	FDB	BLK-6
IN	FDB	DOUSER
	FDB	XIN-UORIG
*
* ======>>  71  <<
	FCB	$83
	FCC	2,OUT
	FCB	$D4
	FDB	IN-5
OUT	FDB	DOUSER
	FDB	XOUT-UORIG
*
* ======>>  72  <<
	FCB	$83
	FCC	2,SCR
	FCB	$D2
	FDB	OUT-6
SCR	FDB	DOUSER
	FDB	XSCR-UORIG
* ######>> screen 37 <<
*
* ======>>  73  <<
	FCB	$86
	FCC	5,OFFSET
	FCB	$D4
	FDB	SCR-6
OFSET	FDB	DOUSER
	FDB	XOFSET-UORIG
*
* ======>>  74  <<
	FCB	$87
	FCC	6,CONTEXT	points to pointer to vocab to search first
	FCB	$D4
	FDB	OFSET-9
CONTXT	FDB	DOUSER
	FDB	XCONT-UORIG
*
* ======>>  75  <<
	FCB	$87
	FCC	6,CURRENT	points to ptr. to vocab being extended
	FCB	$D4
	FDB	CONTXT-10
CURENT	FDB	DOUSER
	FDB	XCURR-UORIG
*
* ======>>  76  <<
	FCB	$85
	FCC	4,STATE	1 if compiling, 0 if not
	FCB	$C5
	FDB	CURENT-10
STATE	FDB	DOUSER
	FDB	XSTATE-UORIG
*
* ======>>  77  <<
	FCB	$84
	FCC	3,BASE	number base for all input & output
	FCB	$C5
	FDB	STATE-8
BASE	FDB	DOUSER
	FDB	XBASE-UORIG
*
* ======>>  78  <<
	FCB	$83
	FCC	2,DPL
	FCB	$CC
	FDB	BASE-7
DPL	FDB	DOUSER
	FDB	XDPL-UORIG
*
* ======>>  79  <<
	FCB	$83
	FCC	2,FLD
	FCB	$C4
	FDB	DPL-6
FLD	FDB	DOUSER
	FDB	XFLD-UORIG
*
* ======>>  80  <<
	FCB	$83
	FCC	2,CSP
	FCB	$D0
	FDB	FLD-6
CSP	FDB	DOUSER
	FDB	XCSP-UORIG
*
* ======>>  81  <<
	FCB	$82
	FCC	1,R#
	FCB	$A3
	FDB	CSP-6
RNUM	FDB	DOUSER
	FDB	XRNUM-UORIG
*
* ======>>  82  <<
	FCB	$83
	FCC	2,HLD
	FCB	$C4
	FDB	RNUM-5
HLD	FDB	DOCON
	FDB	XHLD
*
* ======>>  82.5  <<== SPECIAL
	FCB	$87
	FCC	6,COLUMNS	line width of terminal
	FCB	$D3
	FDB	HLD-6
COLUMS	FDB	DOUSER
	FDB	XCOLUM-UORIG
*
* ######>> screen 38 <<
* ======>>  83  <<
	FCB	$82
	FCC	1,1+
	FCB	$AB
	FDB	COLUMS-10
ONEP	FDB	DOCOL,ONE,PLUS
	FDB	SEMIS
*
* ======>>  84  <<
	FCB	$82
	FCC	1,2+
	FCB	$AB
	FDB	ONEP-5
TWOP	FDB	DOCOL,TWO,PLUS
	FDB	SEMIS
*
* ======>>  85  <<
	FCB	$84
	FCC	3,HERE
	FCB	$C5
	FDB	TWOP-5
HERE	FDB	DOCOL,DP,AT
	FDB	SEMIS
*
* ======>>  86  <<
	FCB	$85
	FCC	4,ALLOT
	FCB	$D4
	FDB	HERE-7
ALLOT	FDB	DOCOL,DP,PSTORE
	FDB	SEMIS
*
* ======>>  87  <<
	FCB	$81	; , (COMMA)
	FCB	$AC
	FDB	ALLOT-8
COMMA	FDB	DOCOL,HERE,STORE,TWO,ALLOT
	FDB	SEMIS
*
* ======>>  88  <<
	FCB	$82
	FCC	1,C,
	FCB	$AC
	FDB	COMMA-4
CCOMM	FDB	DOCOL,HERE,CSTORE,ONE,ALLOT
	FDB	SEMIS
*
* ======>>  89  <<
	FCB	$81	; -
	FCB	$AD
	FDB	CCOMM-5
SUB	FDB	DOCOL,MINUS,PLUS
	FDB	SEMIS
*
* ======>>  90  <<
	FCB	$81	=
	FCB	$BD
	FDB	SUB-4
EQUAL	FDB	DOCOL,SUB,ZEQU
	FDB	SEMIS
*
* ======>>  91  <<
	FCB	$81	<
	FCB	$BC	
	FDB	EQUAL-4
LESS	FDB	*+2
	PUL A
	PUL B
	TSX
	CMP A	0,X
	INS
	BGT	LESST
	BNE	LESSF
	CMP B	1,X
	BHI	LESST
LESSF	CLR B
	BRA	LESSX
LESST	LDA B	#1
LESSX	CLR A
	INS
	JMP	PUSHBA
*
* ======>>  92  <<
	FCB	$81	>
	FCB	$BE
	FDB	LESS-4
GREAT	FDB	DOCOL,SWAP,LESS
	FDB	SEMIS
*
* ======>>  93  <<
	FCB	$83
	FCC	2,ROT
	FCB	$D4
	FDB	GREAT-4
ROT	FDB	DOCOL,TOR,SWAP,FROMR,SWAP
	FDB	SEMIS
*
* ======>>  94  <<
	FCB	$85
	FCC	4,SPACE
	FCB	$C5
	FDB	ROT-6
SPACE	FDB	DOCOL,BL,EMIT
	FDB	SEMIS
*
* ======>>  95  <<
	FCB	$83
	FCC	2,MIN
	FCB	$CE
	FDB	SPACE-8
MIN	FDB	DOCOL,OVER,OVER,GREAT,ZBRAN
	FDB	MIN2-*
	FDB	SWAP
MIN2	FDB	DROP
	FDB	SEMIS
*
* ======>>  96  <<
	FCB	$83
	FCC	2,MAX
	FCB	$D8
	FDB	MIN-6
MAX	FDB	DOCOL,OVER,OVER,LESS,ZBRAN
	FDB	MAX2-*
	FDB	SWAP
MAX2	FDB	DROP
	FDB	SEMIS
*
* ======>>  97  <<
	FCB	$84
	FCC	3,-DUP
	FCB	$D0
	FDB	MAX-6
DDUP	FDB	DOCOL,DUP,ZBRAN
	FDB	DDUP2-*
	FDB	DUP
DDUP2	FDB	SEMIS
*
* ######>> screen 39 <<
* ======>>  98  <<
	FCB	$88
	FCC	7,TRAVERSE
	FCB	$C5
	FDB	DDUP-7
TRAV	FDB	DOCOL,SWAP
TRAV2	FDB	OVER,PLUS,CLITER
	FCB	$7F
	FDB	OVER,CAT,LESS,ZBRAN
	FDB	TRAV2-*
	FDB	SWAP,DROP
	FDB	SEMIS
*
* ======>>  99  <<
	FCB	$86
	FCC	5,LATEST
	FCB	$D4
	FDB	TRAV-11
LATEST	FDB	DOCOL,CURENT,AT,AT
	FDB	SEMIS
*
* ======>>  100  <<
	FCB	$83
	FCC	2,LFA
	FCB	$C1
	FDB	LATEST-9
LFA	FDB	DOCOL,CLITER
	FCB	4
	FDB	SUB
	FDB	SEMIS
*
* ======>>  101  <<
	FCB	$83
	FCC	2,CFA
	FCB	$C1
	FDB	LFA-6
CFA	FDB	DOCOL,TWO,SUB
	FDB	SEMIS
*
* ======>>  102  <<
	FCB	$83
	FCC	2,NFA
	FCB	$C1
	FDB	CFA-6
NFA	FDB	DOCOL,CLITER
	FCB	5
	FDB	SUB,ONE,MINUS,TRAV
	FDB	SEMIS
*
* ======>>  103  <<
	FCB	$83
	FCC	2,PFA
	FCB	$C1
	FDB	NFA-6
PFA	FDB	DOCOL,ONE,TRAV,CLITER
	FCB	5
	FDB	PLUS
	FDB	SEMIS
*
* ######>> screen 40 <<
* ======>>  104  <<
	FCB	$84
	FCC	3,!CSP
	FCB	$D0
	FDB	PFA-6
SCSP	FDB	DOCOL,SPAT,CSP,STORE
	FDB	SEMIS
*
* ======>>  105  <<
	FCB	$86
	FCC	5,?ERROR
	FCB	$D2
	FDB	SCSP-7
QERR	FDB	DOCOL,SWAP,ZBRAN
	FDB	QERR2-*
	FDB	ERROR,BRAN
	FDB	QERR3-*
QERR2	FDB	DROP
QERR3	FDB	SEMIS
*	
* ======>>  106  <<
	FCB	$85
	FCC	4,?COMP
	FCB	$D0
	FDB	QERR-9
QCOMP	FDB	DOCOL,STATE,AT,ZEQU,CLITER
	FCB	$11
	FDB	QERR
	FDB	SEMIS
*
* ======>>  107  <<
	FCB	$85
	FCC	4,?EXEC
	FCB	$C3
	FDB	QCOMP-8
QEXEC	FDB	DOCOL,STATE,AT,CLITER
	FCB	$12
	FDB	QERR
	FDB	SEMIS
*
* ======>>  108  <<
	FCB	$86
	FCC	5,?PAIRS
	FCB	$D3
	FDB	QEXEC-8
QPAIRS	FDB	DOCOL,SUB,CLITER
	FCB	$13
	FDB	QERR
	FDB	SEMIS
*
* ======>>  109  <<
	FCB	$84
	FCC	3,?CSP
	FCB	$D0
	FDB	QPAIRS-9
QCSP	FDB	DOCOL,SPAT,CSP,AT,SUB,CLITER
	FCB	$14
	FDB	QERR
	FDB	SEMIS
*
* ======>>  110  <<
	FCB	$88
	FCC	7,?LOADING
	FCB	$C7
	FDB	QCSP-7
QLOAD	FDB	DOCOL,BLK,AT,ZEQU,CLITER
	FCB	$16
	FDB	QERR
	FDB	SEMIS
*
* ######>> screen 41 <<
* ======>>  111  <<
	FCB	$87
	FCC	6,COMPILE
	FCB	$C5
	FDB	QLOAD-11
COMPIL	FDB	DOCOL,QCOMP,FROMR,TWOP,DUP,TOR,AT,COMMA
	FDB	SEMIS
*
* ======>>  112  <<
	FCB	$C1	[	immediate
	FCB	$DB
	FDB	COMPIL-10
LBRAK	FDB	DOCOL,ZERO,STATE,STORE
	FDB	SEMIS
*
* ======>>  113  <<
	FCB	$81	]
	FCB	$DD
	FDB	LBRAK-4
RBRAK	FDB	DOCOL,CLITER
	FCB	$C0
	FDB	STATE,STORE
	FDB	SEMIS
*
* ======>>  114  <<
	FCB	$86
	FCC	5,SMUDGE
	FCB	$C5
	FDB	RBRAK-4
SMUDGE	FDB	DOCOL,LATEST,CLITER
	FCB	$20
	FDB	TOGGLE
	FDB	SEMIS
*
* ======>>  115  <<
	FCB	$83
	FCC	2,HEX
	FCB	$D8
	FDB	SMUDGE-9
HEX	FDB	DOCOL
	FDB	CLITER
	FCB	16
	FDB	BASE,STORE
	FDB	SEMIS
*
* ======>>  116  <<
	FCB	$87
	FCC	6,DECIMAL
	FCB	$CC
	FDB	HEX-6
DEC	FDB	DOCOL
	FDB	CLITER
	FCB	10	note: hex "A"
	FDB	BASE,STORE
	FDB	SEMIS
*
* ######>> screen 42 <<
* ======>>  117  <<
	FCB	$87
	FCC	6,(;CODE)
	FCB	$A9
	FDB	DEC-10
PSCODE	FDB	DOCOL,FROMR,TWOP,LATEST,PFA,CFA,STORE
	FDB	SEMIS
*
* ======>>  118  <<
	FCB	$C5	immediate
	FCC	4,;CODE
	FCB	$C5
	FDB	PSCODE-10
SEMIC	FDB	DOCOL,QCSP,COMPIL,PSCODE,SMUDGE,LBRAK,QSTACK
	FDB	SEMIS
* note: "QSTACK" will be replaced by "ASSEMBLER" later
*
* ######>> screen 43 <<
* ======>>  119  <<
	FCB	$87
	FCC	6,<BUILDS
	FCB	$D3
	FDB	SEMIC-8
BUILDS	FDB	DOCOL,ZERO,CON
	FDB	SEMIS
*
* ======>>  120  <<
	FCB	$85
	FCC	4,DOES>
	FCB	$BE
	FDB	BUILDS-10
DOES	FDB	DOCOL,FROMR,TWOP,LATEST,PFA,STORE
	FDB	PSCODE
DODOES	LDA A	IP
	LDA B	IP+1
	LDX	RP	make room on return stack
	DEX
	DEX
	STX	RP
	STA A 	2,X	push return address
	STA B	3,X
	LDX	W	get addr of pointer to run-time code
	INX
	INX
	STX	N	stash it in scratch area
	LDX	0,X	get new IP
	STX	IP
	CLR A		get address of parameter
	LDA B	#2
	ADD B	N+1
	ADC A	N
	PSH B		and push it on data stack
	PSH A
	JMP	NEXT2
*
* ######>> screen 44 <<
* ======>>  121  <<
	FCB	$85
	FCC	4,COUNT
	FCB	$D4
	FDB	DOES-8
COUNT	FDB	DOCOL,DUP,ONEP,SWAP,CAT
	FDB	SEMIS
*
* ======>>  122  <<
	FCB	$84
	FCC	3,TYPE
	FCB	$C5
	FDB	COUNT-8
TYPE	FDB	DOCOL,DDUP,ZBRAN
	FDB	TYPE3-*
	FDB	OVER,PLUS,SWAP,XDO
TYPE2	FDB	I,CAT,EMIT,XLOOP
	FDB	TYPE2-*
	FDB	BRAN
	FDB	TYPE4-*
TYPE3	FDB	DROP
TYPE4	FDB	SEMIS
*
* ======>>  123  <<
	FCB	$89
	FCC	8,-TRAILING
	FCB	$C7
	FDB	TYPE-7
DTRAIL	FDB	DOCOL,DUP,ZERO,XDO
DTRAL2	FDB	OVER,OVER,PLUS,ONE,SUB,CAT,BL
	FDB	SUB,ZBRAN
	FDB	DTRAL3-*
	FDB	LEAVE,BRAN
	FDB	DTRAL4-*
DTRAL3	FDB	ONE,SUB
DTRAL4	FDB	XLOOP
	FDB	DTRAL2-*
	FDB	SEMIS
*
* ======>>  124  <<
	FCB	$84
	FCC	3,(.")
	FCB	$A9
	FDB	DTRAIL-12
PDOTQ	FDB	DOCOL,R,TWOP,COUNT,DUP,ONEP
	FDB	FROMR,PLUS,TOR,TYPE
	FDB	SEMIS
*
* ======>>  125  <<
	FCB	$C2	immediate
	FCC	1,."
	FCB	$A2
	FDB	PDOTQ-7
DOTQ	FDB	DOCOL
	FDB	CLITER
	FCB	$22	ascii quote
	FDB	STATE,AT,ZBRAN
	FDB	DOTQ1-*
	FDB	COMPIL,PDOTQ,WORD
	FDB	HERE,CAT,ONEP,ALLOT,BRAN
	FDB	DOTQ2-*
DOTQ1	FDB	WORD,HERE,COUNT,TYPE
DOTQ2	FDB	SEMIS
*
* ######>> screen 45 <<
* ======>>  126  <<== MACHINE DEPENDENT
	FCB	$86
	FCC	5,?STACK
	FCB	$CB
	FDB	DOTQ-5
QSTACK	FDB	DOCOL,CLITER
	FCB	$12
	FDB	PORIG,AT,TWO,SUB,SPAT,LESS,ONE
	FDB	QERR
* prints 'empty stack'
*
QSTAC2	FDB	SPAT
* Here, we compare with a value at least 128
* higher than dict. ptr. (DP)
	FDB	HERE,CLITER
	FCB	$80
	FDB	PLUS,LESS,ZBRAN
	FDB	QSTAC3-*
	FDB	TWO
	FDB	QERR
* prints 'full stack'
*
QSTAC3	FDB	SEMIS
*
* ======>>  127  <<	this word's function
*	    is done by ?STACK in this version
*	FCB	$85
*	FCC	4,?FREE
*	FCB	$C5
*	FDB	QSTACK-9
*QFREE	FDB	DOCOL,SPAT,HERE,CLITER
*	FCB	$80
*	FDB	PLUS,LESS,TWO,QERR,SEMIS
*
* ######>> screen 46 <<
* ======>>  128  <<
	FCB	$86
	FCC	5,EXPECT
	FCB	$D4
	FDB	QSTACK-9
EXPECT	FDB	DOCOL,OVER,PLUS,OVER,XDO
EXPEC2	FDB	KEY,DUP,CLITER
	FCB	$0E
	FDB	PORIG,AT,EQUAL,ZBRAN
	FDB	EXPEC3-*
	FDB	DROP,CLITER
	FCB	8	( backspace character to emit )
	FDB	OVER,I,EQUAL,DUP,FROMR,TWO,SUB,PLUS
	FDB	TOR,SUB,BRAN
	FDB	EXPEC6-*
EXPEC3	FDB	DUP,CLITER
	FCB	$D	( carriage return )
	FDB	EQUAL,ZBRAN
	FDB	EXPEC4-*
	FDB	LEAVE,DROP,BL,ZERO,BRAN
	FDB	EXPEC5-*
EXPEC4	FDB	DUP
EXPEC5	FDB	I,CSTORE,ZERO,I,ONEP,STORE
EXPEC6	FDB	EMIT,XLOOP
	FDB	EXPEC2-*
	FDB	DROP
	FDB	SEMIS
*
* ======>>  129  <<
	FCB	$85
	FCC	4,QUERY
	FCB	$D9
	FDB	EXPECT-9
QUERY	FDB	DOCOL,TIB,AT,COLUMS
	FDB	AT,EXPECT,ZERO,IN,STORE
*DBG
*	FDB	MNOP
*DBG
	FDB	SEMIS
*
* ======>>  130  <<
	FCB	$C1	immediate	< carriage return >
	FCB	$80
	FDB	QUERY-8
NULL	FDB	DOCOL,BLK,AT,ZBRAN
	FDB	NULL2-*
	FDB	ONE,BLK,PSTORE
	FDB	ZERO,IN,STORE,BLK,AT,BSCR,MOD
	FDB	ZEQU
*     check for end of screen
	FDB	ZBRAN
	FDB	NULL1-*
	FDB	QEXEC,FROMR,DROP
NULL1	FDB	BRAN
	FDB	NULL3-*
NULL2	FDB	FROMR,DROP
NULL3	FDB	SEMIS
*
* ######>> screen 47 <<
* ======>>  133  <<
	FCB	$84
	FCC	3,FILL
	FCB	$CC
	FDB	NULL-4
FILL	FDB	DOCOL,SWAP,TOR,OVER,CSTORE,DUP,ONEP
	FDB	FROMR,ONE,SUB,CMOVE
	FDB	SEMIS
*
* ======>>  134  <<
	FCB	$85
	FCC	4,ERASE
	FCB	$C5
	FDB	FILL-7
ERASE	FDB	DOCOL,ZERO,FILL
	FDB	SEMIS
*
* ======>>  135  <<
	FCB	$86
	FCC	5,BLANKS
	FCB	$D3
	FDB	ERASE-8
BLANKS	FDB	DOCOL,BL,FILL
	FDB	SEMIS
*
* ======>>  136  <<
	FCB	$84
	FCC	3,HOLD
	FCB	$C4
	FDB	BLANKS-9
HOLD	FDB	DOCOL,LIT,$FFFF,HLD,PSTORE,HLD,AT,CSTORE
	FDB	SEMIS
*
* ======>>  137  <<
	FCB	$83
	FCC	2,PAD
	FCB	$C4
	FDB	HOLD-7
PAD	FDB	DOCOL,HERE,CLITER
	FCB	$44
	FDB	PLUS
	FDB	SEMIS
*
* ######>> screen 48 <<
* ======>>  138  <<
	FCB	$84
	FCC	3,WORD
	FCB	$C4
	FDB	PAD-6
WORD	FDB	DOCOL,BLK,AT,ZBRAN
	FDB	WORD2-*
	FDB	BLK,AT,BLOCK,BRAN
	FDB	WORD3-*
WORD2	FDB	TIB,AT
WORD3	FDB	IN,AT,PLUS,SWAP,ENCLOS,HERE,CLITER
	FCB	34
	FDB	BLANKS,IN,PSTORE,OVER,SUB,TOR,R,HERE
	FDB	CSTORE,PLUS,HERE,ONEP,FROMR,CMOVE
	FDB	SEMIS
*
* ######>> screen 49 <<
* ======>>  139  <<
	FCB	$88
	FCC	7,(NUMBER)
	FCB	$A9
	FDB	WORD-7
PNUMB	FDB	DOCOL
PNUMB2	FDB	ONEP,DUP,TOR,CAT,BASE,AT,DIGIT,ZBRAN
	FDB	PNUMB4-*
	FDB	SWAP,BASE,AT,USTAR,DROP,ROT,BASE
	FDB	AT,USTAR,DPLUS,DPL,AT,ONEP,ZBRAN
	FDB	PNUMB3-*
	FDB	ONE,DPL,PSTORE
PNUMB3	FDB	FROMR,BRAN
	FDB	PNUMB2-*
PNUMB4	FDB	FROMR
	FDB	SEMIS
*
* ======>>  140  <<
	FCB	$86
	FCC	5,NUMBER
	FCB	$D2
	FDB	PNUMB-11
NUMB	FDB	DOCOL,ZERO,ZERO,ROT,DUP,ONEP,CAT,CLITER
	FCC	"-"	minus sign
	FDB	EQUAL,DUP,TOR,PLUS,LIT,$FFFF
NUMB1	FDB	DPL,STORE,PNUMB,DUP,CAT,BL,SUB
	FDB	ZBRAN
	FDB	NUMB2-*
	FDB	DUP,CAT,CLITER
	FCC	"."
	FDB	SUB,ZERO,QERR,ZERO,BRAN
	FDB	NUMB1-*
NUMB2	FDB	DROP,FROMR,ZBRAN
	FDB	NUMB3-*
	FDB	DMINUS
NUMB3	FDB	SEMIS
*
* ======>>  141  <<
	FCB	$85
	FCC	4,-FIND
	FCB	$C4
	FDB	NUMB-9
DFIND	FDB	DOCOL,BL,WORD,HERE,CONTXT,AT,AT
*DBG
	FDB	MNOP
*DBG
	FDB	PFIND
*DBG
	FDB MNOP
*DBG
	FDB DUP,ZEQU,ZBRAN
	FDB	DFIND2-*
	FDB	DROP,HERE,LATEST,PFIND
DFIND2	FDB	SEMIS
*
* ######>> screen 50 <<
* ======>>  142  <<
	FCB	$87
	FCC	6,(ABORT)
	FCB	$A9
	FDB	DFIND-8
PABORT	FDB	DOCOL,ABORT
	FDB	SEMIS
*
* ======>>  143  <<
	FCB	$85
	FCC	4,ERROR
	FCB	$D2
	FDB	PABORT-10
ERROR	FDB	DOCOL,WARN,AT,ZLESS
	FDB	ZBRAN
* note: WARNING is -1 to abort, 0 to print error #
* and 1 to print error message from disc
	FDB	ERROR2-*
	FDB	PABORT
ERROR2	FDB	HERE,COUNT,TYPE,PDOTQ
	FCB	4,7	( bell )
	FCC	" ? "
	FDB	MESS,SPSTOR,IN,AT,BLK,AT,QUIT
	FDB	SEMIS
*
* ======>>  144  <<
	FCB	$83
	FCC	2,ID.
	FCB	$AE
	FDB	ERROR-8
IDDOT	FDB	DOCOL,PAD,CLITER
	FCB	32
	FDB	CLITER
	FCB	$5F	( underline )
	FDB	FILL,DUP,PFA,LFA,OVER,SUB,PAD
	FDB	SWAP,CMOVE,PAD,COUNT,CLITER
	FCB	31
	FDB	AND,TYPE,SPACE
	FDB	SEMIS
*
* ######>> screen 51 <<
* ======>>  145  <<
	FCB	$86
	FCC	5,CREATE
	FCB	$C5
	FDB	IDDOT-6
CREATE	FDB	DOCOL,DFIND,ZBRAN
	FDB	CREAT2-*
	FDB	DROP,PDOTQ
	FCB	8
	FCB	7	( bel )
	FCC	"redef: "
	FDB	NFA,IDDOT,CLITER
	FCB	4
	FDB	MESS,SPACE
CREAT2	FDB	HERE,DUP,CAT,WIDTH,AT,MIN
	FDB	ONEP,ALLOT,DUP,CLITER
	FCB	$A0
	FDB	TOGGLE,HERE,ONE,SUB,CLITER
	FCB	$80
	FDB	TOGGLE,LATEST,COMMA,CURENT,AT,STORE
	FDB	HERE,TWOP,COMMA
	FDB	SEMIS
*
* ######>> screen 52 <<
* ======>>  146  <<
	FCB	$C9	immediate
	FCC	8,[COMPILE]
	FCB	$DD
	FDB	CREATE-9
BCOMP	FDB	DOCOL,DFIND,ZEQU,ZERO,QERR,DROP,CFA,COMMA
	FDB	SEMIS
*
* ======>>  147  <<
	FCB	$C7	immediate
	FCC	6,LITERAL
	FCB	$CC
	FDB	BCOMP-12
LITER	FDB	DOCOL,STATE,AT,ZBRAN
	FDB	LITER2-*
	FDB	COMPIL,LIT,COMMA
LITER2	FDB	SEMIS
*
* ======>>  148  <<
	FCB	$C8	immediate
	FCC	7,DLITERAL
	FCB	$CC
	FDB	LITER-10
DLITER	FDB	DOCOL,STATE,AT,ZBRAN
	FDB	DLITE2-*
	FDB	SWAP,LITER,LITER
DLITE2	FDB	SEMIS
*
* ######>> screen 53 <<
* ======>>  149  <<
	FCB	$89
	FCC	8,INTERPRET
	FCB	$D4
	FDB	DLITER-11
INTERP	FDB	DOCOL
INTER2	FDB	DFIND
*DBG
*	FDB MNOP
*	FDB OVER,OVER,HEX,DOT,DOT,DEC
*DBG
	FDB ZBRAN
	FDB	INTER5-*
	FDB	STATE,AT,LESS
	FDB	ZBRAN
	FDB	INTER3-*
	FDB	CFA,COMMA,BRAN
	FDB	INTER4-*
INTER3	FDB	CFA,EXEC
INTER4	FDB	BRAN
	FDB	INTER7-*
INTER5	FDB	HERE,NUMB,DPL,AT,ONEP,ZBRAN
	FDB	INTER6-*
	FDB	DLITER,BRAN
	FDB	INTER7-*
INTER6	FDB	DROP,LITER
INTER7	FDB	QSTACK,BRAN
	FDB	INTER2-*
*	FDB	SEMIS	never executed

*
* ######>> screen 54 <<
* ======>>  150  <<
	FCB	$89
	FCC	8,IMMEDIATE
	FCB	$C5
	FDB	INTERP-12
IMMED	FDB	DOCOL,LATEST,CLITER
	FCB	$40
	FDB	TOGGLE
	FDB	SEMIS
*
* ======>>  151  <<
	FCB	$8A
	FCC	9,VOCABULARY
	FCB	$D9
	FDB	IMMED-12
VOCAB	FDB	DOCOL,BUILDS,LIT,$81A0,COMMA,CURENT,AT,CFA
	FDB	COMMA,HERE,VOCLIN,AT,COMMA,VOCLIN,STORE,DOES
DOVOC	FDB	TWOP,CONTXT,STORE
	FDB	SEMIS
*
* ======>>  152  <<
*
* Note: FORTH does not go here in the rom-able dictionary,
*    since FORTH is a type of variable.
*
*
* ======>>  153  <<
	FCB	$8B
	FCC	10,DEFINITIONS
	FCB	$D3
	FDB	VOCAB-13
DEFIN	FDB	DOCOL,CONTXT,AT,CURENT,STORE
	FDB	SEMIS
*
* ======>>  154  <<
	FCB	$C1	immediate	(
	FCB	$A8
	FDB	DEFIN-14
PAREN	FDB	DOCOL,CLITER
	FCC	")"
	FDB	WORD
	FDB	SEMIS
*
* ######>> screen 55 <<
* ======>>  155  <<
	FCB	$84
	FCC	3,QUIT
	FCB	$D4
	FDB	PAREN-4
QUIT	FDB	DOCOL,ZERO,BLK,STORE
	FDB	LBRAK
*
*  Here is the outer interpretter
*  which gets a line of input, does it, prints " OK"
*  then repeats :
QUIT2	FDB	RPSTOR,CR,QUERY,INTERP,STATE,AT,ZEQU
	FDB	ZBRAN
	FDB	QUIT3-*
	FDB	PDOTQ
	FCB	3
	FCC	3, OK
QUIT3	FDB	BRAN
	FDB	QUIT2-*
*	FDB	SEMIS	( never executed )
*
* ======>>  156  <<
	FCB	$85
	FCC	4,ABORT
	FCB	$D4
	FDB	QUIT-7
ABORT	FDB	DOCOL,SPSTOR,DEC,QSTACK,DRZERO,CR,PDOTQ
	FCB	8
	FCC	"Forth-68"
	FDB	FORTH,DEFIN
*DBG
*	FDB TRCON
*	FDB LIT
*	FDB ABORT-8
*	FDB IDDOT
*	FDB LIT
*	FDB NULL-4
*	FDB IDDOT
*	FDB LIT
*	FDB MNOP-7
*	FDB IDDOT
*	FDB LIT
*	FDB TRCON-10
*	FDB IDDOT
*	FDB LIT
*	FDB TRCOFF-11
*	FDB IDDOT
*DBG
	FDB	QUIT
*	FDB	SEMIS	never executed
	PAGE
*
* ######>> screen 56 <<
* bootstrap code... moves rom contents to ram :
* ======>>  157  <<
	FCB	$84
	FCC	3,COLD
	FCB	$C4
	FDB	ABORT-8
COLD	FDB	*+2
CENT	LDS	#REND-1	top of destination
	LDX	#ERAM	top of stuff to move
COLD2	DEX
	LDA A	0,X
	PSH A		move TASK & FORTH to ram
	CPX	#RAM
	BNE	COLD2
*
	LDS	#XFENCE-1	put stack at a safe place for now
	LDX	COLINT
	STX	XCOLUM
	LDX	DELINT
	STX	XDELAY
	LDX	VOCINT
	STX	XVOCL
	LDX	DPINIT
	STX	XDP
	LDX	FENCIN
	STX	XFENCE


WENT	LDS	#XFENCE-1	top of destination
	LDX	#FENCIN		top of stuff to move
WARM2	DEX
	LDA A	0,X
	PSH A
	CPX	#SINIT
	BNE	WARM2
*
	LDS	SINIT
	LDX	UPINIT
	STX	UP		init user ram pointer
	LDX	#ABORT
	STX	IP
	NOP		Here is a place to jump to special user
	NOP		initializations such as I/0 interrups
	NOP
*
* For systems with TRACE:
	LDX	#00
	STX	TRLIM	clear trace mode
	LDX	#0
	STX	BRKPT	clear breakpoint address
	JMP	RPSTOR+2 start the virtual machine running !
*
* Here is the stuff that gets copied to ram :
* at address $140:
*
* Thus, MAGIC numbers that initialize USE and PREV, magically! (JMR)
* RAM	FDB	$3000,$3000,0,0
RAM	FDB	$4000+132,$4000+132,0,0
	
* ======>>  (152)  <<
	FCB	$C5	immediate
	FCC	4,FORTH
	FCB	$C8
	FDB	MNOP-7
RFORTH	FDB	DODOES,DOVOC,$81A0,TASK-7
	FDB	0
	FCC	"(C) Forth Interest Group, 1979"
	FCB	$84
	FCC	3,TASK
	FCB	$CB
	FDB	FORTH-8
RTASK	FDB	DOCOL,SEMIS
ERAM	FCC	"David Lion"	
	PAGE
*
* ######>> screen 57 <<
* ======>>  158  <<
	FCB	$84
	FCC	3,S->D
	FCB	$C4
	FDB	COLD-7
STOD	FDB	DOCOL,DUP,ZLESS,MINUS
	FDB	SEMIS


*
* ======>>  159  <<
	FCB	$81	; *
	FCB	$AA
	FDB	STOD-7
STAR	FDB	*+2
	JSR	USTARS
	INS
	INS
	JMP	NEXT
*
* ======>>  159.5  << *** NEW DOUBLES
	FCB	$82
	FCC	1,D*
	FCB	$AA
	FDB	STAR-4
DSTAR	FDB	*+2
	JSR	JSTARS
	INX
	INX
	INX
	INX
	TXS		; drop the high 2 cells
	JMP	NEXT
*
* ======>>  160  <<
	FCB	$84
	FCC	3,/MOD
	FCB	$C4
	FDB	DSTAR-5
SLMOD	FDB	DOCOL,TOR,STOD,FROMR,USLASH
	FDB	SEMIS
*
* ======>>  161  <<
	FCB	$81	; /
	FCB	$AF
	FDB	SLMOD-7
SLASH	FDB	DOCOL,SLMOD,SWAP,DROP
	FDB	SEMIS
*
* ======>>  162  <<
	FCB	$83
	FCC	2,MOD
	FCB	$C4
	FDB	SLASH-4
MOD	FDB	DOCOL,SLMOD,DROP
	FDB	SEMIS
*
* ======>>  163  <<
	FCB	$85
	FCC	4,*/MOD
	FCB	$C4
	FDB	MOD-6
SSMOD	FDB	DOCOL,TOR,USTAR,FROMR,USLASH
	FDB	SEMIS
*
* ======>>  164  <<
	FCB	$82
	FCC	1,*/
	FCB	$AF
	FDB	SSMOD-8
SSLASH	FDB	DOCOL,SSMOD,SWAP,DROP
	FDB	SEMIS
*
* ======>>  165  <<
	FCB	$85
	FCC	4,M/MOD
	FCB	$C4
	FDB	SSLASH-5
MSMOD	FDB	DOCOL,TOR,ZERO,R,USLASH
	FDB	FROMR,SWAP,TOR,USLASH,FROMR
	FDB	SEMIS
*
* ======>>  166  <<
	FCB	$83
	FCC	2,ABS
	FCB	$D3
	FDB	MSMOD-8
ABS	FDB	DOCOL,DUP,ZLESS,ZBRAN
	FDB	ABS2-*
	FDB	MINUS
ABS2	FDB	SEMIS
*
* ======>>  167  <<
	FCB	$84
	FCC	3,DABS
	FCB	$D3
	FDB	ABS-6
DABS	FDB	DOCOL,DUP,ZLESS,ZBRAN
	FDB	DABS2-*
	FDB	DMINUS
DABS2	FDB	SEMIS
*
* ######>> screen 57.1 <<
* ======>>  167.1  << *** NEW DOUBLES
	FCB	$83
	FCC	2,D2*
	FCB	$AA
	FDB	DABS-7
UD2STA	FDB	*+2
	TSX
	LSL	3,X
	ROL	2,X
	ROL	1,X
	ROL	0,X
	JMP	NEXT
* Want to keep the overflow!
*
* ======>>  167.2  << *** NEW DOUBLES
	FCB	$84
	FCC	3,UD2/
	FCB	$AF
	FDB	UD2STA-6
UD2SLA	FDB	*+2
	TSX
	LSR	0,X
	ROR	1,X
	ROR	2,X
	ROR	3,X
	JMP	NEXT
* Want to keep the carry!
*
* ######>> screen 57.2 <<
* ======>>  167.3  << *** NEW DOUBLES
	FCB	$83
	FCC	2,UD*
	FCB	$AA
	FDB	UD2SLA-7
UDSTAR	FDB	*+2
	BSR	JSTARS
	TXS		; drop the multiplicand temp area
	JMP	NEXT
*
* The following is a subroutine which 
* multiplies top 2 double words on stack,
* leaving 64-bit result on stack.
* I suppose I should compare 32 times through this loop
* with the shorter 16 bit multiply done 4 times with less data movement.
* The shorter loop is about 36 cycles times 16 == 576 plus preamble/cleanup.
* This loop is about 86 cycles times 32 == 2752 plus preamble/cleanup.
* 576 * 4 == 2304. Does moving the halves around cost 450 cycles?
* And would it save code space?
*
* : UMD* ( ud1 ud2 --- uq ) 
*   ( AL ) 3 LC@ ( BL ) 2 LC@ UM* 0 ( QL QML QMH : low cells product, ready to sum into QML QMH )
*   ( AH ) 5 LC@ ( BL ) 5 LC@ UM* >R 0 D+ ( inner product low int QML and carry )
*   ( AL ) 6 LC@ ( BH ) 4 LC@ UM* >R 0 D+ ( again, QML complete. )
*   0 ( zero to QH, ready to sum into QMH QH )
*   R> 0 D+ R> 0 D+ ( QL QML QMH QH : inner product high into QMH and carry )
*   ( AH ) 6 LC@ ( BH ) 5 LC@ UM* D+ ( Product complete, now store it. )
*   3 LC! 3 LC! 3 LC! 3 LC! 
* ;
*
* I might be able to save a hundred or so cycles.
*
* On S when we come here: ML:8 MH:6 NL:4 NH:2 PC:0
* We need a four byte work area, this time we'll use the stack.
* 
*
JSTARS	PUL A	; PC-HI		1
	PUL B	; PC-LO		2
	DES	;		3 Loop would be more expensive here.
	DES	;		4
	DES	;		5
	DES	;		6
	TSX	;		7 "protect" the PC
	PSH B	; PC-LO		8 (Not strictly necessary, just safer.)
	PSH A	; PC-HI		9	
* ML:10 MH:8 NL:6 NH:4 TL:2 TH: 0 PC:-2
	LDA A	7,X	; move things around for easy exit
	STA A	3,X
	LDA A	6,X
	STA A	2,X
	LDA A	5,X	
	STA A	1,X
	LDA A	4,X	
	STA A	0,X
* ML:10 MH:8 SL:6 SH:4 NL:2 NH: 0 PC:-2
* Except, we'll use 7,X for counter and A for least significant byte.
	CLR	6,X	; clear the summing area
	CLR	5,X
	CLR	4,X
	LDA A	#32	bits/word counter
	STA A	7,X	count
	CLR A		; least significant sum
JSTAR2	ROR	8,X	shift multiplier, keeping result in carry
	ROR	9,X
	ROR	10,X
	ROR	11,X
	DEC	7,X	done? keep carry result!
	BMI	JSTAR4
	BCC	JSTAR3
	ADD A	3,X
	LDA B	6,X
	ADC B	2,X
	STA B	6,X
	LDA B	5,X
	ADC B	1,X
	STA B	5,X
	LDA B	4,X
	ADC B	0,X
	STA B	4,X
JSTAR3	ROR	4,X 	; shift sum
	ROR	5,X
	ROR	6,X
	ROR A		; into result
	BRA	JSTAR2
JSTAR4	STA A	7,X	; save least significant byte
	INX	; Get ready to dunp the temps
	INX
	INX
	INX	; Let the caller decide how much to dump.
	RTS
*
* ######>> screen 57.3 <<
* ======>>  167.4  <<
	FCB	$86
	FCC	5,UD/MOD ( qdividend ddivisor -- dremainder dquotient )
	FCB	$C4
	FDB	UDSTAR-6 
UDSLAM	FDB	*+2
* Doing the columns game like the 16 bit division.
	LDA A	#33	; count
	TSX
	LDA B	4,X	; cache dividend MSB
	STA A	4,X	; uncache count in dividend MSB 
UDSLM1	CMP B	0,X	; Jumping out early allows saving time.
	BHI	UDSLM3	; quotient higher, can subtract
	BCS	UDSLM2	; quotient lower, skip to next
	LDA A	5,X	; loop unrolled
	CMP A	1,X
	BHI	UDSLM3
	BCS	UDSLM2
	LDA A	6,X
	CMP A	2,X
	BHI	UDSLM3
	BCS	UDSLM2
	LDA A	7,X	; low byte
	CMP A	3,X
	BCC	UDSLM3	; (BHS==BCC) Not less, can subtract
UDSLM2	CLC		; less, skip subtracting
	BRA	UDSLM4
UDSLM3	LDA A	7,X	; do the subtraction
	SUB A	3,X
	STA A	7,X
	LDA A	6,X
	SBC A	2,X
	STA A	6,X
	LDA A	5,X
	SBC A	1,X
	STA A	5,X
	SBC B	0,X	; Carry has to be clear by now.
	SEC		; record the subtraction in the quotient	
UDSLM4	ROL	11,X	; drop down the scale, next binary column
	ROL	10,X
	ROL	9,X
	ROL	8,X
	DEC	4,X		; leaves carry alone
	BEQ	UDSLM5	
	ROL	7,X	; move the rest (remainder) of the dividend for the next bit
	ROL	6,X
	ROL	5,X
	ROL B
	BCC	UDSLM1
	BRA	UDSLM3	; may need to force next in corner case
UDSLM5	INX		; drop divisor
	INX
	INX
	INX
	BRA	UDSELF	; make this rob-able by 2SWAP
UDSWAP	LDA B	0,X	; swap remainder and quotient, high byte
UDSELF	LDA A	4,X	; quotient high byte
	STA B	4,X	; remainder high byte
	STA A	0,X
	LDA B	1,X	; mid-high byte
	LDA A	5,X
	STA B	5,X
	STA A	1,X
	LDA B	2,X	; mid-low byte
	LDA A	6,X
	STA B	6,X
	STA A	2,X
	LDA B	3,X	; low byte
	LDA A	7,X
	STA B	7,X
	STA A	3,X
	TXS
	JMP	NEXT	
*
* ######>> screen 58 <<
* Disc primatives :
* ======>>  168  <<
	FCB	$83
	FCC	2,USE
	FCB	$C5
	FDB	UDSLAM-9
USE	FDB	DOCON
	FDB	XUSE
* ======>>  169  <<
	FCB	$84
	FCC	3,PREV
	FCB	$D6
	FDB	USE-6
PREV	FDB	DOCON
	FDB	XPREV
* ======>>  170  <<
	FCB	$84
	FCC	3,+BUF
	FCB	$C6
	FDB	PREV-7
PBUF	FDB	DOCOL,CLITER
	FCB	$84
	FDB	PLUS,DUP,LIMIT,EQUAL,ZBRAN
	FDB	PBUF2-*
	FDB	DROP,FIRST
PBUF2	FDB	DUP,PREV,AT,SUB
	FDB	SEMIS
*
* ======>>  171  <<
	FCB	$86
	FCC	5,UPDATE
	FCB	$C5
	FDB	PBUF-7
UPDATE	FDB	DOCOL,PREV,AT,AT,LIT,$8000,OR,PREV,AT,STORE
	FDB	SEMIS
*
* ======>>  172  <<
	FCB	$8D
	FCC	12,EMPTY-BUFFERS
	FCB	$D3
	FDB	UPDATE-9
MTBUF	FDB	DOCOL,FIRST,LIMIT,OVER,SUB,ERASE
	FDB	SEMIS
*
* ======>>  173  <<
	FCB	$83
	FCC	2,DR0
	FCB	$B0
	FDB	MTBUF-16
DRZERO	FDB	DOCOL,ZERO,OFSET,STORE
	FDB	SEMIS
*
* ======>>  174  <<== system dependant word
	FCB	$83
	FCC	2,DR1
	FCB	$B1
	FDB	DRZERO-6
*DRONE	FDB	DOCOL,LIT,$07D0,OFSET,STORE
DRONE	FDB	DOCOL,LIT,RAMDSZ,OFSET,STORE
	FDB	SEMIS
*
* ######>> screen 59 <<
* ======>>  175  <<
	FCB	$86
	FCC	5,BUFFER
	FCB	$D2
	FDB	DRONE-6
BUFFER	FDB	DOCOL,USE,AT,DUP,TOR
BUFFR2	FDB	PBUF,ZBRAN
	FDB	BUFFR2-*
	FDB	USE,STORE,R,AT,ZLESS
	FDB	ZBRAN
	FDB	BUFFR3-*
	FDB	R,TWOP,R,AT,LIT,$7FFF,AND,ZERO,RW
BUFFR3	FDB	R,STORE,R,PREV,STORE,FROMR,TWOP
	FDB	SEMIS
*
* ######>> screen 60 <<
* ======>>  176  <<
	FCB	$85
	FCC	4,BLOCK
	FCB	$CB
	FDB	BUFFER-9
BLOCK	FDB	DOCOL,OFSET,AT,PLUS,TOR
	FDB	PREV,AT,DUP,AT,R,SUB,DUP,PLUS,ZBRAN
	FDB	BLOCK5-*
BLOCK3	FDB	PBUF,ZEQU,ZBRAN
	FDB	BLOCK4-*
	FDB	DROP,R,BUFFER,DUP,R,ONE,RW,TWO,SUB
BLOCK4	FDB	DUP,AT,R,SUB,DUP,PLUS,ZEQU,ZBRAN
	FDB	BLOCK3-*
	FDB	DUP,PREV,STORE
BLOCK5	FDB	FROMR,DROP,TWOP
	FDB	SEMIS
*
* ######>> screen 61 <<
* ======>>  177  <<
	FCB	$86
	FCC	5,(LINE)
	FCB	$A9
	FDB	BLOCK-8
PLINE	FDB	DOCOL,TOR,CLITER
	FCB	$40
	FDB	BBUF,SSMOD,FROMR,BSCR,STAR,PLUS,BLOCK,PLUS,CLITER
	FCB	$40
	FDB	SEMIS
*
* ======>>  178  <<
	FCB	$85
	FCC	4,.LINE
	FCB	$C5
	FDB	PLINE-9
DLINE	FDB	DOCOL,PLINE,DTRAIL,TYPE
	FDB	SEMIS
*
* ======>>  179  <<
	FCB	$87
	FCC	6,MESSAGE
	FCB	$C5
	FDB	DLINE-8
MESS	FDB	DOCOL,WARN,AT,ZBRAN
	FDB	MESS3-*
	FDB	DDUP,ZBRAN
	FDB	MESS3-*
	FDB	CLITER
	FCB	4
	FDB	OFSET,AT,BSCR,SLASH,SUB,DLINE,BRAN
	FDB	MESS4-*
MESS3	FDB	PDOTQ
	FCB	6
	FCC	6,err # ; Make sure there's a space there at the end.
	FDB	DOT
MESS4	FDB	SEMIS
*
* ======>>  180  <<
	FCB	$84
	FCC	3,LOAD	input:scr #
	FCB	$C4
	FDB	MESS-10
LOAD	FDB	DOCOL,BLK,AT,TOR,IN,AT,TOR,ZERO,IN,STORE
	FDB	BSCR,STAR,BLK,STORE
	FDB	INTERP,FROMR,IN,STORE,FROMR,BLK,STORE
	FDB	SEMIS
*
* ======>>  181  <<
	FCB	$C3
	FCC	2,-->
	FCB	$BE
	FDB	LOAD-7
ARROW	FDB	DOCOL,QLOAD,ZERO,IN,STORE,BSCR
	FDB	BLK,AT,OVER,MOD,SUB,BLK,PSTORE
	FDB	SEMIS
	PAGE
*
*
* ######>> screen 63 <<
*    The next 4 subroutines are machine dependent, and are
*    called by words 13 through 16 in the dictionary.
*
* ======>>  182  << code for EMIT
* PEMIT	JMP	$F018	; EXBUG outch, rob the RTS.
PEMIT	STA B	N+1	save B
	STX	N+2	save X
	LDA B	ACIAC
	BIT B	#2	check ready bit
	BEQ	PEMIT+4	if not ready for more data
	STA A	N
	AND A	#$7F
	STA A	ACIAD
	LDX	UP
	STA B	IOSTAT-UORIG,X
	LDA A	N
	LDA B	N+1	recover B & X
	LDX	N+2
	RTS		only A register may change
*  PEMIT	JMP	$E1D1	for MIKBUG
*  PEMIT	FCB	$3F,$11,$39	for PROTO
*  PEMIT	JMP	$D286 for Smoke Signal DOS
*
* ======>>  183  << code for KEY
PKEY	CLR	$FF53
	INC	$FF53	; shut off echo
	JMP	$F015	; EXBUG inch, rob the RTS.
* PKEY	STA B	N
*	STX	N+1
*	LDA B	ACIAC
*	ASR B
*	BCC	PKEY+4	no incoming data yet
*	LDA A	ACIAD
*	AND A	#$7F	strip parity bit
*	LDX	UP
*	STA B	IOSTAT+1-UORIG,X
*	LDA B	N
*	LDX	N+1
*	RTS
*  PKEY	JMP	$E1AC	for MIKBUG
*  PKEY	FCB	$3F,$14,$39	for PROTO
*  PKEY	JMP	$D289 for Smoke Signal DOS
*
* ######>> screen 64 <<
* ======>>  184  << code for ?TERMINAL
PQTER	LDA A	ACIAC	Test for 'break'  condition
	AND A	#$11	mask framing error bit and
*			input buffer full
	BEQ	PQTER2
	LDA A	ACIAD	clear input buffer
	LDA A	#01
PQTER2	RTS


	PAGE
*
* ======>>  185  << code for CR
PCR	JMP	$F021	; EXBUG pcrlf, rob the RTS.
* PCR	LDA A	#$D	carriage return
*	BSR	PEMIT
*	LDA A	#$A	line feed
*	BSR	PEMIT
*	LDA A	#$7F	rubout
*	LDX	UP
*	LDA B	XDELAY+1-UORIG,X
* PCR2	DEC B
*	BMI	PQTER2	return if minus
*	PSH B		save counter
*	BSR	PEMIT	print RUBOUTs to delay.....
*	PUL B
*	BRA	PCR2	repeat


	PAGE
*
* ######>> screen 66 <<
* ======>>  187  <<
	FCB	$85
	FCC	4,?DISC
	FCB	$C3
	FDB	ARROW-6
QDISC	FDB	*+2
	JMP	NEXT
*
* ######>> screen 67 <<
* ======>>  189  <<
	FCB	$8B
	FCC	10,BLOCK-WRITE
	FCB	$C5
	FDB	QDISC-8
BWRITE	FDB	*+2
	JMP	NEXT
*
* ######>> screen 68 <<
* ======>>  190  <<
	FCB	$8A
	FCC	9,BLOCK-READ
	FCB	$C4
	FDB	BWRITE-14
BREAD	FDB	*+2
	JMP	NEXT
*
*The next 3 words are written to create a substitute for disc
* mass memory,located between $3210 & $3FFF in ram.
* ======>>  190.1  <<
	FCB	$82
	FCC	1,LO
	FCB	$CF
	FDB	BREAD-13
LO	FDB	DOCON
	FDB	MEMEND	a system dependent equate at front
*
* ======>>  190.2  <<
	FCB	$82
	FCC	1,HI
	FCB	$C9
	FDB	LO-5
HI	FDB	DOCON
*	FDB	MEMTOP	( $3FFF ($7FFF) in this version )
	FDB	RAMDEN
*
* ######>> screen 69 <<
* ======>>  191  <<
	FCB	$83
	FCC	2,R/W
	FCB	$D7
	FDB	HI-5
RW	FDB	DOCOL,TOR,BBUF,STAR,LO,PLUS,DUP,HI,GREAT,ZBRAN
	FDB	RW2-*
	FDB	PDOTQ
	FCB	8
	FCC	8, Range ?
	FDB	QUIT
RW2	FDB	FROMR,ZBRAN
	FDB	RW3-*
	FDB	SWAP
RW3	FDB	BBUF,CMOVE
	FDB	SEMIS
*
* ######>> screen 72 <<
* ======>>  192  <<
	FCB	$C1	immediate
	FCB	$A7	'	( tick )
	FDB	RW-6
TICK	FDB	DOCOL,DFIND,ZEQU,ZERO,QERR,DROP,LITER
	FDB	SEMIS
*
* ======>>  193  <<
	FCB	$86
	FCC	5,FORGET
	FCB	$D4
	FDB	TICK-4
FORGET	FDB	DOCOL,CURENT,AT,CONTXT,AT,SUB,CLITER
	FCB	$18
	FDB	QERR,TICK,DUP,FENCE,AT,LESS,CLITER
	FCB	$15
	FDB	QERR,DUP,ZERO,PORIG,GREAT,CLITER
	FCB	$15
	FDB	QERR,DUP,NFA,DP,STORE,LFA,AT,CONTXT,AT,STORE
	FDB	SEMIS
*
* ######>> screen 73 <<
* ======>>  194  <<
	FCB	$84
	FCC	3,BACK
	FCB	$CB
	FDB	FORGET-9
BACK	FDB	DOCOL,HERE,SUB,COMMA
	FDB	SEMIS
*
* ======>>  195  <<
	FCB	$C5
	FCC	4,BEGIN
	FCB	$CE
	FDB	BACK-7
BEGIN	FDB	DOCOL,QCOMP,HERE,ONE
	FDB	SEMIS
*
* ======>>  196  <<
	FCB	$C5
	FCC	4,ENDIF
	FCB	$C6
	FDB	BEGIN-8
ENDIF	FDB	DOCOL,QCOMP,TWO,QPAIRS,HERE
	FDB	OVER,SUB,SWAP,STORE
	FDB	SEMIS
*
* ======>>  197  <<
	FCB	$C4
	FCC	3,THEN
	FCB	$CE
	FDB	ENDIF-8
THEN	FDB	DOCOL,ENDIF
	FDB	SEMIS
*
* ======>>  198  <<
	FCB	$C2
	FCC	1,DO
	FCB	$CF
	FDB	THEN-7
DO	FDB	DOCOL,COMPIL,XDO,HERE,THREE
	FDB	SEMIS
*
* ======>>  199  <<
	FCB	$C4
	FCC	3,LOOP
	FCB	$D0
	FDB	DO-5
LOOP	FDB	DOCOL,THREE,QPAIRS,COMPIL,XLOOP,BACK
	FDB	SEMIS
*
* ======>>  200  <<
	FCB	$C5
	FCC	4,+LOOP
	FCB	$D0
	FDB	LOOP-7
PLOOP	FDB	DOCOL,THREE,QPAIRS,COMPIL,XPLOOP,BACK
	FDB	SEMIS
*
* ======>>  201  <<
	FCB	$C5
	FCC	4,UNTIL	( same as END )
	FCB	$CC
	FDB	PLOOP-8
UNTIL	FDB	DOCOL,ONE,QPAIRS,COMPIL,ZBRAN,BACK
	FDB	SEMIS
*
* ######>> screen 74 <<
* ======>>  202  <<
	FCB	$C3
	FCC	2,END
	FCB	$C4
	FDB	UNTIL-8
END	FDB	DOCOL,UNTIL
	FDB	SEMIS
*
* ======>>  203  <<
	FCB	$C5
	FCC	4,AGAIN
	FCB	$CE
	FDB	END-6
AGAIN	FDB	DOCOL,ONE,QPAIRS,COMPIL,BRAN,BACK
	FDB	SEMIS
*
* ======>>  204  <<
	FCB	$C6
	FCC	5,REPEAT
	FCB	$D4
	FDB	AGAIN-8
REPEAT	FDB	DOCOL,TOR,TOR,AGAIN,FROMR,FROMR
	FDB	TWO,SUB,ENDIF
	FDB	SEMIS
*
* ======>>  205  <<
	FCB	$C2
	FCC	1,IF
	FCB	$C6
	FDB	REPEAT-9
IF	FDB	DOCOL,COMPIL,ZBRAN,HERE,ZERO,COMMA,TWO
	FDB	SEMIS
*
* ======>>  206  <<
	FCB	$C4
	FCC	3,ELSE
	FCB	$C5
	FDB	IF-5
ELSE	FDB	DOCOL,TWO,QPAIRS,COMPIL,BRAN,HERE
	FDB	ZERO,COMMA,SWAP,TWO,ENDIF,TWO
	FDB	SEMIS
*
* ======>>  207  <<
	FCB	$C5
	FCC	4,WHILE
	FCB	$C5
	FDB	ELSE-7
WHILE	FDB	DOCOL,IF,TWOP
	FDB	SEMIS
*
* ######>> screen 75 <<
* ======>>  208  <<
	FCB	$86
	FCC	5,SPACES
	FCB	$D3
	FDB	WHILE-8
SPACES	FDB	DOCOL,ZERO,MAX,DDUP,ZBRAN
	FDB	SPACE3-*
	FDB	ZERO,XDO
SPACE2	FDB	SPACE,XLOOP
	FDB	SPACE2-*
SPACE3	FDB	SEMIS
*
* ======>>  209  <<
	FCB	$82
	FCC	1,<#
	FCB	$A3
	FDB	SPACES-9
BDIGS	FDB	DOCOL,PAD,HLD,STORE
	FDB	SEMIS
*
* ======>>  210  <<
	FCB	$82
	FCC	1,#>
	FCB	$BE
	FDB	BDIGS-5
EDIGS	FDB	DOCOL,DROP,DROP,HLD,AT,PAD,OVER,SUB
	FDB	SEMIS
*
* ======>>  211  <<
	FCB	$84
	FCC	3,SIGN
	FCB	$CE
	FDB	EDIGS-5
SIGN	FDB	DOCOL,ROT,ZLESS,ZBRAN
 	FDB	SIGN2-*
 	FDB	CLITER
 	FCC	"-"	
 	FDB	HOLD
SIGN2	FDB	SEMIS
*
* ======>>  212  <<
	FCB	$81	#
	FCB	$A3
	FDB	SIGN-7
DIG	FDB	DOCOL,BASE,AT,MSMOD,ROT,CLITER
	FCB	9
	FDB	OVER,LESS,ZBRAN
	FDB	DIG2-*
	FDB	CLITER
	FCB	7
	FDB	PLUS
DIG2	FDB	CLITER
	FCC	"0"	ascii zero
	FDB	PLUS,HOLD
	FDB	SEMIS
*
* ======>>  213  <<
	FCB	$82
	FCC	1,#S
	FCB	$D3
	FDB	DIG-4
DIGS	FDB	DOCOL
DIGS2	FDB	DIG,OVER,OVER,OR,ZEQU,ZBRAN
	FDB	DIGS2-*
	FDB	SEMIS
*
* ######>> screen 76 <<
* ======>>  214  <<
	FCB	$82
	FCC	1,.R
	FCB	$D2
	FDB	DIGS-5
DOTR	FDB	DOCOL,TOR,STOD,FROMR,DDOTR
	FDB	SEMIS
*
* ======>>  215  <<
	FCB	$83
	FCC	2,D.R
	FCB	$D2
	FDB	DOTR-5
DDOTR	FDB	DOCOL,TOR,SWAP,OVER,DABS,BDIGS,DIGS,SIGN
	FDB	EDIGS,FROMR,OVER,SUB,SPACES,TYPE
	FDB	SEMIS
*
* ======>>  216  <<
	FCB	$82
	FCC	1,D.
	FCB	$AE
	FDB	DDOTR-6
DDOT	FDB	DOCOL,ZERO,DDOTR,SPACE
	FDB	SEMIS
*
* ======>>  217  <<
	FCB	$81	.
	FCB	$AE
	FDB	DDOT-5
DOT	FDB	DOCOL,STOD,DDOT
	FDB	SEMIS
*
* ======>>  218  <<
	FCB	$81	?
	FCB	$BF
	FDB	DOT-4
QUEST	FDB	DOCOL,AT,DOT
	FDB	SEMIS
*
* ######>> screen 77 <<
* ======>>  219  <<
	FCB	$84
	FCC	3,LIST
	FCB	$D4
	FDB	QUEST-4
LIST	FDB	DOCOL,DEC,CR,DUP,SCR,STORE,PDOTQ
	FCB	6
	FCC	"SCR # "
	FDB	DOT,CLITER
	FCB	$10
	FDB	ZERO,XDO
LIST2	FDB	CR,I,THREE
	FDB	DOTR,SPACE,I,SCR,AT,DLINE,XLOOP
	FDB	LIST2-*
	FDB	CR
	FDB	SEMIS
*
* ======>>  220  <<
	FCB	$85
	FCC	4,INDEX
	FCB	$D8
	FDB	LIST-7
INDEX	FDB	DOCOL,CR,ONEP,SWAP,XDO
INDEX2	FDB	CR,I,THREE
	FDB	DOTR,SPACE,ZERO,I,DLINE
	FDB	QTERM,ZBRAN
	FDB	INDEX3-*
	FDB	LEAVE
INDEX3	FDB	XLOOP
	FDB	INDEX2-*
	FDB	SEMIS
*
* ======>>  221  <<
	FCB	$85
	FCC	4,TRIAD
	FCB	$C4
	FDB	INDEX-8
TRIAD	FDB	DOCOL,THREE,SLASH,THREE,STAR
	FDB	THREE,OVER,PLUS,SWAP,XDO
TRIAD2	FDB	CR,I
	FDB	LIST,QTERM,ZBRAN
	FDB	TRIAD3-*
	FDB	LEAVE
TRIAD3	FDB	XLOOP
	FDB	TRIAD2-*
	FDB	CR,CLITER
	FCB	$0F
	FDB	MESS,CR
	FDB	SEMIS
*
* ######>> screen 78 <<
* ======>>  222  <<
	FCB	$85
	FCC	4,VLIST
	FCB	$D4
	FDB	TRIAD-8
VLIST	FDB	DOCOL,CLITER
	FCB	$80
	FDB	OUT,STORE,CONTXT,AT,AT
VLIST1	FDB	OUT,AT,COLUMS,AT,CLITER
	FCB	32
	FDB	SUB,GREAT,ZBRAN
	FDB	VLIST2-*
	FDB	CR,ZERO,OUT,STORE
VLIST2	FDB	DUP
*	FDB TRCON
	FDB IDDOT,SPACE,SPACE,PFA,LFA,AT
	FDB	DUP,ZEQU,QTERM,OR
*	FDB TRCOFF
	FDB ZBRAN
	FDB	VLIST1-*
	FDB	DROP
	FDB	SEMIS
*
* ======>>  XX  <<
	FCB	$84
	FCC	3,NOOP
	FCB	$D0
	FDB	VLIST-8
NOOP	FDB	NEXT	a useful no-op
*
* ======>>  XX1  <<
	FDB	$87
	FCC	6,TRACEON
	FCB	$CE
	FDB	NOOP-7
TRCON	FDB	*+2
	CLR	TRACEM
	INC	TRACEM
	JMP	NEXT
*
* ======>>  XX2  <<
	FDB	$88
	FCC	7,TRACEOFF
	FCB	$C6
	FDB	TRCON-10
TRCOFF	FDB	*+2
	CLR	TRACEM
	JMP	NEXT
*
* ======>>  XXX  <<
	FDB	$84
	FCC	3,MNOP
	FCB	$D0
	FDB	TRCOFF-11
MNOP	FDB	*+2
	NOP		a place to insert a machine-level breakpoint.
	JMP	NEXT
*
ZZZZ	FDB	0,0,0,0,0,0,0,0	end of rom program
*
	ORG	MEMEND	simulating disc on-line
* SCREEN 0
	FCC	"0) Index to BIF HI-LEVEL disk                                   "
	FCC	"1)                                                              "
	FCC	"2) Title page, Copr. notice                                     "
	FCC	"3) MONITOR CALL TO DEBUG                                        "
	FCC	"4) ERROR MESSAGES                                               "
	FCC	"5)                                                              "
	FCC	"6)                                                              "
	FCC	"7)                                                              "
	FCC	"8)                                                              "
	FCC	"9)                                                              "
	FCC	"10)                                                             "
	FCC	"11)                                                             "
	FCC	"12)                                                             "
	FCC	"13)                                                             "
	FCC	"14)                                                             "
	FCC	"15)                                                             "
* SCREEN 1
	FCC	"16)                                                             "
	FCC	"17)                                                             "
	FCC	"18)                                                             "
	FCC	"19)                                                             "
	FCC	"20)                                                             "
	FCC	"21)                                                             "
	FCC	"22)                                                             "
	FCC	"23)                                                             "
	FCC	"24)                                                             "
	FCC	"25)                                                             "
	FCC	"26)                                                             "
	FCC	"27)                                                             "
	FCC	"28)                                                             "
	FCC	"29)                                                             "
	FCC	"30)                                                             "
	FCC	"31)                                                             "
* SCREEN 2
	FCC	" ( FORTH 68 RAM resident utilities and testing stuff )          " 0
	FCC	" ( Copyright 2013 Joel Rees )                                   " 1
	FCC	"                                                                " 2
	FCC	"                                                                " 3
	FCC	"                                                                " 4
	FCC	"                                                                " 5
	FCC	"                                                                " 6
	FCC	"                                                                " 7
	FCC	"                                                                " 8
	FCC	"                                                                " 9
	FCC	"                                                                " 10
	FCC	"                                                                " 11
	FCC	"                                                                " 12
	FCC	"                                                                " 13
	FCC	"                                                                " 14
	FCC	"                                                                " 15
* SCREEN 3
	FCC	" ( No need to call the monitor in exorsim, just ctrl-c. )       " 0
	FCC	" ( But maybe we can put some other useful stuff here. )         " 1
	FCC	"                                                                " 2
	FCC	" 1 WARNING !                                                    " 3
	FCC	"                                                                " 4
	FCC	" VOCABULARY DEBUG DEFINITIONS                                   " 5
	FCC	" ( addr n -- )                                                  " 6
	FCC	" : DUMPHEX BASE @ >R HEX                                        " 7
	FCC	"           0 DO DUP I + C@ 0 <# # # #> TYPE SPACE LOOP          " 8
	FCC	"           DROP R> BASE ! ;                                     " 9
	FCC	"                                                                " 10
	FCC	"                                                                " 11
	FCC	"                                                                " 12
	FCC	"                                                                " 13
	FCC	"                                                                " 14
	FCC	" FORTH DEFINITIONS                                              " 15
* SCREEN 4
	FCC	"( ERROR MESSAGES )                                              " 0
	FCC	"DATA STACK UNDERFLOW                                            " 1
	FCC	"DICTIONARY FULL                                                 " 2
	FCC	"ADDRESS RESOLUTION ERROR                                        " 3
	FCC	"HIDES DEFINITION IN                                             " 4
	FCC	"NULL VECTOR WRITTEN                                             " 5
	FCC	"DISC RANGE?                                                     " 6
	FCC	"DATA STACK OVERFLOW                                             " 7
	FCC	"DISC ERROR!                                                     " 8
	FCC	"CAN'T EXECUTE A NULL!                                           " 9
	FCC	"CONTROL STACK UNDERFLOW                                         " 10
	FCC	"CONTROL STACK OVERFLOW                                          " 11
	FCC	"ARRAY REFERENCE OUT OF BOUNDS                                   " 12
	FCC	"ARRAY DIMENSION NOT VALID                                       " 13
	FCC	"NO PROCEDURE TO ENTER                                           " 14
	FCC	"               ( WAS REGISTER )                                 " 15
* SCREEN 5
	FCC	"                                                                " 0
	FCC	"COMPILATION ONLY, USE IN DEF                                    " 1
	FCC	"EXECUTION ONLY                                                  " 2
	FCC	"CONDITIONALS NOT PAIRED                                         " 3
	FCC	"DEFINITION INCOMPLETE                                           " 4
	FCC	"IN PROTECTED DICTIONARY                                         " 5
	FCC	"USE ONLY WHEN LOADING                                           " 6
	FCC	"OFF CURRENT EDITING SCREEN                                      " 7 
	FCC	"DECLARE VOCABULARY                                              " 8
	FCC	"DEFINITION NOT IN VOCABULARY                                    " 9
	FCC	"IN FORWARD BLOCK                                                " 10
	FCC	"ALLOCATION LIST CORRUPTED: LOST                                 " 11
	FCC	"CAN'T REDEFINE nul!                                             " 12
	FCC	"NOT FORWARD REFERENCE                                           " 13
	FCC	"              ( WAS IMMEDIATE )                                 " 14
	FCC	"                                                                " 15
* SCREEN 6
	FCC	"( MORE ERROR MESSAGES asm6809 )                                 " 0
	FCC	"HAS INCORRECT ADDRESS MODE                                      " 1
	FCC	"HAS INCORRECT INDEX MODE                                        " 2
	FCC	"OPERAND NOT REGISTER                                            " 3
	FCC	"HAS ILLEGAL IMMEDIATE                                           " 4
	FCC	"PC OFFSET MUST BE ABSOLUTE                                      " 5
	FCC	"ACCUMULATOR OFFSET REQUIRED                                     " 6
	FCC	"ILLEGAL MEMORY INDIRECTION  (6809)                              " 7
	FCC	"ILLEGAL INDEX BASE (6809)                                       " 8
	FCC	"ILLEGAL TARGET SPECIFIED                                        " 9
	FCC	"CAN'T STACK ON SELF (6809)                                      " 10
	FCC	"DUPLICATE IN LIST                                               " 11
	FCC	"REGISTER NOT STACK (6809)                                       " 12
	FCC	"EMPTY REGISTER LIST (6809)                                      " 13
	FCC	"IMMEDIATE OPERAND REQUIRED                                      " 14
	FCC	"REQUIRES CONDITION                                              " 15
* 
* SCREEN 7
	FCC	"                                                                " 0
	FCC	"COMPILE-TIME STACK UNDERFLOW                                    " 1
	FCC	"COMPILE-TIME STACK OVERFLOW                                     " 2
	FCC	"                                                                " 3
	FCC	"                                                                " 4
	FCC	"                                                                " 5
	FCC	"                                                                " 6
	FCC	"                                                                " 7
	FCC	"                                                                " 8
	FCC	"                                                                " 9
	FCC	"                                                                " 10
	FCC	"                                                                " 11
	FCC	"                                                                " 12
	FCC	"                                                                " 13
	FCC	"                                                                " 14
	FCC	"                                                                " 15
*
* SCREEN 8
	FCC	" ( Crude editing facilities. -- one byte characters )           " 0
	FCC	"                                                                " 1
	FCC	" VOCABULARY EDITOR DEFINITIONS                                  " 2
	FCC	"                                                                " 3
	FCC	" ( n -- nb nc )  ( convert line number to block, count offset ) " 4
	FCC	" : L2BLOCK 64 * B/BUF /MOD ; ( 64 characters per line magic # ) " 5
	FCC	"                                                                " 6
	FCC	" ( n -- n )           ( convert screen number to block number ) " 7
	FCC	" : S2BLOCK B/SCR * ;          ( magic numbers hidden in B/SCR ) " 8
	FCC	"                                                                " 9
	FCC	" ( ns nl -- addr )         ( screen, line to address in block ) " 10
	FCC	" : SL2BB SWAP S2BLOCK SWAP L2BLOCK SWAP >R + BLOCK R> + ;       " 11
	FCC	"                                                                " 12
	FCC	" ( ns nl -- )                   ( show one line of the screen ) " 13
	FCC	" : SHOWLINE SL2BB CR 64 TYPE ;           ( list just one line ) " 14
	FCC	" -->                                                            " 15
*
* SCREEN 9
	FCC	" ( More crude editing facilities. -- one byte characters )      " 0
	FCC	"                                                                " 1
	FCC	" 0 VARIABLE LNEDBUF 62 ALLOT        ( buffer for line editing ) " 2
	FCC	"                                                                " 3
	FCC	" ( ns nl -- )              ( overwrite one line of the screen ) " 4
	FCC	" : PUTLINE LNEDBUF 64 BLANKS   ( just enough to write to disc ) " 5
	FCC	"           CR LNEDBUF 64 EXPECT CR     ( just enough to write ) " 6
	FCC	"           SL2BB LNEDBUF SWAP 64 CMOVE UPDATE ;                 " 7
	FCC	"       ( Full screen editing requires keyboard control codes. ) " 8
	FCC	"                                                                " 9
	FCC	"                                                                " 10
	FCC	"                                                                " 11
	FCC	"                                                                " 12
	FCC	"                                                                " 13
	FCC	"                                                                " 14
	FCC	"                                                                " 15
*
* I don't know enough about the EXORciser, and don't want to take the time 
* to try to work through the disk simulation in exorsim to get real simulated 
* disk access running.
* This gives me enough to check my understanding of forth, to help me figure 
* out my bif-c project or whatever my next step is.
*
* Going farther with the exorsim version of the fig-FORTH 6800 model would be 
* a good student exercise, maybe? (For what coursework?)
* But I think I need to move on.
*
* SCREEN 10
	FCC	"                                                                " 0
	FCC	"                                                                " 1
	FCC	"                                                                " 2
	FCC	"                                                                " 3
	FCC	"                                                                " 4
	FCC	"                                                                " 5
	FCC	"                                                                " 6
	FCC	"                                                                " 7
	FCC	"                                                                " 8
	FCC	"                                                                " 9
	FCC	"                                                                " 10
	FCC	"                                                                " 11
	FCC	"                                                                " 12
	FCC	"                                                                " 13
	FCC	"                                                                " 14
	FCC	"                                                                " 15
*
* SCREEN 11
	FCC	"                                                                " 0
	FCC	"                                                                " 1
	FCC	"                                                                " 2
	FCC	"                                                                " 3
	FCC	"                                                                " 4
	FCC	"                                                                " 5
	FCC	"                                                                " 6
	FCC	"                                                                " 7
	FCC	"                                                                " 8
	FCC	"                                                                " 9
	FCC	"                                                                " 10
	FCC	"                                                                " 11
	FCC	"                                                                " 12
	FCC	"                                                                " 13
	FCC	"                                                                " 14
	FCC	"                                                                " 15
*
* SCREEN 12
	FCC	"                                                                " 0
	FCC	"                                                                " 1
	FCC	"                                                                " 2
	FCC	"                                                                " 3
	FCC	"                                                                " 4
	FCC	"                                                                " 5
	FCC	"                                                                " 6
	FCC	"                                                                " 7
	FCC	"                                                                " 8
	FCC	"                                                                " 9
	FCC	"                                                                " 10
	FCC	"                                                                " 11
	FCC	"                                                                " 12
	FCC	"                                                                " 13
	FCC	"                                                                " 14
	FCC	"                                                                " 15
*
RAMDEN	EQU	*
RAMDSZ	EQU	RAMDEN-MEMEND
*
	ORG	ORIG	; set the COLD entry address





	PAGE
	OPT	L
	END