screen scroll

This commit is contained in:
Irmen de Jong 2018-01-01 16:41:08 +01:00
parent 50db122525
commit aa2f3dd169
5 changed files with 619 additions and 44 deletions

View File

@ -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)

View File

@ -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)

View File

@ -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 {

View File

@ -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

View File

@ -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(' ')