mirror of
https://github.com/irmen/prog8.git
synced 2025-01-11 13:29:45 +00:00
screen scroll
This commit is contained in:
parent
50db122525
commit
aa2f3dd169
@ -971,16 +971,16 @@ class Parser:
|
|||||||
if r_value.constant:
|
if r_value.constant:
|
||||||
if operator == "+=":
|
if operator == "+=":
|
||||||
if r_value.value > 0: # type: ignore
|
if r_value.value > 0: # type: ignore
|
||||||
return InplaceIncrStmt(l_value, r_value.value, self.sourceref) # type: ignore
|
return InplaceIncrStmt(l_value, r_value.value, None, self.sourceref)
|
||||||
elif r_value.value < 0: # type: ignore
|
elif r_value.value < 0: # type: ignore
|
||||||
return InplaceDecrStmt(l_value, -r_value.value, self.sourceref) # type: ignore
|
return InplaceDecrStmt(l_value, -r_value.value, None, self.sourceref)
|
||||||
else:
|
else:
|
||||||
self.print_warning("incr with zero, ignored")
|
self.print_warning("incr with zero, ignored")
|
||||||
else:
|
else:
|
||||||
if r_value.value > 0: # type: ignore
|
if r_value.value > 0: # type: ignore
|
||||||
return InplaceDecrStmt(l_value, r_value.value, self.sourceref) # type: ignore
|
return InplaceDecrStmt(l_value, r_value.value, None, self.sourceref)
|
||||||
elif r_value.value < 0: # type: ignore
|
elif r_value.value < 0: # type: ignore
|
||||||
return InplaceIncrStmt(l_value, -r_value.value, self.sourceref) # type: ignore
|
return InplaceIncrStmt(l_value, -r_value.value, None, self.sourceref)
|
||||||
else:
|
else:
|
||||||
self.print_warning("decr with zero, ignored")
|
self.print_warning("decr with zero, ignored")
|
||||||
else:
|
else:
|
||||||
@ -1230,8 +1230,8 @@ class Parser:
|
|||||||
if len(value) == 1:
|
if len(value) == 1:
|
||||||
return True, char_to_bytevalue(value)
|
return True, char_to_bytevalue(value)
|
||||||
# if we're an integer value and the passed value is float, truncate it (and give a warning)
|
# if we're an integer value and the passed value is float, truncate it (and give a warning)
|
||||||
if datatype in (DataType.BYTE, DataType.WORD, DataType.MATRIX) and type(value) is float:
|
if datatype in (DataType.BYTE, DataType.WORD, DataType.MATRIX) and isinstance(value, float):
|
||||||
frac = math.modf(value) # type:ignore
|
frac = math.modf(value)
|
||||||
if frac != 0:
|
if frac != 0:
|
||||||
self.print_warning("float value truncated ({} to datatype {})".format(value, datatype.name))
|
self.print_warning("float value truncated ({} to datatype {})".format(value, datatype.name))
|
||||||
return True, int(value)
|
return True, int(value)
|
||||||
|
@ -46,7 +46,7 @@ class PreprocessingParser(Parser):
|
|||||||
return InlineAsm([], self.sourceref)
|
return InlineAsm([], self.sourceref)
|
||||||
|
|
||||||
def parse_statement(self, line: str) -> _AstNode:
|
def parse_statement(self, line: str) -> _AstNode:
|
||||||
return None # type: ignore
|
return None
|
||||||
|
|
||||||
def parse_var_def(self, line: str) -> None:
|
def parse_var_def(self, line: str) -> None:
|
||||||
super().parse_var_def(line)
|
super().parse_var_def(line)
|
||||||
|
586
lib/c64lib.ill
586
lib/c64lib.ill
@ -22,6 +22,9 @@
|
|||||||
|
|
||||||
memory .byte COLOR = $0286 ; cursor color
|
memory .byte COLOR = $0286 ; cursor color
|
||||||
memory .word CINV = $0314 ; IRQ vector
|
memory .word CINV = $0314 ; IRQ vector
|
||||||
|
memory .matrix(40, 25) Screen = $0400 ; default character screen matrix
|
||||||
|
memory .matrix(40, 25) Colors = $d800 ; character screen colors
|
||||||
|
|
||||||
|
|
||||||
; ---- VIC-II registers ----
|
; ---- VIC-II registers ----
|
||||||
|
|
||||||
@ -213,7 +216,7 @@ sub GETIN () -> (A, X?, Y?) = $FFE4 ; (via 810 ($32A)) get a character
|
|||||||
sub CLALL () -> (A?, X?) = $FFE7 ; (via 812 ($32C)) close all files
|
sub CLALL () -> (A?, X?) = $FFE7 ; (via 812 ($32C)) close all files
|
||||||
sub UDTIM () -> (A?, X?) = $FFEA ; update the software clock
|
sub UDTIM () -> (A?, X?) = $FFEA ; update the software clock
|
||||||
sub SCREEN () -> (X, Y) = $FFED ; read number of screen rows and columns
|
sub SCREEN () -> (X, Y) = $FFED ; read number of screen rows and columns
|
||||||
sub PLOT (dir: SC, col: X, row: Y) -> (X, Y) = $FFF0 ; read/set position of cursor on screen
|
sub PLOT (dir: SC, col: Y, row: X) -> (X, Y) = $FFF0 ; read/set position of cursor on screen
|
||||||
sub IOBASE () -> (X, Y) = $FFF3 ; read base address of I/O devices
|
sub IOBASE () -> (X, Y) = $FFF3 ; read base address of I/O devices
|
||||||
|
|
||||||
; ---- end of C64 kernal routines ----
|
; ---- end of C64 kernal routines ----
|
||||||
@ -347,46 +350,577 @@ sub GETADRAY () -> (AY, X?) {
|
|||||||
; ---- this block contains (character) Screen and text I/O related functions ----
|
; ---- this block contains (character) Screen and text I/O related functions ----
|
||||||
|
|
||||||
|
|
||||||
sub clear_screen (char:A, color: Y, screenaddr_hi: X) -> () {
|
sub clear_screen (char:A, color: Y) -> () {
|
||||||
; ---- clear the character screen with the given fill character and character color.
|
; ---- clear the character screen with the given fill character and character color.
|
||||||
; X must be set to the high byte of the current screen display memory address (usually $04, for $0400).
|
; (assumes screen is at $0400, could be altered in the future with self-modifying code)
|
||||||
|
|
||||||
asm {
|
asm {
|
||||||
;ldx #$04 ; high byte of screen addres
|
sta _loop + 1 ; self-modifying
|
||||||
;lda #1 ; fill char
|
stx c64.SCRATCH_ZP1
|
||||||
;ldy #3 ; fill color
|
|
||||||
sta _loop +1 ; self-modify
|
|
||||||
sty _mod_col +1 ; self-modify
|
|
||||||
stx _loop + 4 ; self-modify
|
|
||||||
inx
|
|
||||||
stx _loop + 7 ; self-modify
|
|
||||||
inx
|
|
||||||
stx _loop + 10 ; self-modify
|
|
||||||
stx _loop + 13 ; self-modify
|
|
||||||
|
|
||||||
|
|
||||||
ldx #0
|
ldx #0
|
||||||
_loop lda #0
|
_loop lda #0
|
||||||
sta $8400,x ; screen address will be modified
|
sta c64.Screen,x
|
||||||
sta $8500,x
|
sta c64.Screen+$0100,x
|
||||||
sta $8600,x
|
sta c64.Screen+$0200,x
|
||||||
sta $86e8,x
|
sta c64.Screen+$02e8,x
|
||||||
_mod_col lda #0
|
tya
|
||||||
sta $d800,x ; color address is fixed
|
sta c64.Colors,x
|
||||||
sta $d900,x
|
sta c64.Colors+$0100,x
|
||||||
sta $da00,x
|
sta c64.Colors+$0200,x
|
||||||
sta $dae8,x
|
sta c64.Colors+$02e8,x
|
||||||
inx
|
inx
|
||||||
bne _loop
|
bne _loop
|
||||||
|
|
||||||
lda _loop+1 ; restore A and X
|
lda _loop+1 ; restore A and X
|
||||||
ldx _loop+4
|
ldx c64.SCRATCH_ZP1
|
||||||
rts
|
rts
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sub scroll_left_full (alsocolors: SC) -> (A?, X?, Y?) {
|
||||||
|
; ---- scroll the whole screen 1 character to the left
|
||||||
|
; contents of the rightmost column are unchanged, you should clear/refill this yourself
|
||||||
|
; Carry flag determines if screen color data should be scrolled too
|
||||||
|
asm {
|
||||||
|
bcs +
|
||||||
|
jmp _scroll_screen
|
||||||
|
|
||||||
|
+
|
||||||
|
ldx #0
|
||||||
|
ldy #38
|
||||||
|
-
|
||||||
|
lda c64.Colors + 40*0 + 1,x
|
||||||
|
sta c64.Colors + 40*0,x
|
||||||
|
lda c64.Colors + 40*1 + 1,x
|
||||||
|
sta c64.Colors + 40*1,x
|
||||||
|
lda c64.Colors + 40*2 + 1,x
|
||||||
|
sta c64.Colors + 40*2,x
|
||||||
|
lda c64.Colors + 40*3 + 1,x
|
||||||
|
sta c64.Colors + 40*3,x
|
||||||
|
lda c64.Colors + 40*4 + 1,x
|
||||||
|
sta c64.Colors + 40*4,x
|
||||||
|
lda c64.Colors + 40*5 + 1,x
|
||||||
|
sta c64.Colors + 40*5,x
|
||||||
|
lda c64.Colors + 40*6 + 1,x
|
||||||
|
sta c64.Colors + 40*6,x
|
||||||
|
lda c64.Colors + 40*7 + 1,x
|
||||||
|
sta c64.Colors + 40*7,x
|
||||||
|
lda c64.Colors + 40*8 + 1,x
|
||||||
|
sta c64.Colors + 40*8,x
|
||||||
|
lda c64.Colors + 40*9 + 1,x
|
||||||
|
sta c64.Colors + 40*9,x
|
||||||
|
lda c64.Colors + 40*10 + 1,x
|
||||||
|
sta c64.Colors + 40*10,x
|
||||||
|
lda c64.Colors + 40*11 + 1,x
|
||||||
|
sta c64.Colors + 40*11,x
|
||||||
|
lda c64.Colors + 40*12 + 1,x
|
||||||
|
sta c64.Colors + 40*12,x
|
||||||
|
inx
|
||||||
|
dey
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
ldx #0
|
||||||
|
ldy #38
|
||||||
|
-
|
||||||
|
lda c64.Colors + 40*13 + 1,x
|
||||||
|
sta c64.Colors + 40*13,x
|
||||||
|
lda c64.Colors + 40*14 + 1,x
|
||||||
|
sta c64.Colors + 40*14,x
|
||||||
|
lda c64.Colors + 40*15 + 1,x
|
||||||
|
sta c64.Colors + 40*15,x
|
||||||
|
lda c64.Colors + 40*16 + 1,x
|
||||||
|
sta c64.Colors + 40*16,x
|
||||||
|
lda c64.Colors + 40*17 + 1,x
|
||||||
|
sta c64.Colors + 40*17,x
|
||||||
|
lda c64.Colors + 40*18 + 1,x
|
||||||
|
sta c64.Colors + 40*18,x
|
||||||
|
lda c64.Colors + 40*19 + 1,x
|
||||||
|
sta c64.Colors + 40*19,x
|
||||||
|
lda c64.Colors + 40*20 + 1,x
|
||||||
|
sta c64.Colors + 40*20,x
|
||||||
|
lda c64.Colors + 40*21 + 1,x
|
||||||
|
sta c64.Colors + 40*21,x
|
||||||
|
lda c64.Colors + 40*22 + 1,x
|
||||||
|
sta c64.Colors + 40*22,x
|
||||||
|
lda c64.Colors + 40*23 + 1,x
|
||||||
|
sta c64.Colors + 40*23,x
|
||||||
|
lda c64.Colors + 40*24 + 1,x
|
||||||
|
sta c64.Colors + 40*24,x
|
||||||
|
inx
|
||||||
|
dey
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
_scroll_screen
|
||||||
|
ldx #0
|
||||||
|
ldy #38
|
||||||
|
-
|
||||||
|
lda c64.Screen + 40*0 + 1,x
|
||||||
|
sta c64.Screen + 40*0,x
|
||||||
|
lda c64.Screen + 40*1 + 1,x
|
||||||
|
sta c64.Screen + 40*1,x
|
||||||
|
lda c64.Screen + 40*2 + 1,x
|
||||||
|
sta c64.Screen + 40*2,x
|
||||||
|
lda c64.Screen + 40*3 + 1,x
|
||||||
|
sta c64.Screen + 40*3,x
|
||||||
|
lda c64.Screen + 40*4 + 1,x
|
||||||
|
sta c64.Screen + 40*4,x
|
||||||
|
lda c64.Screen + 40*5 + 1,x
|
||||||
|
sta c64.Screen + 40*5,x
|
||||||
|
lda c64.Screen + 40*6 + 1,x
|
||||||
|
sta c64.Screen + 40*6,x
|
||||||
|
lda c64.Screen + 40*7 + 1,x
|
||||||
|
sta c64.Screen + 40*7,x
|
||||||
|
lda c64.Screen + 40*8 + 1,x
|
||||||
|
sta c64.Screen + 40*8,x
|
||||||
|
lda c64.Screen + 40*9 + 1,x
|
||||||
|
sta c64.Screen + 40*9,x
|
||||||
|
lda c64.Screen + 40*10 + 1,x
|
||||||
|
sta c64.Screen + 40*10,x
|
||||||
|
lda c64.Screen + 40*11 + 1,x
|
||||||
|
sta c64.Screen + 40*11,x
|
||||||
|
lda c64.Screen + 40*12 + 1,x
|
||||||
|
sta c64.Screen + 40*12,x
|
||||||
|
inx
|
||||||
|
dey
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
ldx #0
|
||||||
|
ldy #38
|
||||||
|
-
|
||||||
|
lda c64.Screen + 40*13 + 1,x
|
||||||
|
sta c64.Screen + 40*13,x
|
||||||
|
lda c64.Screen + 40*14 + 1,x
|
||||||
|
sta c64.Screen + 40*14,x
|
||||||
|
lda c64.Screen + 40*15 + 1,x
|
||||||
|
sta c64.Screen + 40*15,x
|
||||||
|
lda c64.Screen + 40*16 + 1,x
|
||||||
|
sta c64.Screen + 40*16,x
|
||||||
|
lda c64.Screen + 40*17 + 1,x
|
||||||
|
sta c64.Screen + 40*17,x
|
||||||
|
lda c64.Screen + 40*18 + 1,x
|
||||||
|
sta c64.Screen + 40*18,x
|
||||||
|
lda c64.Screen + 40*19 + 1,x
|
||||||
|
sta c64.Screen + 40*19,x
|
||||||
|
lda c64.Screen + 40*20 + 1,x
|
||||||
|
sta c64.Screen + 40*20,x
|
||||||
|
lda c64.Screen + 40*21 + 1,x
|
||||||
|
sta c64.Screen + 40*21,x
|
||||||
|
lda c64.Screen + 40*22 + 1,x
|
||||||
|
sta c64.Screen + 40*22,x
|
||||||
|
lda c64.Screen + 40*23 + 1,x
|
||||||
|
sta c64.Screen + 40*23,x
|
||||||
|
lda c64.Screen + 40*24 + 1,x
|
||||||
|
sta c64.Screen + 40*24,x
|
||||||
|
inx
|
||||||
|
dey
|
||||||
|
bpl -
|
||||||
|
rts
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sub scroll_right_full (alsocolors: SC) -> (A?, X?) {
|
||||||
|
; ---- scroll the whole screen 1 character to the right
|
||||||
|
; contents of the leftmost column are unchanged, you should clear/refill this yourself
|
||||||
|
; Carry flag determines if screen color data should be scrolled too
|
||||||
|
asm {
|
||||||
|
bcs +
|
||||||
|
jmp _scroll_screen
|
||||||
|
|
||||||
|
+
|
||||||
|
ldx #38
|
||||||
|
-
|
||||||
|
lda c64.Colors + 40*0,x
|
||||||
|
sta c64.Colors + 40*0 + 1,x
|
||||||
|
lda c64.Colors + 40*1,x
|
||||||
|
sta c64.Colors + 40*1 + 1,x
|
||||||
|
lda c64.Colors + 40*2,x
|
||||||
|
sta c64.Colors + 40*2 + 1,x
|
||||||
|
lda c64.Colors + 40*3,x
|
||||||
|
sta c64.Colors + 40*3 + 1,x
|
||||||
|
lda c64.Colors + 40*4,x
|
||||||
|
sta c64.Colors + 40*4 + 1,x
|
||||||
|
lda c64.Colors + 40*5,x
|
||||||
|
sta c64.Colors + 40*5 + 1,x
|
||||||
|
lda c64.Colors + 40*6,x
|
||||||
|
sta c64.Colors + 40*6 + 1,x
|
||||||
|
lda c64.Colors + 40*7,x
|
||||||
|
sta c64.Colors + 40*7 + 1,x
|
||||||
|
lda c64.Colors + 40*8,x
|
||||||
|
sta c64.Colors + 40*8 + 1,x
|
||||||
|
lda c64.Colors + 40*9,x
|
||||||
|
sta c64.Colors + 40*9 + 1,x
|
||||||
|
lda c64.Colors + 40*10,x
|
||||||
|
sta c64.Colors + 40*10 + 1,x
|
||||||
|
lda c64.Colors + 40*11,x
|
||||||
|
sta c64.Colors + 40*11 + 1,x
|
||||||
|
lda c64.Colors + 40*12,x
|
||||||
|
sta c64.Colors + 40*12 + 1,x
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
ldx #38
|
||||||
|
-
|
||||||
|
lda c64.Colors + 40*13,x
|
||||||
|
sta c64.Colors + 40*13 + 1,x
|
||||||
|
lda c64.Colors + 40*14,x
|
||||||
|
sta c64.Colors + 40*14 + 1,x
|
||||||
|
lda c64.Colors + 40*15,x
|
||||||
|
sta c64.Colors + 40*15 + 1,x
|
||||||
|
lda c64.Colors + 40*16,x
|
||||||
|
sta c64.Colors + 40*16 + 1,x
|
||||||
|
lda c64.Colors + 40*17,x
|
||||||
|
sta c64.Colors + 40*17 + 1,x
|
||||||
|
lda c64.Colors + 40*18,x
|
||||||
|
sta c64.Colors + 40*18 + 1,x
|
||||||
|
lda c64.Colors + 40*19,x
|
||||||
|
sta c64.Colors + 40*19 + 1,x
|
||||||
|
lda c64.Colors + 40*20,x
|
||||||
|
sta c64.Colors + 40*20 + 1,x
|
||||||
|
lda c64.Colors + 40*21,x
|
||||||
|
sta c64.Colors + 40*21 + 1,x
|
||||||
|
lda c64.Colors + 40*22,x
|
||||||
|
sta c64.Colors + 40*22 + 1,x
|
||||||
|
lda c64.Colors + 40*23,x
|
||||||
|
sta c64.Colors + 40*23 + 1,x
|
||||||
|
lda c64.Colors + 40*24,x
|
||||||
|
sta c64.Colors + 40*24 + 1,x
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
_scroll_screen
|
||||||
|
ldx #38
|
||||||
|
-
|
||||||
|
lda c64.Screen + 40*0,x
|
||||||
|
sta c64.Screen + 40*0 + 1,x
|
||||||
|
lda c64.Screen + 40*1,x
|
||||||
|
sta c64.Screen + 40*1 + 1,x
|
||||||
|
lda c64.Screen + 40*2,x
|
||||||
|
sta c64.Screen + 40*2 + 1,x
|
||||||
|
lda c64.Screen + 40*3,x
|
||||||
|
sta c64.Screen + 40*3 + 1,x
|
||||||
|
lda c64.Screen + 40*4,x
|
||||||
|
sta c64.Screen + 40*4 + 1,x
|
||||||
|
lda c64.Screen + 40*5,x
|
||||||
|
sta c64.Screen + 40*5 + 1,x
|
||||||
|
lda c64.Screen + 40*6,x
|
||||||
|
sta c64.Screen + 40*6 + 1,x
|
||||||
|
lda c64.Screen + 40*7,x
|
||||||
|
sta c64.Screen + 40*7 + 1,x
|
||||||
|
lda c64.Screen + 40*8,x
|
||||||
|
sta c64.Screen + 40*8 + 1,x
|
||||||
|
lda c64.Screen + 40*9,x
|
||||||
|
sta c64.Screen + 40*9 + 1,x
|
||||||
|
lda c64.Screen + 40*10,x
|
||||||
|
sta c64.Screen + 40*10 + 1,x
|
||||||
|
lda c64.Screen + 40*11,x
|
||||||
|
sta c64.Screen + 40*11 + 1,x
|
||||||
|
lda c64.Screen + 40*12,x
|
||||||
|
sta c64.Screen + 40*12 + 1,x
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
ldx #38
|
||||||
|
-
|
||||||
|
lda c64.Screen + 40*13,x
|
||||||
|
sta c64.Screen + 40*13 + 1,x
|
||||||
|
lda c64.Screen + 40*14,x
|
||||||
|
sta c64.Screen + 40*14 + 1,x
|
||||||
|
lda c64.Screen + 40*15,x
|
||||||
|
sta c64.Screen + 40*15 + 1,x
|
||||||
|
lda c64.Screen + 40*16,x
|
||||||
|
sta c64.Screen + 40*16 + 1,x
|
||||||
|
lda c64.Screen + 40*17,x
|
||||||
|
sta c64.Screen + 40*17 + 1,x
|
||||||
|
lda c64.Screen + 40*18,x
|
||||||
|
sta c64.Screen + 40*18 + 1,x
|
||||||
|
lda c64.Screen + 40*19,x
|
||||||
|
sta c64.Screen + 40*19 + 1,x
|
||||||
|
lda c64.Screen + 40*20,x
|
||||||
|
sta c64.Screen + 40*20 + 1,x
|
||||||
|
lda c64.Screen + 40*21,x
|
||||||
|
sta c64.Screen + 40*21 + 1,x
|
||||||
|
lda c64.Screen + 40*22,x
|
||||||
|
sta c64.Screen + 40*22 + 1,x
|
||||||
|
lda c64.Screen + 40*23,x
|
||||||
|
sta c64.Screen + 40*23 + 1,x
|
||||||
|
lda c64.Screen + 40*24,x
|
||||||
|
sta c64.Screen + 40*24 + 1,x
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
rts
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sub scroll_up_full (alsocolors: SC) -> (A?, X?) {
|
||||||
|
; ---- scroll the whole screen 1 character up
|
||||||
|
; contents of the bottom row are unchanged, you should refill/clear this yourself
|
||||||
|
; Carry flag determines if screen color data should be scrolled too
|
||||||
|
asm {
|
||||||
|
bcs +
|
||||||
|
jmp _scroll_screen
|
||||||
|
|
||||||
|
+
|
||||||
|
ldx #39
|
||||||
|
-
|
||||||
|
lda c64.Colors + 40*1,x
|
||||||
|
sta c64.Colors + 40*0,x
|
||||||
|
lda c64.Colors + 40*2,x
|
||||||
|
sta c64.Colors + 40*1,x
|
||||||
|
lda c64.Colors + 40*3,x
|
||||||
|
sta c64.Colors + 40*2,x
|
||||||
|
lda c64.Colors + 40*4,x
|
||||||
|
sta c64.Colors + 40*3,x
|
||||||
|
lda c64.Colors + 40*5,x
|
||||||
|
sta c64.Colors + 40*4,x
|
||||||
|
lda c64.Colors + 40*6,x
|
||||||
|
sta c64.Colors + 40*5,x
|
||||||
|
lda c64.Colors + 40*7,x
|
||||||
|
sta c64.Colors + 40*6,x
|
||||||
|
lda c64.Colors + 40*8,x
|
||||||
|
sta c64.Colors + 40*7,x
|
||||||
|
lda c64.Colors + 40*9,x
|
||||||
|
sta c64.Colors + 40*8,x
|
||||||
|
lda c64.Colors + 40*10,x
|
||||||
|
sta c64.Colors + 40*9,x
|
||||||
|
lda c64.Colors + 40*11,x
|
||||||
|
sta c64.Colors + 40*10,x
|
||||||
|
lda c64.Colors + 40*12,x
|
||||||
|
sta c64.Colors + 40*11,x
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
ldx #39
|
||||||
|
-
|
||||||
|
lda c64.Colors + 40*13,x
|
||||||
|
sta c64.Colors + 40*12,x
|
||||||
|
lda c64.Colors + 40*14,x
|
||||||
|
sta c64.Colors + 40*13,x
|
||||||
|
lda c64.Colors + 40*15,x
|
||||||
|
sta c64.Colors + 40*14,x
|
||||||
|
lda c64.Colors + 40*16,x
|
||||||
|
sta c64.Colors + 40*15,x
|
||||||
|
lda c64.Colors + 40*17,x
|
||||||
|
sta c64.Colors + 40*16,x
|
||||||
|
lda c64.Colors + 40*18,x
|
||||||
|
sta c64.Colors + 40*17,x
|
||||||
|
lda c64.Colors + 40*19,x
|
||||||
|
sta c64.Colors + 40*18,x
|
||||||
|
lda c64.Colors + 40*20,x
|
||||||
|
sta c64.Colors + 40*19,x
|
||||||
|
lda c64.Colors + 40*21,x
|
||||||
|
sta c64.Colors + 40*20,x
|
||||||
|
lda c64.Colors + 40*22,x
|
||||||
|
sta c64.Colors + 40*21,x
|
||||||
|
lda c64.Colors + 40*23,x
|
||||||
|
sta c64.Colors + 40*22,x
|
||||||
|
lda c64.Colors + 40*24,x
|
||||||
|
sta c64.Colors + 40*23,x
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
_scroll_screen
|
||||||
|
ldx #39
|
||||||
|
-
|
||||||
|
lda c64.Screen + 40*1,x
|
||||||
|
sta c64.Screen + 40*0,x
|
||||||
|
lda c64.Screen + 40*2,x
|
||||||
|
sta c64.Screen + 40*1,x
|
||||||
|
lda c64.Screen + 40*3,x
|
||||||
|
sta c64.Screen + 40*2,x
|
||||||
|
lda c64.Screen + 40*4,x
|
||||||
|
sta c64.Screen + 40*3,x
|
||||||
|
lda c64.Screen + 40*5,x
|
||||||
|
sta c64.Screen + 40*4,x
|
||||||
|
lda c64.Screen + 40*6,x
|
||||||
|
sta c64.Screen + 40*5,x
|
||||||
|
lda c64.Screen + 40*7,x
|
||||||
|
sta c64.Screen + 40*6,x
|
||||||
|
lda c64.Screen + 40*8,x
|
||||||
|
sta c64.Screen + 40*7,x
|
||||||
|
lda c64.Screen + 40*9,x
|
||||||
|
sta c64.Screen + 40*8,x
|
||||||
|
lda c64.Screen + 40*10,x
|
||||||
|
sta c64.Screen + 40*9,x
|
||||||
|
lda c64.Screen + 40*11,x
|
||||||
|
sta c64.Screen + 40*10,x
|
||||||
|
lda c64.Screen + 40*12,x
|
||||||
|
sta c64.Screen + 40*11,x
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
ldx #39
|
||||||
|
-
|
||||||
|
lda c64.Screen + 40*13,x
|
||||||
|
sta c64.Screen + 40*12,x
|
||||||
|
lda c64.Screen + 40*14,x
|
||||||
|
sta c64.Screen + 40*13,x
|
||||||
|
lda c64.Screen + 40*15,x
|
||||||
|
sta c64.Screen + 40*14,x
|
||||||
|
lda c64.Screen + 40*16,x
|
||||||
|
sta c64.Screen + 40*15,x
|
||||||
|
lda c64.Screen + 40*17,x
|
||||||
|
sta c64.Screen + 40*16,x
|
||||||
|
lda c64.Screen + 40*18,x
|
||||||
|
sta c64.Screen + 40*17,x
|
||||||
|
lda c64.Screen + 40*19,x
|
||||||
|
sta c64.Screen + 40*18,x
|
||||||
|
lda c64.Screen + 40*20,x
|
||||||
|
sta c64.Screen + 40*19,x
|
||||||
|
lda c64.Screen + 40*21,x
|
||||||
|
sta c64.Screen + 40*20,x
|
||||||
|
lda c64.Screen + 40*22,x
|
||||||
|
sta c64.Screen + 40*21,x
|
||||||
|
lda c64.Screen + 40*23,x
|
||||||
|
sta c64.Screen + 40*22,x
|
||||||
|
lda c64.Screen + 40*24,x
|
||||||
|
sta c64.Screen + 40*23,x
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
rts
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sub scroll_down_full (alsocolors: SC) -> (A?, X?) {
|
||||||
|
; ---- scroll the whole screen 1 character down
|
||||||
|
; contents of the top row are unchanged, you should refill/clear this yourself
|
||||||
|
; Carry flag determines if screen color data should be scrolled too
|
||||||
|
asm {
|
||||||
|
bcs +
|
||||||
|
jmp _scroll_screen
|
||||||
|
|
||||||
|
+
|
||||||
|
ldx #39
|
||||||
|
-
|
||||||
|
lda c64.Colors + 40*23,x
|
||||||
|
sta c64.Colors + 40*24,x
|
||||||
|
lda c64.Colors + 40*22,x
|
||||||
|
sta c64.Colors + 40*23,x
|
||||||
|
lda c64.Colors + 40*21,x
|
||||||
|
sta c64.Colors + 40*22,x
|
||||||
|
lda c64.Colors + 40*20,x
|
||||||
|
sta c64.Colors + 40*21,x
|
||||||
|
lda c64.Colors + 40*19,x
|
||||||
|
sta c64.Colors + 40*20,x
|
||||||
|
lda c64.Colors + 40*18,x
|
||||||
|
sta c64.Colors + 40*19,x
|
||||||
|
lda c64.Colors + 40*17,x
|
||||||
|
sta c64.Colors + 40*18,x
|
||||||
|
lda c64.Colors + 40*16,x
|
||||||
|
sta c64.Colors + 40*17,x
|
||||||
|
lda c64.Colors + 40*15,x
|
||||||
|
sta c64.Colors + 40*16,x
|
||||||
|
lda c64.Colors + 40*14,x
|
||||||
|
sta c64.Colors + 40*15,x
|
||||||
|
lda c64.Colors + 40*13,x
|
||||||
|
sta c64.Colors + 40*14,x
|
||||||
|
lda c64.Colors + 40*12,x
|
||||||
|
sta c64.Colors + 40*13,x
|
||||||
|
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
ldx #39
|
||||||
|
-
|
||||||
|
lda c64.Colors + 40*11,x
|
||||||
|
sta c64.Colors + 40*12,x
|
||||||
|
lda c64.Colors + 40*10,x
|
||||||
|
sta c64.Colors + 40*11,x
|
||||||
|
lda c64.Colors + 40*9,x
|
||||||
|
sta c64.Colors + 40*10,x
|
||||||
|
lda c64.Colors + 40*8,x
|
||||||
|
sta c64.Colors + 40*9,x
|
||||||
|
lda c64.Colors + 40*7,x
|
||||||
|
sta c64.Colors + 40*8,x
|
||||||
|
lda c64.Colors + 40*6,x
|
||||||
|
sta c64.Colors + 40*7,x
|
||||||
|
lda c64.Colors + 40*5,x
|
||||||
|
sta c64.Colors + 40*6,x
|
||||||
|
lda c64.Colors + 40*4,x
|
||||||
|
sta c64.Colors + 40*5,x
|
||||||
|
lda c64.Colors + 40*3,x
|
||||||
|
sta c64.Colors + 40*4,x
|
||||||
|
lda c64.Colors + 40*2,x
|
||||||
|
sta c64.Colors + 40*3,x
|
||||||
|
lda c64.Colors + 40*1,x
|
||||||
|
sta c64.Colors + 40*2,x
|
||||||
|
lda c64.Colors + 40*0,x
|
||||||
|
sta c64.Colors + 40*1,x
|
||||||
|
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
_scroll_screen
|
||||||
|
ldx #39
|
||||||
|
-
|
||||||
|
lda c64.Screen + 40*23,x
|
||||||
|
sta c64.Screen + 40*24,x
|
||||||
|
lda c64.Screen + 40*22,x
|
||||||
|
sta c64.Screen + 40*23,x
|
||||||
|
lda c64.Screen + 40*21,x
|
||||||
|
sta c64.Screen + 40*22,x
|
||||||
|
lda c64.Screen + 40*20,x
|
||||||
|
sta c64.Screen + 40*21,x
|
||||||
|
lda c64.Screen + 40*19,x
|
||||||
|
sta c64.Screen + 40*20,x
|
||||||
|
lda c64.Screen + 40*18,x
|
||||||
|
sta c64.Screen + 40*19,x
|
||||||
|
lda c64.Screen + 40*17,x
|
||||||
|
sta c64.Screen + 40*18,x
|
||||||
|
lda c64.Screen + 40*16,x
|
||||||
|
sta c64.Screen + 40*17,x
|
||||||
|
lda c64.Screen + 40*15,x
|
||||||
|
sta c64.Screen + 40*16,x
|
||||||
|
lda c64.Screen + 40*14,x
|
||||||
|
sta c64.Screen + 40*15,x
|
||||||
|
lda c64.Screen + 40*13,x
|
||||||
|
sta c64.Screen + 40*14,x
|
||||||
|
lda c64.Screen + 40*12,x
|
||||||
|
sta c64.Screen + 40*13,x
|
||||||
|
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
ldx #39
|
||||||
|
-
|
||||||
|
lda c64.Screen + 40*11,x
|
||||||
|
sta c64.Screen + 40*12,x
|
||||||
|
lda c64.Screen + 40*10,x
|
||||||
|
sta c64.Screen + 40*11,x
|
||||||
|
lda c64.Screen + 40*9,x
|
||||||
|
sta c64.Screen + 40*10,x
|
||||||
|
lda c64.Screen + 40*8,x
|
||||||
|
sta c64.Screen + 40*9,x
|
||||||
|
lda c64.Screen + 40*7,x
|
||||||
|
sta c64.Screen + 40*8,x
|
||||||
|
lda c64.Screen + 40*6,x
|
||||||
|
sta c64.Screen + 40*7,x
|
||||||
|
lda c64.Screen + 40*5,x
|
||||||
|
sta c64.Screen + 40*6,x
|
||||||
|
lda c64.Screen + 40*4,x
|
||||||
|
sta c64.Screen + 40*5,x
|
||||||
|
lda c64.Screen + 40*3,x
|
||||||
|
sta c64.Screen + 40*4,x
|
||||||
|
lda c64.Screen + 40*2,x
|
||||||
|
sta c64.Screen + 40*3,x
|
||||||
|
lda c64.Screen + 40*1,x
|
||||||
|
sta c64.Screen + 40*2,x
|
||||||
|
lda c64.Screen + 40*0,x
|
||||||
|
sta c64.Screen + 40*1,x
|
||||||
|
|
||||||
|
dex
|
||||||
|
bpl -
|
||||||
|
|
||||||
|
rts
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
sub byte2decimal (ubyte: A) -> (Y, X, A) {
|
sub byte2decimal (ubyte: A) -> (Y, X, A) {
|
||||||
; ---- A to decimal string in Y/X/A (100s in Y, 10s in X, 1s in A)
|
; ---- A to decimal string in Y/X/A (100s in Y, 10s in X, 1s in A)
|
||||||
asm {
|
asm {
|
||||||
|
@ -15,6 +15,8 @@ import "c64lib"
|
|||||||
start
|
start
|
||||||
c64.init_system()
|
c64.init_system()
|
||||||
|
|
||||||
|
c64.VMCSB += 2
|
||||||
|
c64.VMCSB *= 2
|
||||||
A = c64.VMCSB
|
A = c64.VMCSB
|
||||||
A |= 2 ; @todo c64.VMCSB |= 2
|
A |= 2 ; @todo c64.VMCSB |= 2
|
||||||
c64.VMCSB = A
|
c64.VMCSB = A
|
||||||
|
61
todo.ill
61
todo.ill
@ -5,23 +5,62 @@ output prg,basic
|
|||||||
import "c64lib"
|
import "c64lib"
|
||||||
|
|
||||||
~ main {
|
~ main {
|
||||||
|
|
||||||
var .float float1 = 123.456
|
|
||||||
var .float float2 = 99.99
|
|
||||||
const .float flc = 1234.55
|
|
||||||
const .text foostr = "derp"
|
|
||||||
var .text foostr2 = "derp2"
|
|
||||||
|
|
||||||
start
|
start
|
||||||
|
asm {
|
||||||
|
ldy #200
|
||||||
|
- lda #81
|
||||||
|
sta c64.Screen+39-40,y
|
||||||
|
sta c64.Screen+39+4*40,y
|
||||||
|
sta c64.Screen+39+9*40,y
|
||||||
|
sta c64.Screen+39+14*40,y
|
||||||
|
sta c64.Screen+39+19*40,y
|
||||||
|
lda #83
|
||||||
|
sta c64.Screen-40,y
|
||||||
|
sta c64.Screen+4*40,y
|
||||||
|
sta c64.Screen+9*40,y
|
||||||
|
sta c64.Screen+14*40,y
|
||||||
|
sta c64.Screen+19*40,y
|
||||||
|
lda #1
|
||||||
|
sta c64.Colors+39-40,y
|
||||||
|
sta c64.Colors+39+4*40,y
|
||||||
|
sta c64.Colors+39+9*40,y
|
||||||
|
sta c64.Colors+39+14*40,y
|
||||||
|
sta c64.Colors+39+19*40,y
|
||||||
|
lda #5
|
||||||
|
sta c64.Colors-40,y
|
||||||
|
sta c64.Colors+4*40,y
|
||||||
|
sta c64.Colors+9*40,y
|
||||||
|
sta c64.Colors+14*40,y
|
||||||
|
sta c64.Colors+19*40,y
|
||||||
|
tya
|
||||||
|
sec
|
||||||
|
sbc #40
|
||||||
|
tay
|
||||||
|
bne -
|
||||||
|
}
|
||||||
|
|
||||||
|
loop
|
||||||
|
A=c64.GETIN()
|
||||||
|
if_not goto loop
|
||||||
|
c64scr.scroll_down_full(1)
|
||||||
|
goto loop
|
||||||
|
c64.CHROUT(A)
|
||||||
|
goto loop
|
||||||
|
|
||||||
|
;c64scr.print_byte_hex(0, A)
|
||||||
|
;c64.CHROUT(' ')
|
||||||
|
;goto loop
|
||||||
|
|
||||||
|
;return
|
||||||
|
|
||||||
A = $11
|
A = $11
|
||||||
X = $22
|
X = $22
|
||||||
Y = $33
|
Y = $33
|
||||||
|
|
||||||
c64scr.clear_screen !(81, 5, $04) ; @todo new syntax to specify registers to save (! = all three A,X,Y)
|
c64scr.clear_screen !(81, 5) ; @todo new syntax to specify registers to save (! = all three A,X,Y)
|
||||||
;c64scr.clear_screen !A (81, 5, $04) ; @todo new syntax to specify registers to save (only A)
|
;c64scr.clear_screen !A (81, 5) ; @todo new syntax to specify registers to save (only A)
|
||||||
;c64scr.clear_screen !AX (81, 5, $04)
|
;c64scr.clear_screen !AX (81, 5)
|
||||||
;c64scr.clear_screen !AXY (81, 5, $04)
|
;c64scr.clear_screen !AXY (81, 5)
|
||||||
|
|
||||||
c64scr.print_byte_hex(1,A)
|
c64scr.print_byte_hex(1,A)
|
||||||
c64.CHROUT(' ')
|
c64.CHROUT(' ')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user