;================================ ; move_and_print ;================================ ; get X,Y from OUTL/OUTH ; then print following string to that address ; stop at NUL ; convert to APPLE ASCII (or with 0x80) ; leave OUTL/OUTH pointing to next string move_and_print: ldy #0 lda (OUTL),Y sta CH iny lda (OUTL),Y asl tay lda gr_offsets,Y ; lookup low-res memory address clc adc CH ; add in xpos sta BASL ; store out low byte of addy lda gr_offsets+1,Y ; look up high byte adc DRAW_PAGE ; sta BASH ; and store it out ; BASH:BASL now points at right place clc lda OUTL adc #2 sta OUTL lda OUTH adc #0 sta OUTH ;================================ ; print_string ;================================ print_string: ldy #0 print_string_loop: lda (OUTL),Y beq done_print_string ps_smc1: and #$3f ; make sure we are inverse sta (BASL),Y iny bne print_string_loop done_print_string: iny clc tya adc OUTL sta OUTL lda OUTH adc #0 sta OUTH rts ; set normal text ($80-$ff) set_normal: lda #$80 sta ps_smc1+1 lda #$09 ; ora sta ps_smc1 rts ; restore inverse text ($00-$3f) set_inverse: lda #$29 ; and sta ps_smc1 lda #$3f sta ps_smc1+1 rts ; set flashing text ($40-$7f) set_flash: lda #$40 sta ps_smc1+1 lda #$09 ; ora sta ps_smc1 rts ;================================ ; move and print a list of lines ;================================ ; look for negative X meaning done move_and_print_list: jsr move_and_print ldy #0 lda (OUTL),Y bpl move_and_print_list rts