💾 Archived View for mirrors.apple2.org.za › archive › www.textfiles.com › apple › ANATOMY › t.dos.9f… captured on 2024-12-17 at 17:09:53.

View Raw

More Information

⬅️ Previous capture (2023-01-29)

-=-=-=-=-=-=-



OPUTHDL2 CMP #$8D ;<CR>?
 BNE DSPLYALL ;NO - (WAS AN "RH BRACKETT"?)
SET2EVAL LDX #0 ;SET CONDITION0 - EVALUATE START
 STX OPUTCOND ;OF LINE.
 JMP DSPLYALL ;GO DISPLAY CHAR UNCONDITIONALLY.




OPUTHDL3 LDX #0 ;SET CONDITION 0 WHEN INPUT ENDS.
 STX OPUTCOND
 CMP #$8D ;<CR>?
 BEQ ASUMIMED ;YES.


TESTEXEC LDA EXECFLAG ;ARE WE EXECING?
 BEQ DSPLYALL ;NO.
 BNE DSPLYINP ;YES.  EXECFLAG CONTAINS THE 1RST
;CHR OF NAME OF THE EXEC FILE.

ASUMIMED PHA ;SAVE CHAR ON STK.
 SEC ;(C)=1, DFLT, ASSUME IMMED MODE.
 LDA EXECFLAG ;ARE WE EXECING?
 BNE TESTMODE ;BRANCH IF EXECING.
 JSR CKBSCRUN ;NOT EXECING, SO SEE IF BASIC IS
;RUNNING A PRGM OR NOT.
;(C) = 0, EITHER BASIC RUNNING.
;(C) = 1 IF IMMEDIATE.
TESTMODE PLA ;RETRIEVE CHAR FROM STK.
 BCC TESTEXEC ;BASIC RUNNING, DSPLY INPUT & XIT



 LDX XSAVED ;RETRIEVE (X).
 JMP PUTINBUF ;GO PUT CHR IN INPUT BUF (COND 1)




OPUTHDL4 CMP #$8D ;<CR>?
 BNE CMWRTBYT ;NO.
 LDA #5 ;SET CONDITION 5.
 STA OPUTCOND
CMWRTBYT JSR WRITEXT ;GO WRITE DATA BYTE.
 JMP DSPLYOUT ;DISPLAY OUTPUT CONDITIONALLY.




OPUTHDL5 CMP DCTRLCHR ;IS CHAR = DOS'S CTRL CHAR?
;************* NOTE ************
;* DOS'S CTRL CHAR CANCELS THE *
;* WRITE MODE.                 *
;*******************************

 BEQ OPUTHDL0 ;YES - SO GO TO CONDITION 0.
 CMP #$8A ;IS CHAR AN <LF>?
 BEQ CMWRTBYT ;YES -GO WRITE IT, STAY IN COND 5
 LDX #4 ;NO -RESET TO CONDITION4 - SIGNAL
 STX OPUTCOND ;WANT TO WRITE ANOTHER LINE.
 BNE OPUTHDL4 ;ALWAYS.




OPUTHDL6 LDA #0 ;SET CONDITION 0.
 STA OPUTCOND
 BEQ DSPLYINP ;ALWAYS.
;GO CONDITIONALLY DISPLAY INPUT.




FINSHRUN LDA #0 ;ZERO OUT THE RUN INTERRUPT FLAG.
 STA RUNTRUPT
 JSR INITIOHK ;RESET I/O HOOKS 2 PT AT DOS.
 JMP RUNFPINT ;JUMP BACK INTO THE RUN COMMAND
;TO FINISH IT OFF.
;************* NOTE *************
;* THE STACK WAS RESET SO WE    *
;* RETURN AT THE CORRECT LEVEL. *
;********************************




FINSHCMD LDA BUF200 ;GET FIRST CHAR IN BUF.
 CMP DCTRLCHR ;WAS CMD DONE VIA DOS'S CTRL CHR?
 BEQ DSPLYCMD ;YES.




 LDA #$8D ;<CR>
 STA BUF200 ;SET 200: 8D.
 LDX #0 ;SET INDEX TO START OF INPUT BUF.
 STX XSAVED




