You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

162 lines
3.7 KiB

;
; tty_dochar - added setup in HL of position data before call to write
;==================================================================================================
; TTY EMULATION MODULE
;==================================================================================================
;
; TODO:
; - SOME FUNCTIONS ARE NOT IMPLEMENTED!!!
;
TTY_INIT:
PRTS("TTY: RESET$")
;
JR TTY_INI ; REUSE THE INI FUNCTION BELOW
;
;
;
TTY_DISPATCH:
LD A,B ; GET REQUESTED FUNCTION
AND $0F ; ISOLATE SUB-FUNCTION
JR Z,TTY_IN ; $30
DEC A
JR Z,TTY_OUT ; $31
DEC A
JR Z,TTY_IST ; $32
DEC A
JR Z,TTY_OST ; $33
DEC A
JR Z,TTY_CFG ; $34
CP 8
JR Z,TTY_INI ; $38
CP 9
JR Z,TTY_QRY ; $39
CALL PANIC
;
;
;
TTY_IN:
LD B,BF_VDAKRD ; SET FUNCTION TO KEYBOARD READ
JP EMU_VDADISP ; CHAIN TO VDA DISPATCHER
;
;
;
TTY_OUT:
CALL TTY_DOCHAR ; HANDLE THE CHARACTER (EMULATION ENGINE)
XOR A ; SIGNAL SUCCESS
RET
;
;
;
TTY_IST:
LD B,BF_VDAKST ; SET FUNCTION TO KEYBOARD STATUS
JP EMU_VDADISP ; CHAIN TO VDA DISPATCHER
;
;
;
TTY_OST:
XOR A ; ZERO ACCUM
INC A ; A := $FF TO SIGNAL OUTPUT BUFFER READY
RET
;
;
;
TTY_CFG:
XOR A ; SIGNAL SUCCESS
RET
;
;
;
TTY_INI:
LD B,BF_VDAQRY ; FUNCTION IS QUERY
LD HL,0 ; WE DO NOT WANT A COPY OF THE CHARACTER BITMAP DATA
CALL EMU_VDADISP ; PERFORM THE QUERY FUNCTION
LD (TTY_DIM),DE ; SAVE THE SCREEN DIMENSIONS RETURNED
LD DE,0 ; DE := 0, CURSOR TO HOME POSITION 0,0
LD (TTY_POS),DE ; SAVE CURSOR POSITION
LD B,BF_VDARES ; SET FUNCTION TO RESET
JP EMU_VDADISP ; RESET VDA AND RETURN
;
;
;
TTY_QRY:
XOR A ; SIGNAL SUCCESS
RET
;
;
;
TTY_DOCHAR:
LD A,E ; CHARACTER TO PROCESS
CP 8 ; BACKSPACE
JR Z,TTY_BS
CP 12 ; FORMFEED
JR Z,TTY_FF
CP 13 ; CARRIAGE RETURN
JR Z,TTY_CR
CP 10 ; LINEFEED
JR Z,TTY_LF
CP 32 ; COMPARE TO SPACE (FIRST PRINTABLE CHARACTER)
RET C ; SWALLOW OTHER CONTROL CHARACTERS
LD B,BF_VDAWRC
CALL EMU_VDADISP ; SPIT OUT THE RAW CHARACTER
LD A,(TTY_COL) ; GET CUR COL
INC A ; INCREMENT
LD (TTY_COL),A ; SAVE IT
LD DE,(TTY_DIM) ; GET SCREEN DIMENSIONS
CP E ; COMPARE TO COLS IN LINE
RET C ; NOT PAST END OF LINE, ALL DONE
CALL TTY_CR ; CARRIAGE RETURN
JR TTY_LF ; LINEFEED AND RETURN
;
TTY_FF:
LD DE,0 ; PREPARE TO HOME CURSOR
LD (TTY_POS),DE ; SAVE NEW CURSOR POSITION
CALL TTY_XY ; EXECUTE
LD DE,(TTY_DIM) ; GET SCREEN DIMENSIONS
LD H,D ; SET UP TO MULTIPLY ROWS BY COLS
CALL MULT8 ; HL := H * E TO GET TOTAL SCREEN POSITIONS
LD E,' ' ; FILL SCREEN WITH BLANKS
LD B,BF_VDAFIL ; SET FUNCTION TO FILL
CALL EMU_VDADISP ; PERFORM FILL
JR TTY_XY ; HOME CURSOR AND RETURN
;
TTY_BS:
LD A,(TTY_COL) ; GET CURRENT COLUMN
DEC A ; BACK IT UP BY ONE
RET C ; IF CARRY, MARGIN EXCEEDED, ABORT
LD (TTY_COL),A ; SAVE NEW COLUMN
JP TTY_XY ; UDPATE CUSROR AND RETURN
;
TTY_CR:
XOR A ; ZERO ACCUM
LD (TTY_COL),A ; COL := 0
JR TTY_XY ; REPOSITION CURSOR AND RETURN
;
TTY_LF: ; LINEFEED (FORWARD INDEX)
LD A,(TTY_ROW) ; GET CURRENT ROW
LD DE,(TTY_DIM) ; GET SCREEN DIMENSIONS
DEC D ; D := MAX ROW NUM
CP D ; >= LAST ROW?
JR NC,TTY_LF1 ; IF SO, NEED TO SCROLL
INC A ; BUMP TO NEXT ROW
LD (TTY_ROW),A ; SAVE IT
JP TTY_XY ; UPDATE CURSOR AND RETURN
;
TTY_LF1: ; SCROLL
LD E,1 ; SCROLL FORWARD 1 LINE
LD B,BF_VDASCR ; SET FUNCTION TO SCROLL
JP EMU_VDADISP ; DO THE SCROLLING AND RETURN
;
TTY_XY:
LD DE,(TTY_POS) ; GET THE DESIRED CURSOR POSITION
LD B,BF_VDASCP ; SET FUNCTIONT TO SET CURSOR POSITION
JP EMU_VDADISP ; REPOSITION CURSOR
;
;
;
TTY_POS:
TTY_COL .DB 0 ; CURRENT COLUMN - 0 BASED
TTY_ROW .DB 0 ; CURRENT ROW - 0 BASED
;
TTY_DIM:
TTY_COLS .DB 80 ; NUMBER OF COLUMNS ON SCREEN
TTY_ROWS .DB 24 ; NUMBER OF ROWS ON SCREEN