add support for XDOS command lines
This commit is contained in:
@@ -50,4 +50,4 @@ done: rts
|
||||
|
||||
.data
|
||||
|
||||
__dos_type: .byte 0 ; default to ATARIDOS
|
||||
__dos_type: .byte ATARIDOS; default to ATARIDOS
|
||||
|
||||
@@ -7,6 +7,8 @@
|
||||
; startup code but is nevertheless included in the compiled program when
|
||||
; needed.
|
||||
|
||||
; XDOS support added 05/2016 by Christian Groessler
|
||||
|
||||
MAXARGS = 16 ; max. amount of arguments in arg. table
|
||||
CL_SIZE = 64 ; command line buffer size
|
||||
SPACE = 32 ; SPACE char.
|
||||
@@ -22,22 +24,30 @@ SPACE = 32 ; SPACE char.
|
||||
|
||||
.segment "ONCE"
|
||||
|
||||
nargdos:rts
|
||||
|
||||
initmainargs:
|
||||
lda __dos_type ; which DOS?
|
||||
cmp #ATARIDOS
|
||||
beq nargdos ; DOS does not support arguments
|
||||
cmp #MYDOS
|
||||
bne argdos ; DOS supports arguments
|
||||
nargdos:rts
|
||||
cmp #MAX_DOS_WITH_CMDLINE + 1
|
||||
bcs nargdos
|
||||
|
||||
; Initialize ourcl buffer
|
||||
|
||||
argdos: lda #ATEOL
|
||||
sta ourcl+CL_SIZE
|
||||
argdos: ldy #ATEOL
|
||||
sty ourcl+CL_SIZE
|
||||
|
||||
; Move SpartaDOS command line to our own buffer
|
||||
; Move SpartaDOS/XDOS command line to our own buffer
|
||||
|
||||
lda DOSVEC
|
||||
cmp #XDOS
|
||||
bne sparta
|
||||
|
||||
lda #<XLINE
|
||||
sta ptr1
|
||||
lda #>XLINE
|
||||
sta ptr1+1
|
||||
bne cpcl0
|
||||
|
||||
sparta: lda DOSVEC
|
||||
clc
|
||||
adc #<LBUF
|
||||
sta ptr1
|
||||
@@ -45,7 +55,7 @@ argdos: lda #ATEOL
|
||||
adc #>LBUF
|
||||
sta ptr1+1
|
||||
|
||||
ldy #0
|
||||
cpcl0: ldy #0
|
||||
cpcl: lda (ptr1),y
|
||||
sta ourcl,y
|
||||
iny
|
||||
|
||||
Reference in New Issue
Block a user