DSPLYCMD LDA #%01000000 ;SET BIT6 TO SEE IF USING "MON C"
 BNE DSPLYCHR ;ALWAYS.
DSPLYOUT LDA #%00010000 ;SET BIT4 TO SEE IF USING "MON O"
 BNE DSPLYCHR ;ALWAYS.
DSPLYINP LDA #%00100000 ;SET BIT5 TO SEE IF USING "MON I"
DSPLYCHR AND CIOCUMUL ;TEST FLAG:  SEE IF SHOULD DSPLY.
 BEQ DOSEXIT ;NO DISPLAY -SPECIFIC BIT WAS OFF
;MON/NOMON CLR/SET SPECIFIC BITS.




DSPLYALL JSR RESTOREG ;RESTORE (A), (Y) & (X) REGS.
 JSR GODSPLY ;OUTPUT  CHR VIA TRU OUTPUT HNDLR
 STA ASAVED ;SAVE (A), (Y) & (X) REGS.
 STY YSAVED
 STX XSAVED




DOSEXIT JSR INITIOHK ;RESET I/O HKS TO POINT TO DOS.
 LDX STKSAVED ;RETRIEVE SAVED STACK POINTER.
 TXS
RESTOREG LDA ASAVED ;RESTORE (A), (Y) & (X) REGS.
 LDY YSAVED
 LDX XSAVED
 SEC ;WHY?????
 RTS ;************ NOTE **************
;* IF THIS RTS IS ENCOUNTERED   *
;* VIA A FALL THRU FROM DOSEXIT,*
;* THEN RTN TO THE ROUTINE THAT *
;* CALLED THE ROUTINE THAT      *
;* CONTAINED THE "JSR PREP4DOS" *
;* INSTRUCTION.                 *
;********************************




GODSPLY JMP (CSW) ;USUALLY POINTS 2 THE TRUE OUTPUT
;HANDLER (COUT1, $FDF0 IF SCRN).
CRVIADOS LDA #$8D ;<CR>.
 JMP GODSPLY ;USUALLY PRINTS A <CR> THRU THE
;OUTPUT HANDLER (COUT1). HOWEVER,
;WHEN ACCESSED BY RUNFPINT($A4DC)
;DURING A COLDSTART, GOES INTO
;DOS'S OUTPUT INTERCEPT ROUTINE
;(OPUTINCP, $9EBD).




PARSECMD LDY #$FF ;INITIALIZE INDEX TO CMD TXT TBL.
 STY NDX2CMD
 INY ;(Y) = 0.
 STY NEXTCMD ;SIGNAL NO PENDING COMMAND FOR
;NEXT TIME AROUND.
GETCHR1 INC NDX2CMD ;INDEX TO COMMAND TEXT TABLE.
;(0 ON ENTRY.)
 LDX #0 ;INITIALIZE INDEX TO INPUT CHARS.
 PHP ;SAVE STATUS (WITH Z=1) ON STK.
;(DFLT STATUS, ASSUME CHRS MTCH.)
 LDA BUF200,X ;GET FIRST CHAR IN INPUT BUFFER.
 CMP DCTRLCHR ;IF IT IS NOT DOS'S CTRL CHAR,
 BNE SAVLINDX ;SET LINE INDEX TO 0.  IF IT IS
 INX ;DOS'S CTRL CHAR, SET INDEX TO 1
;SO SKIP CTRL CHAR.



SAVLINDX STX NDX2INBF ;SAVE INDEX TO INPUT BUF.
INVSCMD JSR PURGECMD ;GET CHAR FROM INPUT BUFFER
;(IGNORE SPACES).
 AND #$7F ;STRIP HI BIT OFF OF CHAR.
 EOR CMDTXTBL,Y ;DOES INPUT CHAR MATCH A CMD CHR?
;IF POS INPUT CHAR/POS ASCII CMD
;CHAR MATCH, THEN (A) = 0.
;IF POS INPUT CHR / NEG ASCII CMD
;CHAR MATCH, THEN (A) = $80.
 INY ;KICK UP INDEX TO NEXT CHAR IN
;THE COMMAND TEXT TABLE.
 ASL ;IF POS/POS MATCH (A)=0 & (C)=0.
;IF POS/NEG MTCH (A)=$80 & (C)=1.
 BEQ CKIFCHRS ;CHAR MATCHED SO GO CHK CARRY.



 PLA ;PULL SAVED STATUS OFF STK TO CLR
;Z-FLG (CAUSE IF SAVED STATUS
;HAD (Z) OR (C) = 1, THEN NEW (A)
;WILL HAVE AT LEAST 1 BIT SET SO
;THEN (A) < > 0.)
 PHP ;PUSH STATUS ON STK (WITH Z-FLAG
;CLR & (C) CONDITIONED AS PER
;ABOVE "ASL" INSTRUCTION.



CKIFCHRS BCC INVSCMD ;IF (C)=0, MORE CHARS TO CHK IN
;GIVEN CMD LISTED IN TABLE.
;IF (C)=1, CHKD LAST CHR IN TBL.



 PLP ;GET STATUS OFF STACK.



 BEQ PRPDOCMD ;IF LAST CHR MATCHED, THEN ENTIRE
;CMD MATCHED SO GO PROCESS CMD.



 LDA CMDTXTBL,Y ;LAST CHAR DIDN'T MATCH, SO NOT
 BNE GETCHR1 ;CORRECT CMD.  THERE4, GO CHK IF
;NEXT CHAR BYTE IN TABLE IS $00.
;IF NOT $00, GO CHK REMAINING
;CMDS IN TBL.  IF IT IS $00, THEN
;DONE ENTIRE TBL & NO CMDS MTCHD.





CKIFCTRL LDA BUF200 ;IS 1RST CHAR IN THE INPUT BUFFER
 CMP DCTRLCHR ;EQUAL TO DOS'S CTRL CHAR?
 BEQ CHKIFCR ;YES.
 JMP DSPLYALL ;NO -GO DSPLY CHR & THEN XIT DOS.



CHKIFCR LDA BUF200+1 ;GET 2ND BYTE IN INPUT BUFFER.
 CMP #$8D ;WAS IT A <CR>?
 BNE PRSYNERR ;NO -NOT SIMPLY DEALING WITH CMD
;CANCELLING DOS CTRL CHR AND <CR>
;SO GO ISSUE A SYNTAX-ERROR MSG.
 JSR RESTAT0 ;YES - SET CONDITION 0.
 JMP DSPLYCMD ;GO DISPLAY <CR>.
PRSYNERR JMP SYNTXERR ;EITHER A CTRL CHR DENOTED THAT A
;DOS CMD WAS WANTED & NO MATCHING
;CMD WAS FOUND (ELSE DETECTED A
;BSAVE CMD WITH NO A- OR L-PARMS)
;SO GO GIVE DOS'S SYNTAX ERR MSG.




PRPDOCMD ASL NDX2CMD ;DOUBLE INDEX CAUSE 2 BYTES/ADDR
 LDY NDX2CMD ;IN TABLE OF DOS CMD ENTRY PTS.
 JSR CKBSCRUN ;CHECK IF BASIC IS RUNNING A PGM:
 BCC CHKIFRUN ;       (C)=0= BASIC RUNNING.
;       (C)=1= BASIC NOT RUNNING.



IMMED LDA #%00000010 ;CHK BIT1 OF CMDATTRB TO SEE IF
 AND CMDATTRB,Y ;CMD IS LEGAL IN THAT MODE.
 BEQ CHKIFRUN ;BRANCH IF LEGAL.
NODIRCMD LDA #15 ;SET RETURN CODE TO SIGNAL THAT
 JMP ERRHNDLR ;WE GOT A NOT-DIRECT-COMMAND ERR.



CHKIFRUN CPY #6 ;CHECK TO SEE IF CMD WAS A "RUN".
 BNE TST4NAME ;BRANCH IF NOT.
 STY PROMPT ;PUT AN $06 IN PROMPT IF COMMAND
;WAS A "RUN".



TST4NAME LDA #%00100000 ;BIT5 = 1 IF FILENAME APPLICABLE.
 AND CMDATTRB,Y
 BEQ FNOTAPPL ;BRANCH IF NAME NOT APPLICABLE.
;(EX. CMDS: CATALOG, PR#, IN#,
;MON, NOMON, MAXFILES, FP & INT.)



FNXPCTD JSR BLNKFNBF ;BLANK BOTH 1RST & 2ND NAME BUFS.
 PHP ;SAVE STATUS (Z-FLAG=1) ON STK.
;NOTE:  Z-FLAG USED TO SIGNAL IF
;       DEALING WITH PRIMARY OR
;       SECONDARY NAME BUFFERS.
FNAMCHR1 JSR PURGECMD ;GET 1RST CHAR IN NAME. (IGNORE
;LEADING SPACES.)
 BEQ DONEFN ;GOT "," OR <CR> - CHK IF DONE
;(CAUSE THESE NOT LEGAL 4 NAME).



 ASL ;(C) = HI BIT OF CHAR.
 BCC LGLFNCHR ;IF INV OR FLSH, OK FOR NAME.
;BUT, NOTE THAT THEY CAN ONLY BE
;POKED INTO INPUT BUF FROM A
;RUNNING PRGM. (THIS TECHNIQUE IS
;USED IN MANY PROTECT'N SCHEMES.)
 BMI LGLFNCHR ;ACTUALLY TESTING BIT6 CAUSE JUST
;DID AN "ASL".IF BYTE IS 11XXXXXX
;(IE. $C0, NORMAL "@" OR GREATER)
;CHAR IS LEGAL FOR NAME.
 JMP CKIFCTRL ;GOT ILLEGAL NAME CHAR SO GO DO A
;FEW MORE CHKS ON CTRL CHRS, ETC
;& EXIT DOS. (WAS IT A CTRL CHAR,
;NUMBER OR ONE OF THE FOLLOWING
;NORMAL CHARS:SPC, !, ", #, $, %,
;&, ', (, ), *, +, COMMA, -, ., /
;:, ;, <, -, >, OR ?



LGLFNCHR ROR ;RESTORE NAME CHAR.
 JMP SVFNCHAR ;SAVE IT IN 1RST OR 2ND NAME BUF.



NCHR2ETC JSR CMDCHAR ;GET 2ND & SUB'QUENT CHRS IN NAME
 BEQ DONEFN ;GOT A <CR> OR "," SO GO CHK IF
;JUST FINISHED SECOND FILENAME.



SVFNCHAR STA PRIMFNBF,Y ;(Y)=OFFSET FRM PRIMARY NAME BUF.
 INY
 CPY #60 ;TOTAL OF 60 CHARS IN BOTH BUFS.
 BCC NCHR2ETC ;HAVEN'T HIT ",", EOL MARKER (IE.
;<CR>) OR DONE ALL 60 CHARS YET.



PURGEFN JSR CMDCHAR ;GET NEXT CHAR.
 BNE PURGEFN ;NOT $00 YET SO GO GET NXT CHAR.



DONEFN PLP ;RETRIEVE STATUS FROM STACK.
 BNE CKFN2LGL ;Z-FLAG CLR SO DONE 2ND FILENAME.



FINFIRST LDY NDX2CMD ;GET INDEX ASSOC WITH CMD ISSUED.
 LDA #%00010000 ;CHK BIT 4 OF CMDATTRB TO SEE IF
  AND CMDATTRB,Y ;2ND NAME REQUIRED (IE RENAME ?).
 BEQ CKFN1LGL ;2ND NAME NOT APPLICABLE SO GO
;& CHK 1RST NAME BUF.



 LDY #30 ;(Y) = INDEX 2 START OF 2ND NAME.
 PHP ;PUT STATUS ON STK (Z-FLG = 0) TO
 BNE FNAMCHR1 ;SIGNAL DEALING WITH 2ND NAME &
;GO BACK TO GET ITS CHARS.
;ALWAYS TAKE BRANCH.



CKFN2LGL LDA SCNDFNBF ;CHK 1RST BYTE IN SECONDARY.
 CMP #" "   ;IF IT IS A <SPC>, THEN NO CHARS
 BEQ GOXITDOS ;WERE GOOD & SO A 2ND NAME WAS
;REQUIRED BUT NOT ISSUED,SO EXIT.



CKFN1LGL LDA PRIMFNBF ;IF 1RST CHAR IN BUF IS A <SPC>,
 CMP #" "  ;A LEGAL PRIMARY FILENAME WAS NOT
;ISSUED SO FALL THRU TO SEE IF IT
;WAS REQUIRED OR OPTIONAL.
 BNE DFLTPRSD ;BRANCH IF GOT PRIMARY FILENAME.



 LDY NDX2CMD ;GET INDEX ASSOC WITH CMD.
 LDA #%11000000 ;CHK BITS 7 & 6 TO SEE IF A NAME
 AND CMDATTRB,Y ;IS REQUIRED.
 BEQ GOXITDOS ;A PRIMARY NAME IS REQUIRED BUT
;WAS NOT ISSUED, SO GO EXIT DOS.



 BPL DFLTPRSD ;NAME WASN'T PRESENT, BUT IS NO
;BIG DEAL CAUSE IT WAS OPTIONAL.
GOXITDOS JMP CKIFCTRL ;CMD WAS LOAD, RUN OR SAVE WHICH
;CAN ALSO BE BASIC COMMANDS.




BLNKFNBF LDY #60 ;30 BYTES IN EACH BUFFER.
BLNK1RST LDA #" " ;BLANK.
STORBLNK STA PRIMFNBF-1,Y
 DEY
 BNE STORBLNK ;MORE BYTES TO BLANK OUT.
 RTS




FNOTAPPL STA PRIMFNBF ;PUT A $00 IN THE FIRST BYTE OF
;THE PRIMARY FILENAME BUFFER.
;************* NOTE *************
;* ALTHOUGH THIS SEEMS LIKE A   *
;* BEGNIN INSTRUCTION, IT IS    *
;* IMPORTANT BECAUSE IT IS LATER*
;* USED 2 INSURE THAT A MATCHING*
;* DOS FILENAME BUF WON'T BE    *
;* FOUND WHEN THE GETBUFF ROUT'N*
;* ($A764) IS EVENTUALLY USED BY*
;* THE VARIOUS DOS CMDS.  AS A  *
;* RESULT, THE HIGHEST NUMBERED *
;* (LOWEST IN MEMORY) FREE DOS  *
;* FILENAME BUFFER WILL BE      *
;* SELECTED.                    *
;********************************



 LDA #%00001100 ;TEST BITS 2 & 3 TO SEE IF IN#,
 AND CMDATTRB,Y ;PR# OR MAXFILES NUMERIC
;OPERAND IS EXPECTED.
 BEQ DFLTPRSD ;BRANCH IF NOT EXPECTED.



INPRMAX JSR CNVRTASC ;CONVERT ASCII NUMBER ARGUMENT TO
;HEX WITH RESULT IN A5L/H.
 BCS TOSYNTX ;CHR NOT #, EXIT WITH SYNTAX ERR.
 TAY  ;(Y) = HI BYTE OF CONVERTED CHAR.
 BNE ARGRNGER ;RANGE ERROR - CAUSE VALUE > 255.
 CPX #17
 BCS ARGRNGER ;RANGE ERROR CAUSE IF MAXFILES OR
;IN# OR PR# ARGUMENT > 16, THEN
;VALUE TOO LARGE.



 LDY NDX2CMD ;CHK TO SEE IF A SLOT VALUE IS
 LDA #%00001000 ;APPLICABLE TO THE COMMAND.
 AND CMDATTRB,Y
 BEQ MAXFMIN ;SLOT VAL NOT APPLICABLE SO MUST
;BE DEALING WITH MAXFILES.



 CPX #8 ;TOO LARGE?
 BCS GOXITDOS ;YES -BAIL OUT.
 BCC DFLTPRSD ;NO -SET DFLTS & CONTINUE PARSING



MAXFMIN TXA
 BNE DFLTPRSD ;NOT 0, SO OKAY.



ARGRNGER LDA #2 ;SET RETURN CODE FOR RANGE ERROR.
 JMP ERRHNDLR ;GO HANDLE THE ERROR.

TOSYNTX JMP SYNTXERR ;EXIT VIA SYNTAX ERROR.



DFLTPRSD LDA #0
 STA CUMLOPTN ;SET CUMLOPTN TO DEFAULT VAL OF 0
;TO ASSUME NO OPTIONS ISSUED.
 STA MONPRSD ;SET DEFAULT VALS IN PARSED TBL.
 STA VOLPRSD ;THAT IS ASSUME THAT:
 STA LENPRSD  ;    - C, I, O WEREN'T ISSUED.
 STA LENPRSD+1 ;    - VOL # AND LENGTH ARE 0.
 JSR ZEROPTCH ;SET TEMPBYT & BYTPRSD TO 0 DFLTS
 LDA NDX2INBF ;IRREL, MIGHT AS WELL BE 3 "NOP"S
;(MADE OBSOLETE BY ZEROPTCH).



NXCMDCHR JSR PURGECMD ;GET NEXT CHAR.
 BNE CHKOPTNS ;IF IT ISN'T A <CR> OR COMMA THEN
;MAYBE ITS AN OPTION, SO TAKE
;BRANCH TO CHECK IT OUT.
 CMP #$8D ;WAS IT A <CR>?
 BNE NXCMDCHR ;NO - SO MUST HAVE BEEN A COMMA.
;BRANCH BACK TO IGNORE COMMAS.



 LDX NDX2CMD
 LDA CUMLOPTN ;CHK IF OPTIONS ARE LEGAL.
 ORA CMDATTRB+1,X
 EOR CMDATTRB+1,X
 BNE GOXITDOS ;ILLEGAL SO EXIT.



 LDX TEMPBYT ;TEMPBYT = 0 AS SET IN ZEROPTCH.
 BEQ TODOSCMD ;ALWAYS.



 STA TEMPBYT
 STX NDX2INBF
 BNE NXCMDCHR



CHKOPTNS LDX #10
CKNXOPTN CMP OPTNTXT-1,X
 BEQ OPTNOK ;FOUND AN OPTION.
 DEX
 BNE CKNXOPTN ;HAVEN'T CHKD ALL OPTIONS YET.

TOTOSYNT BEQ TOSYNTX ;COULDN'T FIND A MATCH.
;(SYNTAX ERR - CHAR NOT OPTION.)



OPTNOK LDA OPTNISSD-1,X
 BMI CIOPTNS ;IF HI BIT=0, THEN OPTION WAS A
;"C", "I" OR "O" AND NO NUMERIC
;ARGUMENT IS NEEDED.



 ORA CUMLOPTN
 STA CUMLOPTN



 DEX ;REDUCE COUNTER THAT WAS KICKED UP
;IN ANTICIPATION OF MORE CHARS
;IN THE CMDCHAR ROUTINE.
 STX NDX2OPTN ;SAVE INDEX TO OPTION.
 JSR CNVRTASC ;CONVERT ASCII # TO HEX.



 BCS TOSYNTX ;NO - SYNTAX ERROR.



 LDA NDX2OPTN ;RETRIEVE INDEX TO OPTION.
 ASL ;TIMES 4 CAUSE GOING TO CHK MIN
 ASL ;& MAX VALS OF LEGAL RANGES ASSOC
;WITH OPTION (2 BYTES @).
 TAY ;(Y) = INDEX TO LEGAL RANGE TBL.



 LDA A5L+1 ;GET HI BYTE OF ARGUMENT.
 BNE CKMAXVAL ;BRANCH IF NOT 0.
 LDA A5L ;HI BYTE WAS 0 SO CHK LOW BYTE.
 CMP OPTNRNG,Y
 BCC ARGRNGER ;RANGE ERR -ARGUMENT < MIN LEGAL.



 LDA A5L+1
CKMAXVAL CMP OPTNRNG+3,Y ;CMP HI BYTE TO MAX LEGAL VAL.
 BCC SVALOPTN ;LESS THAN MAX SO ARGUMENT OK.
TOARGRNG BNE ARGRNGER ;ARGUMENT > MAX LGL, SO RNG ERR.
 LDA A5L ;NOW CHK IF LOW BYTE OF ARGUMENT
 CMP OPTNRNG+2,Y ;COMPLIES TO MAX LEGAL LOW BYTE.
 BCC SVALOPTN ;ARGUMENT IS LEGAL.
 BNE TOARGRNG ;ARGUMENT IS ILLEGAL.



SVALOPTN LDA TEMPBYT ;OBSOLETE, TEMPBYT WAS SET TO 0
 BNE NXCMDCHR ;IN ZEROPTCH SO ALWAYS FALL THRU.
 TYA ;(Y)-->(A)=INDEX TO OPTION RNGS.
 LSR ;DIVIDE BY 2 CAUSE @ OPTION RANGE
;TABLE HAS 4 BYTES, BUT @ PARSED
;VAL ENTRY IS ONLY 2 BYTES LONG.
 TAY ;PUT INDEX 2 PARSED TABLE IN (Y).
 LDA A5L+1 ;STORE ARGUMENT IN PARSED TBL.
 STA VOLPRSD+1,Y
 LDA A5L
 STA VOLPRSD,Y



TONXOPTN JMP NXCMDCHR



CIOPTNS PHA ;PUT (A) = OPTNISSD ON STK.
 LDA #%10000000 ;UPDATE CUMLOPTN TO SIGNAL THAT
 ORA CUMLOPTN ;"C", "I" OR "O" OPTIONS ISSUED.
 STA CUMLOPTN
 PLA ;GET (A) = OPTNISSD BACK FRM STK.
 AND #%01111111 ;TURN HI BIT OFF.
 ORA MONPRSD ;UPDATE MONPRSD IN PARSED TABLE.
 STA MONPRSD
 BNE TONXOPTN ;GO SEE IF ANY MORE OPTIONS.
 BEQ TOTOSYNT ;IRRELEVANT.




TODOSCMD JSR DODOSCMD ;GO DO THE DOS COMMAND.




AFTRCMD JMP FINSHCMD





DODOSCMD JSR RESTAT0 ;RESET CONDITION TO 0.  THAT IS,
;SET CONDNFLG AND OPUTCOND = 0.
 JSR CLRFMPRM ;CLEAR OUT THE FM PARAMETER LIST
;SO WE CAN CUSTOMIZE IT IN
;ACCORDANCE WITH THE SPECIFIC DOS
;COMMAND HANDLER CALLED.
 LDA NDX2CMD ;GET (A) = INDEX TO COMMAND.
 TAX ;(X) = INDEX 2 TBL OF ENTRY PTS.
 LDA CMDTBL+1,X ;GET ADR-1 OF THE CMD'S ROUTINE &
 PHA ;PUT IT ON STACK (HI BYTE 1RST).
 LDA CMDTBL,X
 PHA
 RTS ;DO A "STK JMP" TO PROCESS CMD.




CMDCHAR LDX NDX2INBF ;(X) = INDEX TO INPUT BUFFER.
 LDA BUF200,X ;GET NEXT CHAR.
 CMP #$8D ;IS IT A <CR>?
 BEQ CMDCHRTS ;YES.
 INX  ;(X)=INDEX 4 NXT ANTICIPATED CHR.
 STX NDX2INBF
 CMP #"," ;COMMA?
CMDCHRTS RTS ;EXIT WITH Z-FLAG CONDITIONED.
;Z=1 IF CHAR IS A <CR> OR COMMA.




PURGECMD JSR CMDCHAR ;GET 1RST CHAR.
 BEQ CMDCHRTS ;EXIT IF <CR> OR COMMA.
 CMP #" " ;SPACE?
 BEQ PURGECMD ;YES - IGNORE LEADING SPACES.
 RTS




CLRFMPRM LDA #0
 LDY #$16 ;22 BYTES TO ZERO OUT.
ZFMPARM STA FMPRMLST-1,Y ;STORE ZERO BYTE.
 DEY ;$16 --> $01, EXIT AT $00.
 BNE ZFMPARM
 RTS




CNVRTASC LDA #0 ;ZERO OUT LOC'S TO HOLD RESULT.
 STA A5L ;LOW BYTE OF RESULT.
 STA A5L+1 ;HI BYTE OF RESULT.
 JSR PURGECMD ;GET 1RST NON-SPACE CHAR.
 PHP  ;SAVE STATUS (Z-FLAG) ON STK.
;(IF <CR> OR COMMA, Z-FLAG = 1.)



 CMP #"$" ;IS HEX SYMBOL PRESENT?
 BEQ ASC2HEX ;YES - BRANCH FOR ASCII TO HEX.




 PLP  ;GET STATUS DENOTING IF CR OR ","
 JMP CKIFDONE ;BEGIN DEC CONVERSION OF 1RST CHR

ASC2DEC JSR PURGECMD ;GET 2ND & SUBSEQUENT ASCII CHARS
;TO BE CONVERTED TO DECIMAL.
;(IGNORE SPACES.)

CKIFDONE BNE SUBTRASC ;BRANCH IF NOT <CR> OR COMMA.
;(ALWAYS FALL THRU IF ACCESSED FRM
;THE HEX CONVERSION ROUTINE.)



 LDX A5L ;RESULT LOW.
 LDA A5L+1 ;RESULT HI.
 CLC ;(C)=0 TO SIGNAL GOOD CONVERSION.
 RTS ;EXIT TO CALLER OF CNVRTASC.



SUBTRASC SEC
 SBC #$B0 ;SUBTRACT ASCII "0".
 BMI NOTASCII ;ERROR CAUSE < 0.
 CMP #$0A ;DECIMAL 10.
 BCS NOTASCII ;ERROR CAUSE > 9.



 JSR DOUBLE ;GET RESULT * 2.
 ADC A5L
 TAX ;(X) = LOW RESULT * 2 + NEW DIGIT
 LDA #0
 ADC A5L+1 ;ADD (C) TO HI BYTE OF RESULT.
 TAY ;(Y) = HI BYTE OF RESULT*2 + (C).
 JSR DOUBLE ;(A) = RESULT * 8.
 JSR DOUBLE
 TXA
 ADC A5L
 STA A5L ;(RESULT*2+NEW DIGIT)+(RESULT*8).
 TYA
 ADC A5L+1 ;ADD (C) TO UPDATE HI BYTE.
 STA A5L+1
 BCC ASC2DEC ;BRANCH IF # <65536.



NOTASCII SEC ;EXIT WITH (C)=1 TO SIGNAL ERROR.
 RTS ;RETURN TO CALLER OF CNVRTASC.



DOUBLE ASL A5L ;"ROLL" HI & LOW BYTES AS A UNIT.
 ROL A5L+1 ;(PICK UP (C) IN HI BYTE.)
 RTS




ASC2HEX PLP ;THROW SAVED STATUS OFF STACK.
GETASCII JSR PURGECMD ;GET 1RST & SUBSEQUENT CHARS THAT
;OCCUR AFTER THE HEX ("$") SYMBOL
 BEQ CKIFDONE ;GO EXIT IF <CR> OR COMMA.



 SEC
 SBC #$B0 ;SUBTRACT ASCII "0".
 BMI NOTASCII ;ERROR CAUSE < 0.
 CMP #$0A
 BCC PRP2DUBL ;VALID: 0 <--> 9.
 SBC #7 ;CHK HI RANGE OF HEX #'S.
 BMI NOTASCII ;ERROR CAUSE > $09 AND < $0A.
 CMP #$10
 BCS NOTASCII ;ERROR CAUSE > $0F.



PRP2DUBL LDX #4 ;(X) = # OF TIMES TO DOUBLE UNIT.
TIMES2 JSR DOUBLE ;MULTIPLY RESULT * 2.
 DEX
 BNE TIMES2 ;MORE MULTIPLICATION TO DO.



 ORA A5L
 STA A5L
 JMP GETASCII ;GO GET NEXT CHAR TO CONVERT.






CMDPR LDA A5L ;GET SLOT NUMBER.
 JMP OUTPORT ;USE MONITOR ROM 2 SET OUTPUT HK.
;RTN 2 THE CALLER OF THE PR# CMD.
;(OFTEN RETURNS 2 AFTRCMD ($A17D)
;ASSOCIATED WITH THE COMMAND
;PARSING & PROCESSING ROUTINES.)






CMDIN LDA A5L ;GET SLOT NUMBER.
 JMP INPORT ;USE MONITOR ROM TO SET INPUT HK.
;RTN 2 THE CALLER OF THE IN# CMD.
;(OFTEN RETURNS 2 AFTRCMD ($A17D)
;ASSOCIATED WITH THE COMMAND
;PARSING & PROCESSING ROUTINES.)
{