1
0
mirror of https://gitlab.com/camelot/kickc.git synced 2025-01-09 05:33:11 +00:00

Merge remote-tracking branch 'origin/328-memvars' into 328-memvars

This commit is contained in:
Jesper Gravgaard 2019-10-31 16:10:46 +01:00
commit e427cb648b
11 changed files with 259 additions and 259 deletions

View File

@ -1,27 +1,27 @@
// SID registers for random number generation
const word* SID_VOICE3_FREQ = $d40e;
const byte* SID_VOICE3_FREQ_LOW = $d40e;
const byte* SID_VOICE3_FREQ_HIGH = $d40f;
const byte* SID_VOICE3_CONTROL = $d412;
const byte SID_CONTROL_NOISE = $80;
const byte SID_CONTROL_PULSE = $40;
const byte SID_CONTROL_SAWTOOTH = $20;
const byte SID_CONTROL_TRIANGLE = $10;
const byte SID_CONTROL_TEST = $08;
const byte SID_CONTROL_RING = $04;
const byte SID_CONTROL_SYNC = $02;
const byte SID_CONTROL_GATE = $01;
const byte* SID_VOICE3_OSC = $d41b;
const unsigned int* SID_VOICE3_FREQ = 0xd40e;
const char* SID_VOICE3_FREQ_LOW = 0xd40e;
const char* SID_VOICE3_FREQ_HIGH = 0xd40f;
const char* SID_VOICE3_CONTROL = 0xd412;
const char SID_CONTROL_NOISE = 0x80;
const char SID_CONTROL_PULSE = 0x40;
const char SID_CONTROL_SAWTOOTH = 0x20;
const char SID_CONTROL_TRIANGLE = 0x10;
const char SID_CONTROL_TEST = 0x08;
const char SID_CONTROL_RING = 0x04;
const char SID_CONTROL_SYNC = 0x02;
const char SID_CONTROL_GATE = 0x01;
const char* SID_VOICE3_OSC = 0xd41b;
// Initialize SID voice 3 for random number generation
void sid_rnd_init() {
*SID_VOICE3_FREQ = $ffff;
*SID_VOICE3_FREQ = 0xffff;
*SID_VOICE3_CONTROL = SID_CONTROL_NOISE;
}
// Get a random number from the SID voice 3,
// Must be initialized with sid_rnd_init()
inline byte sid_rnd() {
inline char sid_rnd() {
return *SID_VOICE3_OSC;
}

View File

@ -1,30 +1,30 @@
import "tetris-sprites"
byte[256] SIN = kickasm {{
char[256] SIN = kickasm {{
.var AMPL = 200-21
.for(var i=0; i<256; i++) {
.byte 51+AMPL/2+sin(toRadians([i*360]/256))*AMPL/2
}
}};
byte* SIN_SPRITE = $2800;
char* SIN_SPRITE = 0x2800;
kickasm(pc SIN_SPRITE) {{
.fill $40, $ff
}}
byte sin_idx = 0;
char sin_idx = 0;
void main() {
vicSelectGfxBank(PLAYFIELD_SCREEN_1);
*D018 = toD018(PLAYFIELD_SCREEN_1, PLAYFIELD_CHARSET);
sprites_init();
*SPRITES_ENABLE = $ff;
*SPRITES_ENABLE = 0xff;
byte xpos = 24;
byte ypos = 50;
for(byte s:4..7) {
byte s2 = s*2;
char xpos = 24;
char ypos = 50;
for(char s:4..7) {
char s2 = s*2;
SPRITES_XPOS[s2] = xpos;
SPRITES_YPOS[s2] = ypos;
SPRITES_COLS[s] = s-3;
@ -40,9 +40,9 @@ void main() {
void loop() {
while(true) {
do {} while (*RASTER!=$ff);
byte idx = sin_idx;
for(byte s:4..7) {
do {} while (*RASTER!=0xff);
char idx = sin_idx;
for(char s:4..7) {
SPRITES_YPOS[s*2] = SIN[idx];
idx += 10;
}

View File

@ -2,55 +2,55 @@
// Memory Layout and Shared Data
// Address of the first screen
const byte* PLAYFIELD_SCREEN_1 = $0400;
const char* PLAYFIELD_SCREEN_1 = 0x0400;
// Address of the second screen
const byte* PLAYFIELD_SCREEN_2 = $2c00;
const char* PLAYFIELD_SCREEN_2 = 0x2c00;
// Screen Sprite pointers on screen 1
const byte* PLAYFIELD_SPRITE_PTRS_1 = (PLAYFIELD_SCREEN_1+SPRITE_PTRS);
const char* PLAYFIELD_SPRITE_PTRS_1 = (PLAYFIELD_SCREEN_1+SPRITE_PTRS);
// Screen Sprite pointers on screen 2
const byte* PLAYFIELD_SPRITE_PTRS_2 = (PLAYFIELD_SCREEN_2+SPRITE_PTRS);
const char* PLAYFIELD_SPRITE_PTRS_2 = (PLAYFIELD_SCREEN_2+SPRITE_PTRS);
// Address of the original playscreen chars
const byte* PLAYFIELD_SCREEN_ORIGINAL = $1800;
const char* PLAYFIELD_SCREEN_ORIGINAL = 0x1800;
// Address of the original playscreen colors
const byte* PLAYFIELD_COLORS_ORIGINAL = $1c00;
const char* PLAYFIELD_COLORS_ORIGINAL = 0x1c00;
// Address of the sprites covering the playfield
const byte* PLAYFIELD_SPRITES = $2000;
const char* PLAYFIELD_SPRITES = 0x2000;
// Address of the charset
const byte* PLAYFIELD_CHARSET = $2800;
const char* PLAYFIELD_CHARSET = 0x2800;
// The size of the playfield
const byte PLAYFIELD_LINES = 22;
const byte PLAYFIELD_COLS = 10;
const char PLAYFIELD_LINES = 22;
const char PLAYFIELD_COLS = 10;
// The playfield. 0 is empty non-zero is color.
// The playfield is layed out line by line, meaning the first 10 bytes are line 1, the next 10 line 2 and so forth,
byte[PLAYFIELD_LINES*PLAYFIELD_COLS] playfield;
char[PLAYFIELD_LINES*PLAYFIELD_COLS] playfield;
// Pointer to the current piece in the current orientation. Updated each time current_orientation is updated.
byte* current_piece_gfx;
char* current_piece_gfx;
// The char of the current piece
byte current_piece_char;
char current_piece_char;
// Position of top left corner of current moving piece on the playfield
byte current_xpos;
byte current_ypos;
char current_xpos;
char current_ypos;
// The screen currently being rendered to. $00 for screen 1 / $20 for screen 2.
byte render_screen_render = $20;
// The screen currently to show next to the user. $00 for screen 1 / $20 for screen 2.
byte render_screen_show = 0;
// The screen currently being showed to the user. $00 for screen 1 / $20 for screen 2.
volatile byte render_screen_showing = 0;
// The screen currently being rendered to. 0x00 for screen 1 / 0x20 for screen 2.
char render_screen_render = 0x20;
// The screen currently to show next to the user. 0x00 for screen 1 / 0x20 for screen 2.
char render_screen_show = 0;
// The screen currently being showed to the user. 0x00 for screen 1 / 0x20 for screen 2.
volatile char render_screen_showing = 0;
// Current score in BCD-format
dword score_bcd = 0;
unsigned long score_bcd = 0;
// Current number of cleared lines in BCD-format
word lines_bcd = 0;
unsigned int lines_bcd = 0;
// Current level BCD-format
byte level_bcd = 0;
char level_bcd = 0;
// Current level in normal (non-BCD) format
byte level = 0;
char level = 0;
// Is the game over?
byte game_over = 0;
char game_over = 0;

View File

@ -2,7 +2,7 @@
// The tetris pieces
// The T-piece
align($40) byte[4*4*4] PIECE_T = {
align(0x40) char[4*4*4] PIECE_T = {
0, 0, 0, 0,
1, 1, 1, 0,
0, 1, 0, 0,
@ -25,7 +25,7 @@ align($40) byte[4*4*4] PIECE_T = {
};
// The S-piece
align($40) byte[4*4*4] PIECE_S = {
align(0x40) char[4*4*4] PIECE_S = {
0, 0, 0, 0,
0, 1, 1, 0,
1, 1, 0, 0,
@ -49,7 +49,7 @@ align($40) byte[4*4*4] PIECE_S = {
};
// The Z-piece
align($40) byte[4*4*4] PIECE_Z = {
align(0x40) char[4*4*4] PIECE_Z = {
0, 0, 0, 0,
1, 1, 0, 0,
0, 1, 1, 0,
@ -73,7 +73,7 @@ align($40) byte[4*4*4] PIECE_Z = {
};
// The L-piece
align($40) byte[4*4*4] PIECE_L = {
align(0x40) char[4*4*4] PIECE_L = {
0, 0, 0, 0,
1, 1, 1, 0,
1, 0, 0, 0,
@ -97,7 +97,7 @@ align($40) byte[4*4*4] PIECE_L = {
};
// The J-piece
align($40) byte[4*4*4] PIECE_J = {
align(0x40) char[4*4*4] PIECE_J = {
0, 0, 0, 0,
1, 1, 1, 0,
0, 0, 1, 0,
@ -121,7 +121,7 @@ align($40) byte[4*4*4] PIECE_J = {
};
// The O-piece
align($40) byte[4*4*4] PIECE_O = {
align(0x40) char[4*4*4] PIECE_O = {
0, 0, 0, 0,
0, 1, 1, 0,
0, 1, 1, 0,
@ -145,7 +145,7 @@ align($40) byte[4*4*4] PIECE_O = {
};
// The I-piece
align($40) byte[4*4*4] PIECE_I = {
align(0x40) char[4*4*4] PIECE_I = {
0, 0, 0, 0,
0, 0, 0, 0,
1, 1, 1, 1,
@ -169,14 +169,14 @@ align($40) byte[4*4*4] PIECE_I = {
};
// The different pieces
word[] PIECES = { (word)PIECE_T, (word)PIECE_S, (word)PIECE_Z, (word)PIECE_J, (word)PIECE_O, (word)PIECE_I, (word)PIECE_L };
unsigned int[] PIECES = { (unsigned int)PIECE_T, (unsigned int)PIECE_S, (unsigned int)PIECE_Z, (unsigned int)PIECE_J, (unsigned int)PIECE_O, (unsigned int)PIECE_I, (unsigned int)PIECE_L };
// The chars to use for the different pieces - when inside the playing area
byte[] PIECES_CHARS = { $65, $66, $a6, $66, $65, $65, $a6 };
char[] PIECES_CHARS = { 0x65, 0x66, 0xa6, 0x66, 0x65, 0x65, 0xa6 };
// The chars to use for the different pieces - when outside the playing area (eg. the next area).
byte[] PIECES_NEXT_CHARS = { $63, $64, $a4, $64, $63, $63, $a4 };
char[] PIECES_NEXT_CHARS = { 0x63, 0x64, 0xa4, 0x64, 0x63, 0x63, 0xa4 };
// The initial X/Y for each piece
byte[] PIECES_START_X = { 4, 4, 4, 4, 4, 4, 4 };
byte[] PIECES_START_Y = { 1, 1, 1, 1, 1, 0, 1 };
char[] PIECES_START_X = { 4, 4, 4, 4, 4, 4, 4 };
char[] PIECES_START_Y = { 1, 1, 1, 1, 1, 0, 1 };

View File

@ -6,48 +6,48 @@ import "tetris-data"
import "tetris-pieces"
// Pointers to the playfield address for each playfield line
byte*[PLAYFIELD_LINES] playfield_lines;
char*[PLAYFIELD_LINES] playfield_lines;
// Indixes into the playfield for each playfield line
byte[PLAYFIELD_LINES+1] playfield_lines_idx;
char[PLAYFIELD_LINES+1] playfield_lines_idx;
// The index of the next moving piece. (0-6)
byte next_piece_idx = 0;
char next_piece_idx = 0;
// The current moving piece. Points to the start of the piece definition.
byte* current_piece = 0;
char* current_piece = 0;
// The curent piece orientation - each piece have 4 orientations (00/$10/$20/$30).
// The curent piece orientation - each piece have 4 orientations (00/0x10/0x20/0x30).
// The orientation chooses one of the 4 sub-graphics of the piece.
byte current_orientation = 0;
char current_orientation = 0;
// The speed of moving down the piece when soft-drop is not activated
// This array holds the number of frames per move by level (0-29). For all levels 29+ the value is 1.
const byte[] MOVEDOWN_SLOW_SPEEDS = { 48, 43, 38, 33, 28, 23, 18, 13, 8, 6, 5, 5, 5, 4, 4, 4, 3, 3, 3, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1 };
const char[] MOVEDOWN_SLOW_SPEEDS = { 48, 43, 38, 33, 28, 23, 18, 13, 8, 6, 5, 5, 5, 4, 4, 4, 3, 3, 3, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1 };
// The rate of moving down the current piece (number of frames between moves if movedown is not forced)
byte current_movedown_slow = 48;
char current_movedown_slow = 48;
// The rate of moving down the current piece fast (number of frames between moves if movedown is not forced)
const byte current_movedown_fast = 10;
const char current_movedown_fast = 10;
// Counts up to the next movedown of current piece
byte current_movedown_counter = 0;
char current_movedown_counter = 0;
// Base Score values for removing 0-4 lines (in BCD)
// These values are added to score_add_bcd for each level gained.
const dword[] SCORE_BASE_BCD = { $0000, $0040, $0100, $0300, $1200 };
const unsigned long[] SCORE_BASE_BCD = { 0x0000, 0x0040, 0x0100, 0x0300, 0x1200 };
// Score values for removing 0-4 lines (in BCD)
// These values are updated based on the players level and the base values from SCORE_BASE_BCD
dword[5] score_add_bcd;
unsigned long[5] score_add_bcd;
// Initialize play data tables
void play_init() {
// Initialize the playfield line pointers;
byte idx = 0;
byte* pli = playfield;
for(byte j:0..PLAYFIELD_LINES-1) {
char idx = 0;
char* pli = playfield;
for(char j:0..PLAYFIELD_LINES-1) {
playfield_lines[j] = pli;
playfield_lines_idx[j] = idx;
pli += PLAYFIELD_COLS;
@ -58,17 +58,17 @@ void play_init() {
// Set initial speed of moving down a tetromino
current_movedown_slow = MOVEDOWN_SLOW_SPEEDS[level];
// Set the initial score add values
for(byte b: 0..4) {
for(char b: 0..4) {
score_add_bcd[b] = SCORE_BASE_BCD[b];
}
}
// Perform any movement of the current piece
// key_event is the next keyboard_event() og $ff if no keyboard event is pending
// key_event is the next keyboard_event() og 0xff if no keyboard event is pending
// Returns a byte signaling whether rendering is needed. (0 no render, >0 render needed)
byte play_movement(byte key_event) {
byte render = 0;
char play_movement(char key_event) {
char render = 0;
render += play_move_down(key_event);
if(game_over!=0) {
return render;
@ -80,10 +80,10 @@ byte play_movement(byte key_event) {
// Move down the current piece
// Return non-zero if a render is needed
byte play_move_down(byte key_event) {
char play_move_down(byte key_event) {
// Handle moving down current piece
++current_movedown_counter;
byte movedown = 0;
char movedown = 0;
// As soon as space is pressed move down once
if(key_event==KEY_SPACE) {
movedown++;
@ -107,7 +107,7 @@ byte play_move_down(byte key_event) {
// Lock current piece
play_lock_current();
// Check for any lines and remove them
byte removed = play_remove_lines();
char removed = play_remove_lines();
// Tally up the score
play_update_score(removed);
// Spawn a new piece
@ -121,7 +121,7 @@ byte play_move_down(byte key_event) {
// Move left/right or rotate the current piece
// Return non-zero if a render is needed
byte play_move_leftright(byte key_event) {
char play_move_leftright(char key_event) {
// Handle keyboard events
if(key_event==KEY_COMMA) {
if(play_collision(current_xpos-1,current_ypos,current_orientation)==COLLISION_NONE) {
@ -139,13 +139,13 @@ byte play_move_leftright(byte key_event) {
// Rotate the current piece based on key-presses
// Return non-zero if a render is needed
byte play_move_rotate(byte key_event) {
char play_move_rotate(char key_event) {
// Handle keyboard events
byte orientation = $80;
char orientation = 0x80;
if(key_event==KEY_Z) {
orientation = (current_orientation-$10)&$3f;
orientation = (current_orientation-0x10)&0x3f;
} else if(key_event==KEY_X) {
orientation = (current_orientation+$10)&$3f;
orientation = (current_orientation+0x10)&0x3f;
} else {
return 0;
}
@ -158,32 +158,32 @@ byte play_move_rotate(byte key_event) {
}
// No collision
const byte COLLISION_NONE = 0;
const char COLLISION_NONE = 0;
// Playfield piece collision (cell on top of other cell on the playfield)
const byte COLLISION_PLAYFIELD = 1;
const char COLLISION_PLAYFIELD = 1;
// Bottom collision (cell below bottom of the playfield)
const byte COLLISION_BOTTOM = 2;
const char COLLISION_BOTTOM = 2;
// Left side collision (cell beyond the left side of the playfield)
const byte COLLISION_LEFT = 4;
const char COLLISION_LEFT = 4;
// Right side collision (cell beyond the right side of the playfield)
const byte COLLISION_RIGHT = 8;
const char COLLISION_RIGHT = 8;
// Test if there is a collision between the current piece moved to (x, y) and anything on the playfield or the playfield boundaries
// Returns information about the type of the collision detected
byte play_collision(byte xpos, byte ypos, byte orientation) {
byte* piece_gfx = current_piece + orientation;
byte i = 0;
byte yp = ypos;
for(byte l:0..3) {
byte* playfield_line = playfield_lines[yp];
byte xp = xpos;
for(byte c:0..3) {
char play_collision(char xpos, char ypos, char orientation) {
char* piece_gfx = current_piece + orientation;
char i = 0;
char yp = ypos;
for(char l:0..3) {
char* playfield_line = playfield_lines[yp];
char xp = xpos;
for(char c:0..3) {
if(piece_gfx[i++]!=0) {
if(yp>=PLAYFIELD_LINES) {
// Below the playfield bottom
return COLLISION_BOTTOM;
}
if((xp&$80)!=0) {
if((xp&0x80)!=0) {
// Beyond left side of the playfield
return COLLISION_LEFT;
}
@ -205,12 +205,12 @@ byte play_collision(byte xpos, byte ypos, byte orientation) {
// Lock the current piece onto the playfield
void play_lock_current() {
byte i = 0;
byte yp = current_ypos;
for(byte l:0..3) {
byte* playfield_line = playfield_lines[yp];
byte xp = current_xpos;
for(byte c:0..3) {
char i = 0;
char yp = current_ypos;
for(char l:0..3) {
char* playfield_line = playfield_lines[yp];
char xp = current_xpos;
for(char c:0..3) {
if(current_piece_gfx[i++]!=0) {
playfield_line[xp] = current_piece_char;
}
@ -224,7 +224,7 @@ void play_lock_current() {
// Moves the next piece into the current and spawns a new next piece
void play_spawn_current() {
// Move next piece into current
byte current_piece_idx = next_piece_idx;
char current_piece_idx = next_piece_idx;
current_piece = PIECES[current_piece_idx];
current_piece_char = PIECES_CHARS[current_piece_idx];
current_orientation = 0;
@ -237,7 +237,7 @@ void play_spawn_current() {
// Spawn a new next piece
// Pick a random piece (0-6)
byte piece_idx = 7;
char piece_idx = 7;
while(piece_idx==7) {
piece_idx = sid_rnd()&7;
}
@ -249,17 +249,17 @@ void play_spawn_current() {
// Utilizes two cursors on the playfield - one reading cells and one writing cells
// Whenever a full line is detected the writing cursor is instructed to write to the same line once more.
// Returns the number of lines removed
byte play_remove_lines() {
char play_remove_lines() {
// Start both cursors at the end of the playfield
byte r = PLAYFIELD_LINES*PLAYFIELD_COLS-1;
byte w = PLAYFIELD_LINES*PLAYFIELD_COLS-1;
char r = PLAYFIELD_LINES*PLAYFIELD_COLS-1;
char w = PLAYFIELD_LINES*PLAYFIELD_COLS-1;
byte removed = 0;
char removed = 0;
// Read all lines and rewrite them
for(byte y:0..PLAYFIELD_LINES-1) {
byte full = 1;
for(byte x:0..PLAYFIELD_COLS-1) {
byte c = playfield[r--];
for(char y:0..PLAYFIELD_LINES-1) {
char full = 1;
for(char x:0..PLAYFIELD_COLS-1) {
char c = playfield[r--];
if(c==0) {
full = 0;
}
@ -273,7 +273,7 @@ byte play_remove_lines() {
}
// Write zeros in the rest of the lines
while(w!=$ff) {
while(w!=0xff) {
playfield[w--] = 0;
}
// Return the number of removed lines
@ -281,10 +281,10 @@ byte play_remove_lines() {
}
// Update the score based on the number of lines removed
void play_update_score(byte removed) {
void play_update_score(char removed) {
if(removed!=0){
byte lines_before = <lines_bcd&$f0;
dword add_bcd = score_add_bcd[removed];
char lines_before = <lines_bcd&0xf0;
unsigned long add_bcd = score_add_bcd[removed];
asm { sed }
lines_bcd += removed;
@ -292,7 +292,7 @@ void play_update_score(byte removed) {
asm { cld }
// If line 10-part updated increase the level
byte lines_after = <lines_bcd&$f0;
char lines_after = <lines_bcd&0xf0;
if(lines_before!=lines_after) {
play_increase_level();
}
@ -311,13 +311,13 @@ void play_increase_level() {
}
// Increase BCD-format level
level_bcd++;
if((level_bcd&$f)==$a) {
// If level low nybble hits $a change to $10
if((level_bcd&0xf)==0xa) {
// If level low nybble hits 0xa change to 0x10
level_bcd += 6;
}
// Increase the score values gained
asm { sed }
for(byte b: 0..4) {
for(char b: 0..4) {
score_add_bcd[b] += SCORE_BASE_BCD[b];
}
asm { cld }

View File

@ -9,7 +9,7 @@ kickasm(pc PLAYFIELD_CHARSET, resource "playfield-screen.imap") {{
.import binary "playfield-screen.imap"
}}
const byte PLAYFIELD_SCREEN_ORIGINAL_WIDTH=32;
const char PLAYFIELD_SCREEN_ORIGINAL_WIDTH=32;
kickasm(pc PLAYFIELD_SCREEN_ORIGINAL, resource "playfield-screen.iscr", resource "playfield-extended.col" ) {{
// Load chars for the screen
.var screen = LoadBinary("playfield-screen.iscr")
@ -27,22 +27,22 @@ kickasm(pc PLAYFIELD_COLORS_ORIGINAL, resource "playfield-screen.col") {{
}}
// The color #1 to use for the pieces for each level
byte[] PIECES_COLORS_1 = {
char[] PIECES_COLORS_1 = {
BLUE, GREEN, PURPLE, BLUE, RED, LIGHT_GREEN, RED, BLUE, LIGHT_BLUE, RED,
BLUE, GREEN, PURPLE, BLUE, RED, LIGHT_GREEN, RED, BLUE, LIGHT_BLUE, RED,
BLUE, GREEN, PURPLE, BLUE, RED, LIGHT_GREEN, RED, BLUE, LIGHT_BLUE, RED
};
// The color #2 to use for the pieces for each level
byte[] PIECES_COLORS_2 = {
char[] PIECES_COLORS_2 = {
CYAN, LIGHT_GREEN, PINK, LIGHT_GREEN, LIGHT_GREEN, LIGHT_BLUE, DARK_GREY, PURPLE, RED, ORANGE,
CYAN, LIGHT_GREEN, PINK, LIGHT_GREEN, LIGHT_GREEN, LIGHT_BLUE, DARK_GREY, PURPLE, RED, ORANGE,
CYAN, LIGHT_GREEN, PINK, LIGHT_GREEN, LIGHT_GREEN, LIGHT_BLUE, DARK_GREY, PURPLE, RED, ORANGE
};
// Pointers to the screen address for rendering each playfield line
// The lines for screen 1 is aligned with $80 and screen 2 with $40 - so XOR'ing with $40 gives screen 2 lines.
align($80) byte*[PLAYFIELD_LINES] screen_lines_1;
align($40) byte*[PLAYFIELD_LINES] screen_lines_2;
// The lines for screen 1 is aligned with 0x80 and screen 2 with 0x40 - so XOR'ing with 0x40 gives screen 2 lines.
align(0x80) char*[PLAYFIELD_LINES] screen_lines_1;
align(0x40) char*[PLAYFIELD_LINES] screen_lines_2;
// Initialize rendering
void render_init() {
@ -60,9 +60,9 @@ void render_init() {
render_screen_original(PLAYFIELD_SCREEN_2);
// Initialize the screen line pointers;
byte* li_1 = PLAYFIELD_SCREEN_1 + 2*40 + 16;
byte* li_2 = PLAYFIELD_SCREEN_2 + 2*40 + 16;
for(byte i:0..PLAYFIELD_LINES-1) {
char* li_1 = PLAYFIELD_SCREEN_1 + 2*40 + 16;
char* li_2 = PLAYFIELD_SCREEN_2 + 2*40 + 16;
for(char i:0..PLAYFIELD_LINES-1) {
screen_lines_1[i] = li_1;
screen_lines_2[i] = li_2;
li_1 += 40;
@ -71,12 +71,12 @@ void render_init() {
// Show showing screen 1 and rendering to screen 2
render_screen_show = 0;
render_screen_render = $20;
render_screen_render = 0x20;
}
// Update $D018 to show the current screen (used for double buffering)
// Update 0xD018 to show the current screen (used for double buffering)
void render_show() {
byte d018val = 0;
char d018val = 0;
if(render_screen_show==0) {
d018val = toD018(PLAYFIELD_SCREEN_1, PLAYFIELD_CHARSET);
} else {
@ -90,30 +90,30 @@ void render_show() {
// Swap rendering to the other screen (used for double buffering)
void render_screen_swap() {
render_screen_render ^= $20;
render_screen_show ^= $20;
render_screen_render ^= 0x20;
render_screen_show ^= 0x20;
}
// Show the current score
void render_score() {
byte* screen;
char* screen;
if(render_screen_render==0) {
screen = PLAYFIELD_SCREEN_1;
} else {
screen = PLAYFIELD_SCREEN_2;
}
byte* score_bytes = (byte*)(&score_bcd);
word score_offset = 40*$05 + $1c;
char* score_bytes = (byte*)(&score_bcd);
unsigned int score_offset = 40*0x05 + 0x1c;
render_bcd( screen, score_offset, score_bytes[2], 0);
render_bcd( screen, score_offset+2, score_bytes[1], 0);
render_bcd( screen, score_offset+4, score_bytes[0], 0);
word lines_offset = 40*$01 + $16;
unsigned int lines_offset = 40*0x01 + 0x16;
render_bcd( screen, lines_offset, >lines_bcd, 1);
render_bcd( screen, lines_offset+1, <lines_bcd, 0);
word level_offset = 40*19 + $1f;
unsigned int level_offset = 40*19 + 0x1f;
render_bcd( screen, level_offset, level_bcd, 0);
}
@ -123,24 +123,24 @@ void render_score() {
// - offset: offset on the screen
// - bcd: The BCD-value to render
// - only_low: if non-zero only renders the low digit
void render_bcd(byte* screen, word offset, byte bcd, byte only_low) {
const byte ZERO_CHAR = 53;
byte* screen_pos = screen+offset;
void render_bcd(char* screen, unsigned int offset, char bcd, char only_low) {
const char ZERO_CHAR = 53;
char* screen_pos = screen+offset;
if(only_low==0) {
*screen_pos++ = ZERO_CHAR + (bcd >> 4);
}
*screen_pos++ = ZERO_CHAR + (bcd & $0f);
*screen_pos++ = ZERO_CHAR + (bcd & 0x0f);
}
// Copy the original screen data to the passed screen
// Also copies colors to $d800
void render_screen_original(byte* screen) {
byte SPACE = 0;
byte* oscr = PLAYFIELD_SCREEN_ORIGINAL+32*2;
byte* ocols = PLAYFIELD_COLORS_ORIGINAL+32*2;
byte* cols = COLS;
for(byte y:0..24) {
byte x=0;
// Also copies colors to 0xd800
void render_screen_original(char* screen) {
char SPACE = 0;
char* oscr = PLAYFIELD_SCREEN_ORIGINAL+32*2;
char* ocols = PLAYFIELD_COLORS_ORIGINAL+32*2;
char* cols = COLS;
for(char y:0..24) {
char x=0;
do {
*screen++ = SPACE;
*cols++ = BLACK;
@ -159,10 +159,10 @@ void render_screen_original(byte* screen) {
// Render the static playfield on the screen (all pieces already locked into place)
void render_playfield() {
// Do not render the top 2 lines.
byte i = PLAYFIELD_COLS*2;
for(byte l:2..PLAYFIELD_LINES-1) {
byte* screen_line = screen_lines_1[render_screen_render+l];
for(byte c:0..PLAYFIELD_COLS-1) {
char i = PLAYFIELD_COLS*2;
for(char l:2..PLAYFIELD_LINES-1) {
char* screen_line = screen_lines_1[render_screen_render+l];
for(char c:0..PLAYFIELD_COLS-1) {
*(screen_line++) = playfield[i++];
}
}
@ -171,14 +171,14 @@ void render_playfield() {
// Render the current moving piece at position (current_xpos, current_ypos)
// Ignores cases where parts of the tetromino is outside the playfield (sides/bottom) since the movement collision routine prevents this.
void render_moving() {
byte i = 0;
byte ypos = current_ypos;
for(byte l:0..3) {
char i = 0;
char ypos = current_ypos;
for(char l:0..3) {
if(ypos>1) {
byte* screen_line = screen_lines_1[render_screen_render+ypos];
byte xpos = current_xpos;
for(byte c:0..3) {
byte current_cell = current_piece_gfx[i++];
char* screen_line = screen_lines_1[render_screen_render+ypos];
char xpos = current_xpos;
for(char c:0..3) {
char current_cell = current_piece_gfx[i++];
if(current_cell!=0) {
screen_line[xpos] = current_piece_char;
}
@ -195,8 +195,8 @@ void render_moving() {
void render_next() {
// Find the screen area
word next_area_offset = 40*12 + 24 + 4;
byte* screen_next_area;
unsigned int next_area_offset = 40*12 + 24 + 4;
char* screen_next_area;
if(render_screen_render==0) {
screen_next_area = PLAYFIELD_SCREEN_1+next_area_offset;
} else {
@ -204,11 +204,11 @@ void render_next() {
}
// Render the next piece
byte* next_piece_gfx = PIECES[next_piece_idx];
byte next_piece_char = PIECES_NEXT_CHARS[next_piece_idx];
for(byte l:0..3) {
for(byte c:0..3) {
byte cell = *next_piece_gfx++;
char* next_piece_gfx = PIECES[next_piece_idx];
char next_piece_char = PIECES_NEXT_CHARS[next_piece_idx];
for(char l:0..3) {
for(char c:0..3) {
char cell = *next_piece_gfx++;
if(cell!=0) {
*screen_next_area = next_piece_char;
} else {

View File

@ -24,9 +24,9 @@ kickasm(pc PLAYFIELD_SPRITES, resource "playfield-sprites.png") {{
void sprites_init() {
*SPRITES_ENABLE = %00001111;
*SPRITES_EXPAND_X = *SPRITES_EXPAND_Y = *SPRITES_MC = 0;
byte xpos = 24+15*8;
for(byte s:0..3) {
byte s2 = s*2;
char xpos = 24+15*8;
for(char s:0..3) {
char s2 = s*2;
SPRITES_XPOS[s2] = xpos;
SPRITES_COLS[s] = BLACK;
xpos = xpos+24;
@ -34,17 +34,17 @@ void sprites_init() {
}
// The Y-position of the first sprite row
const byte SPRITES_FIRST_YPOS = 49;
const char SPRITES_FIRST_YPOS = 49;
// The line of the first IRQ
const byte IRQ_RASTER_FIRST = SPRITES_FIRST_YPOS + 19;
const char IRQ_RASTER_FIRST = SPRITES_FIRST_YPOS + 19;
// The raster line of the next IRQ
volatile byte irq_raster_next = IRQ_RASTER_FIRST;
volatile char irq_raster_next = IRQ_RASTER_FIRST;
// Y-pos of the sprites on the next IRQ
volatile byte irq_sprite_ypos = SPRITES_FIRST_YPOS + 21;
volatile char irq_sprite_ypos = SPRITES_FIRST_YPOS + 21;
// Index of the sprites to show on the next IRQ
volatile byte irq_sprite_ptr = toSpritePtr(PLAYFIELD_SPRITES) + 3;
volatile char irq_sprite_ptr = toSpritePtr(PLAYFIELD_SPRITES) + 3;
// Counting the 10 IRQs
volatile byte irq_cnt = 0;
volatile char irq_cnt = 0;
// Setup the IRQ
void sprites_irq_init() {
@ -59,7 +59,7 @@ void sprites_irq_init() {
// Disable CIA 1 Timer IRQ
*CIA1_INTERRUPT = CIA_INTERRUPT_CLEAR;
// Set raster line
*VIC_CONTROL &=$7f;
*VIC_CONTROL &=0x7f;
*RASTER = IRQ_RASTER_FIRST;
// Enable Raster Interrupt
*IRQ_ENABLE = IRQ_RASTER;
@ -77,18 +77,18 @@ interrupt(hardware_clobber) void sprites_irq() {
// Clear decimal flag (because it is used by the score algorithm)
asm { cld }
// Place the sprites
byte ypos = irq_sprite_ypos;
char ypos = irq_sprite_ypos;
SPRITES_YPOS[0] = ypos;
SPRITES_YPOS[2] = ypos;
SPRITES_YPOS[4] = ypos;
SPRITES_YPOS[6] = ypos;
// Wait for the y-position before changing sprite pointers
volatile byte raster_sprite_gfx_modify = irq_raster_next+1;
volatile char raster_sprite_gfx_modify = irq_raster_next+1;
do {
} while(*RASTER<raster_sprite_gfx_modify);
byte ptr = irq_sprite_ptr;
char ptr = irq_sprite_ptr;
if(render_screen_showing==0) {
PLAYFIELD_SPRITE_PTRS_1[0] = ptr++;
PLAYFIELD_SPRITE_PTRS_1[1] = ptr;

View File

@ -25,14 +25,14 @@ void main() {
render_next();
while(true) {
// Wait for a frame to pass
while(*RASTER!=$ff) {}
//*BORDERCOL = render_screen_show/$10;
while(*RASTER!=0xff) {}
//*BORDERCOL = render_screen_show/0x10;
// Update D018 to show the selected screen
render_show();
// Scan keyboard events
keyboard_event_scan();
byte key_event = keyboard_event_get();
byte render = 0;
char key_event = keyboard_event_get();
char render = 0;
if(game_over==0) {
render = play_movement(key_event);
} else {

View File

@ -4030,7 +4030,7 @@ main: {
lax.z ypos
axs #-[$18]
stx.z ypos
// for(byte s:4..7)
// for(char s:4..7)
// [30] (byte) main::s#1 ← ++ (byte) main::s#2 -- vbuyy=_inc_vbuyy
iny
// [31] if((byte) main::s#1!=(byte) 8) goto main::@1 -- vbuyy_neq_vbuc1_then_la1
@ -4094,7 +4094,7 @@ loop: {
// [44] (byte) loop::idx#1 ← (byte) loop::idx#2 + (byte) $a -- vbuxx=vbuxx_plus_vbuc1
txa
axs #-[$a]
// for(byte s:4..7)
// for(char s:4..7)
// [45] (byte) loop::s#1 ← ++ (byte) loop::s#2 -- vbuz1=_inc_vbuz1
inc.z s
// [46] if((byte) loop::s#1!=(byte) 8) goto loop::@4 -- vbuz1_neq_vbuc1_then_la1
@ -4214,7 +4214,7 @@ sprites_init: {
lax.z xpos
axs #-[$18]
stx.z xpos
// for(byte s:0..3)
// for(char s:0..3)
// [69] (byte) sprites_init::s#1 ← ++ (byte) sprites_init::s#2 -- vbuyy=_inc_vbuyy
iny
// [70] if((byte) sprites_init::s#1!=(byte) 4) goto sprites_init::@1 -- vbuyy_neq_vbuc1_then_la1

View File

@ -146,7 +146,7 @@
.label current_piece_gfx_1 = $24
.label current_piece_char_1 = $f
__b1:
// The screen currently being showed to the user. $00 for screen 1 / $20 for screen 2.
// The screen currently being showed to the user. 0x00 for screen 1 / 0x20 for screen 2.
lda #0
sta.z render_screen_showing
// Current score in BCD-format
@ -551,7 +551,7 @@ render_playfield: {
rts
}
// Perform any movement of the current piece
// key_event is the next keyboard_event() og $ff if no keyboard event is pending
// key_event is the next keyboard_event() og 0xff if no keyboard event is pending
// Returns a byte signaling whether rendering is needed. (0 no render, >0 render needed)
// play_movement(byte zeropage($20) key_event)
play_movement: {
@ -948,7 +948,7 @@ play_increase_level: {
and.z level_bcd
cmp #$a
bne __b2
// If level low nybble hits $a change to $10
// If level low nybble hits 0xa change to 0x10
lax.z level_bcd
axs #-[6]
stx.z level_bcd
@ -1224,7 +1224,7 @@ keyboard_matrix_read: {
eor #$ff
rts
}
// Update $D018 to show the current screen (used for double buffering)
// Update 0xD018 to show the current screen (used for double buffering)
render_show: {
.const toD0181_return = (>(PLAYFIELD_SCREEN_1&$3fff)*4)|(>PLAYFIELD_CHARSET)/4&$f
.const toD0182_return = (>(PLAYFIELD_SCREEN_2&$3fff)*4)|(>PLAYFIELD_CHARSET)/4&$f
@ -1437,7 +1437,7 @@ render_init: {
rts
}
// Copy the original screen data to the passed screen
// Also copies colors to $d800
// Also copies colors to 0xd800
// render_screen_original(byte* zeropage($24) screen)
render_screen_original: {
.const SPACE = 0
@ -1683,7 +1683,7 @@ sprites_irq: {
// These values are updated based on the players level and the base values from SCORE_BASE_BCD
score_add_bcd: .fill 4*5, 0
// Pointers to the screen address for rendering each playfield line
// The lines for screen 1 is aligned with $80 and screen 2 with $40 - so XOR'ing with $40 gives screen 2 lines.
// The lines for screen 1 is aligned with 0x80 and screen 2 with 0x40 - so XOR'ing with 0x40 gives screen 2 lines.
.align $80
screen_lines_1: .fill 2*PLAYFIELD_LINES, 0
.align $40

View File

@ -13792,7 +13792,7 @@ __bbegin:
// @1
__b1:
// [1] (byte) render_screen_showing#0 ← (byte) 0 -- vbuz1=vbuc1
// The screen currently being showed to the user. $00 for screen 1 / $20 for screen 2.
// The screen currently being showed to the user. 0x00 for screen 1 / 0x20 for screen 2.
lda #0
sta.z render_screen_showing
// [2] (dword) score_bcd#0 ← (byte) 0 -- vduz1=vbuc1
@ -14847,7 +14847,7 @@ render_playfield: {
}
// play_movement
// Perform any movement of the current piece
// key_event is the next keyboard_event() og $ff if no keyboard event is pending
// key_event is the next keyboard_event() og 0xff if no keyboard event is pending
// Returns a byte signaling whether rendering is needed. (0 no render, >0 render needed)
// play_movement(byte zeropage($7c) key_event)
play_movement: {
@ -15907,7 +15907,7 @@ play_increase_level: {
// play_increase_level::@4
__b4:
// [330] (byte) level_bcd#8 ← (byte) level_bcd#21 + (byte) 6 -- vbuz1=vbuz1_plus_vbuc1
// If level low nybble hits $a change to $10
// If level low nybble hits 0xa change to 0x10
lax.z level_bcd
axs #-[6]
stx.z level_bcd
@ -16648,7 +16648,7 @@ keyboard_matrix_read: {
rts
}
// render_show
// Update $D018 to show the current screen (used for double buffering)
// Update 0xD018 to show the current screen (used for double buffering)
render_show: {
.const toD0181_return = (>(PLAYFIELD_SCREEN_1&$3fff)*4)|(>PLAYFIELD_CHARSET)/4&$f
.const toD0182_return = (>(PLAYFIELD_SCREEN_2&$3fff)*4)|(>PLAYFIELD_CHARSET)/4&$f
@ -17064,7 +17064,7 @@ render_init: {
}
// render_screen_original
// Copy the original screen data to the passed screen
// Also copies colors to $d800
// Also copies colors to 0xd800
// render_screen_original(byte* zeropage($70) screen)
render_screen_original: {
.const SPACE = 0
@ -17514,7 +17514,7 @@ sprites_irq: {
// These values are updated based on the players level and the base values from SCORE_BASE_BCD
score_add_bcd: .fill 4*5, 0
// Pointers to the screen address for rendering each playfield line
// The lines for screen 1 is aligned with $80 and screen 2 with $40 - so XOR'ing with $40 gives screen 2 lines.
// The lines for screen 1 is aligned with 0x80 and screen 2 with 0x40 - so XOR'ing with 0x40 gives screen 2 lines.
.align $80
screen_lines_1: .fill 2*PLAYFIELD_LINES, 0
.align $40
@ -18904,7 +18904,7 @@ __bbegin:
// @1
__b1:
// [1] (byte) render_screen_showing#0 ← (byte) 0 -- vbuz1=vbuc1
// The screen currently being showed to the user. $00 for screen 1 / $20 for screen 2.
// The screen currently being showed to the user. 0x00 for screen 1 / 0x20 for screen 2.
lda #0
sta.z render_screen_showing
// [2] (dword) score_bcd#0 ← (byte) 0 -- vduz1=vbuc1
@ -19866,7 +19866,7 @@ render_playfield: {
}
// play_movement
// Perform any movement of the current piece
// key_event is the next keyboard_event() og $ff if no keyboard event is pending
// key_event is the next keyboard_event() og 0xff if no keyboard event is pending
// Returns a byte signaling whether rendering is needed. (0 no render, >0 render needed)
// play_movement(byte zeropage($20) key_event)
play_movement: {
@ -20785,7 +20785,7 @@ play_increase_level: {
// play_increase_level::@4
__b4:
// [330] (byte) level_bcd#8 ← (byte) level_bcd#21 + (byte) 6 -- vbuz1=vbuz1_plus_vbuc1
// If level low nybble hits $a change to $10
// If level low nybble hits 0xa change to 0x10
lax.z level_bcd
axs #-[6]
stx.z level_bcd
@ -21441,7 +21441,7 @@ keyboard_matrix_read: {
rts
}
// render_show
// Update $D018 to show the current screen (used for double buffering)
// Update 0xD018 to show the current screen (used for double buffering)
render_show: {
.const toD0181_return = (>(PLAYFIELD_SCREEN_1&$3fff)*4)|(>PLAYFIELD_CHARSET)/4&$f
.const toD0182_return = (>(PLAYFIELD_SCREEN_2&$3fff)*4)|(>PLAYFIELD_CHARSET)/4&$f
@ -21830,7 +21830,7 @@ render_init: {
}
// render_screen_original
// Copy the original screen data to the passed screen
// Also copies colors to $d800
// Also copies colors to 0xd800
// render_screen_original(byte* zeropage($24) screen)
render_screen_original: {
.const SPACE = 0
@ -22244,7 +22244,7 @@ sprites_irq: {
// These values are updated based on the players level and the base values from SCORE_BASE_BCD
score_add_bcd: .fill 4*5, 0
// Pointers to the screen address for rendering each playfield line
// The lines for screen 1 is aligned with $80 and screen 2 with $40 - so XOR'ing with $40 gives screen 2 lines.
// The lines for screen 1 is aligned with 0x80 and screen 2 with 0x40 - so XOR'ing with 0x40 gives screen 2 lines.
.align $80
screen_lines_1: .fill 2*PLAYFIELD_LINES, 0
.align $40
@ -24178,7 +24178,7 @@ Score: 3353851
__b1:
// render_screen_showing = 0
// [1] (byte) render_screen_showing#0 ← (byte) 0 -- vbuz1=vbuc1
// The screen currently being showed to the user. $00 for screen 1 / $20 for screen 2.
// The screen currently being showed to the user. 0x00 for screen 1 / 0x20 for screen 2.
lda #0
sta.z render_screen_showing
// score_bcd = 0
@ -24386,7 +24386,7 @@ main: {
// Wait for a frame to pass
// main::@2
__b2:
// while(*RASTER!=$ff)
// while(*RASTER!=0xff)
// [41] if(*((const byte*) RASTER)!=(byte) $ff) goto main::@2 -- _deref_pbuc1_neq_vbuc2_then_la1
lda #$ff
cmp RASTER
@ -24499,12 +24499,12 @@ main: {
// render_screen_swap
// Swap rendering to the other screen (used for double buffering)
render_screen_swap: {
// render_screen_render ^= $20
// render_screen_render ^= 0x20
// [72] (byte) render_screen_render#11 ← (byte) render_screen_render#18 ^ (byte) $20 -- vbuz1=vbuz1_bxor_vbuc1
lda #$20
eor.z render_screen_render
sta.z render_screen_render
// render_screen_show ^= $20
// render_screen_show ^= 0x20
// [73] (byte) render_screen_show#13 ← (byte) render_screen_show#16 ^ (byte) $20 -- vbuz1=vbuz1_bxor_vbuc1
lda #$20
eor.z render_screen_show
@ -24704,15 +24704,15 @@ render_bcd: {
// [104] phi (byte*) render_bcd::screen_pos#3 = (byte*) render_bcd::screen_pos#0 [phi:render_bcd/render_bcd::@2->render_bcd::@1#0] -- register_copy
// render_bcd::@1
__b1:
// bcd & $0f
// bcd & 0x0f
// [105] (byte~) render_bcd::$3 ← (byte) render_bcd::bcd#6 & (byte) $f -- vbuaa=vbuxx_band_vbuc1
txa
and #$f
// ZERO_CHAR + (bcd & $0f)
// ZERO_CHAR + (bcd & 0x0f)
// [106] (byte~) render_bcd::$4 ← (const byte) render_bcd::ZERO_CHAR + (byte~) render_bcd::$3 -- vbuaa=vbuc1_plus_vbuaa
clc
adc #ZERO_CHAR
// *screen_pos++ = ZERO_CHAR + (bcd & $0f)
// *screen_pos++ = ZERO_CHAR + (bcd & 0x0f)
// [107] *((byte*) render_bcd::screen_pos#3) ← (byte~) render_bcd::$4 -- _deref_pbuz1=vbuaa
ldy #0
sta (screen_pos),y
@ -24816,7 +24816,7 @@ render_next: {
bne !+
inc.z screen_next_area+1
!:
// for(byte c:0..3)
// for(char c:0..3)
// [123] (byte) render_next::c#1 ← ++ (byte) render_next::c#2 -- vbuxx=_inc_vbuxx
inx
// [124] if((byte) render_next::c#1!=(byte) 4) goto render_next::@4 -- vbuxx_neq_vbuc1_then_la1
@ -24832,7 +24832,7 @@ render_next: {
bcc !+
inc.z screen_next_area+1
!:
// for(byte l:0..3)
// for(char l:0..3)
// [126] (byte) render_next::l#1 ← ++ (byte) render_next::l#7 -- vbuz1=_inc_vbuz1
inc.z l
// [127] if((byte) render_next::l#1!=(byte) 4) goto render_next::@3 -- vbuz1_neq_vbuc1_then_la1
@ -24895,7 +24895,7 @@ render_moving: {
// ypos++;
// [136] (byte) render_moving::ypos#1 ← ++ (byte) render_moving::ypos#2 -- vbuz1=_inc_vbuz1
inc.z ypos
// for(byte l:0..3)
// for(char l:0..3)
// [137] (byte) render_moving::l#1 ← ++ (byte) render_moving::l#4 -- vbuz1=_inc_vbuz1
inc.z l
// [138] if((byte) render_moving::l#1!=(byte) 4) goto render_moving::@1 -- vbuz1_neq_vbuc1_then_la1
@ -24958,7 +24958,7 @@ render_moving: {
// xpos++;
// [149] (byte) render_moving::xpos#1 ← ++ (byte) render_moving::xpos#2 -- vbuz1=_inc_vbuz1
inc.z xpos
// for(byte c:0..3)
// for(char c:0..3)
// [150] (byte) render_moving::c#1 ← ++ (byte) render_moving::c#2 -- vbuxx=_inc_vbuxx
inx
// [151] if((byte) render_moving::c#1!=(byte) 4) goto render_moving::@4 -- vbuxx_neq_vbuc1_then_la1
@ -25025,7 +25025,7 @@ render_playfield: {
!:
// [160] (byte) render_playfield::i#1 ← ++ (byte) render_playfield::i#2 -- vbuz1=_inc_vbuz1
inc.z i
// for(byte c:0..PLAYFIELD_COLS-1)
// for(char c:0..PLAYFIELD_COLS-1)
// [161] (byte) render_playfield::c#1 ← ++ (byte) render_playfield::c#2 -- vbuz1=_inc_vbuz1
inc.z c
// [162] if((byte) render_playfield::c#1!=(const byte) PLAYFIELD_COLS-(byte) 1+(byte) 1) goto render_playfield::@2 -- vbuz1_neq_vbuc1_then_la1
@ -25033,7 +25033,7 @@ render_playfield: {
cmp.z c
bne __b2
// render_playfield::@3
// for(byte l:2..PLAYFIELD_LINES-1)
// for(char l:2..PLAYFIELD_LINES-1)
// [163] (byte) render_playfield::l#1 ← ++ (byte) render_playfield::l#2 -- vbuz1=_inc_vbuz1
inc.z l
// [164] if((byte) render_playfield::l#1!=(const byte) PLAYFIELD_LINES-(byte) 1+(byte) 1) goto render_playfield::@1 -- vbuz1_neq_vbuc1_then_la1
@ -25047,7 +25047,7 @@ render_playfield: {
}
// play_movement
// Perform any movement of the current piece
// key_event is the next keyboard_event() og $ff if no keyboard event is pending
// key_event is the next keyboard_event() og 0xff if no keyboard event is pending
// Returns a byte signaling whether rendering is needed. (0 no render, >0 render needed)
// play_movement(byte zeropage($20) key_event)
play_movement: {
@ -25136,11 +25136,11 @@ play_move_rotate: {
rts
// play_move_rotate::@2
__b2:
// current_orientation+$10
// current_orientation+0x10
// [187] (byte~) play_move_rotate::$5 ← (byte) current_orientation#20 + (byte) $10 -- vbuxx=vbuz1_plus_vbuc1
lax.z current_orientation
axs #-[$10]
// orientation = (current_orientation+$10)&$3f
// orientation = (current_orientation+0x10)&0x3f
// [188] (byte) play_move_rotate::orientation#2 ← (byte~) play_move_rotate::$5 & (byte) $3f -- vbuz1=vbuxx_band_vbuc1
lda #$3f
sax.z orientation
@ -25199,11 +25199,11 @@ play_move_rotate: {
rts
// play_move_rotate::@1
__b1:
// current_orientation-$10
// current_orientation-0x10
// [200] (byte~) play_move_rotate::$7 ← (byte) current_orientation#20 - (byte) $10 -- vbuxx=vbuz1_minus_vbuc1
lax.z current_orientation
axs #$10
// orientation = (current_orientation-$10)&$3f
// orientation = (current_orientation-0x10)&0x3f
// [201] (byte) play_move_rotate::orientation#1 ← (byte~) play_move_rotate::$7 & (byte) $3f -- vbuz1=vbuxx_band_vbuc1
lda #$3f
sax.z orientation
@ -25283,11 +25283,11 @@ play_collision: {
rts
// play_collision::@4
__b4:
// xp&$80
// xp&0x80
// [212] (byte~) play_collision::$5 ← (byte) play_collision::xp#2 & (byte) $80 -- vbuaa=vbuz1_band_vbuc1
lda #$80
and.z xp
// if((xp&$80)!=0)
// if((xp&0x80)!=0)
// [213] if((byte~) play_collision::$5==(byte) 0) goto play_collision::@5 -- vbuaa_eq_0_then_la1
cmp #0
beq __b5
@ -25326,7 +25326,7 @@ play_collision: {
// xp++;
// [218] (byte) play_collision::xp#1 ← ++ (byte) play_collision::xp#2 -- vbuz1=_inc_vbuz1
inc.z xp
// for(byte c:0..3)
// for(char c:0..3)
// [219] (byte) play_collision::c#1 ← ++ (byte) play_collision::c#2 -- vbuxx=_inc_vbuxx
inx
// [220] if((byte) play_collision::c#1!=(byte) 4) goto play_collision::@10 -- vbuxx_neq_vbuc1_then_la1
@ -25336,7 +25336,7 @@ play_collision: {
// yp++;
// [221] (byte) play_collision::yp#1 ← ++ (byte) play_collision::yp#2 -- vbuz1=_inc_vbuz1
inc.z yp
// for(byte l:0..3)
// for(char l:0..3)
// [222] (byte) play_collision::l#1 ← ++ (byte) play_collision::l#6 -- vbuz1=_inc_vbuz1
inc.z l
// [223] if((byte) play_collision::l#1!=(byte) 4) goto play_collision::@9 -- vbuz1_neq_vbuc1_then_la1
@ -25808,7 +25808,7 @@ play_update_score: {
// <lines_bcd
// [308] (byte~) play_update_score::$2 ← < (word) lines_bcd#19 -- vbuaa=_lo_vwuz1
lda.z lines_bcd
// lines_before = <lines_bcd&$f0
// lines_before = <lines_bcd&0xf0
// [309] (byte) play_update_score::lines_before#0 ← (byte~) play_update_score::$2 & (byte) $f0 -- vbuz1=vbuaa_band_vbuc1
and #$f0
sta.z lines_before
@ -25860,7 +25860,7 @@ play_update_score: {
// <lines_bcd
// [316] (byte~) play_update_score::$4 ← < (word) lines_bcd#29 -- vbuaa=_lo_vwuz1
lda.z lines_bcd
// lines_after = <lines_bcd&$f0
// lines_after = <lines_bcd&0xf0
// [317] (byte) play_update_score::lines_after#0 ← (byte~) play_update_score::$4 & (byte) $f0 -- vbuaa=vbuaa_band_vbuc1
and #$f0
// if(lines_before!=lines_after)
@ -25915,18 +25915,18 @@ play_increase_level: {
// level_bcd++;
// [327] (byte) level_bcd#21 ← ++ (byte) level_bcd#11 -- vbuz1=_inc_vbuz1
inc.z level_bcd
// level_bcd&$f
// level_bcd&0xf
// [328] (byte~) play_increase_level::$1 ← (byte) level_bcd#21 & (byte) $f -- vbuaa=vbuz1_band_vbuc1
lda #$f
and.z level_bcd
// if((level_bcd&$f)==$a)
// if((level_bcd&0xf)==0xa)
// [329] if((byte~) play_increase_level::$1!=(byte) $a) goto play_increase_level::@2 -- vbuaa_neq_vbuc1_then_la1
cmp #$a
bne __b2
// play_increase_level::@4
// level_bcd += 6
// [330] (byte) level_bcd#8 ← (byte) level_bcd#21 + (byte) 6 -- vbuz1=vbuz1_plus_vbuc1
// If level low nybble hits $a change to $10
// If level low nybble hits 0xa change to 0x10
lax.z level_bcd
axs #-[6]
stx.z level_bcd
@ -25965,7 +25965,7 @@ play_increase_level: {
lda score_add_bcd+3,y
adc SCORE_BASE_BCD+3,y
sta score_add_bcd+3,y
// for(byte b: 0..4)
// for(char b: 0..4)
// [336] (byte) play_increase_level::b#1 ← ++ (byte) play_increase_level::b#2 -- vbuxx=_inc_vbuxx
inx
// [337] if((byte) play_increase_level::b#1!=(byte) 5) goto play_increase_level::@5 -- vbuxx_neq_vbuc1_then_la1
@ -26052,7 +26052,7 @@ play_remove_lines: {
// playfield[w--] = c;
// [349] (byte) play_remove_lines::w#1 ← -- (byte) play_remove_lines::w#4 -- vbuxx=_dec_vbuxx
dex
// for(byte x:0..PLAYFIELD_COLS-1)
// for(char x:0..PLAYFIELD_COLS-1)
// [350] (byte) play_remove_lines::x#1 ← ++ (byte) play_remove_lines::x#2 -- vbuz1=_inc_vbuz1
inc.z x
// [351] if((byte) play_remove_lines::x#1!=(const byte) PLAYFIELD_COLS-(byte) 1+(byte) 1) goto play_remove_lines::@2 -- vbuz1_neq_vbuc1_then_la1
@ -26078,7 +26078,7 @@ play_remove_lines: {
// [355] phi (byte) play_remove_lines::w#11 = (byte) play_remove_lines::w#1 [phi:play_remove_lines::@4/play_remove_lines::@5->play_remove_lines::@6#1] -- register_copy
// play_remove_lines::@6
__b6:
// for(byte y:0..PLAYFIELD_LINES-1)
// for(char y:0..PLAYFIELD_LINES-1)
// [356] (byte) play_remove_lines::y#1 ← ++ (byte) play_remove_lines::y#8 -- vbuz1=_inc_vbuz1
inc.z y
// [357] if((byte) play_remove_lines::y#1!=(const byte) PLAYFIELD_LINES-(byte) 1+(byte) 1) goto play_remove_lines::@1 -- vbuz1_neq_vbuc1_then_la1
@ -26090,7 +26090,7 @@ play_remove_lines: {
// [358] phi (byte) play_remove_lines::w#6 = (byte) play_remove_lines::w#11 [phi:play_remove_lines::@6/play_remove_lines::@8->play_remove_lines::@7#0] -- register_copy
// Write zeros in the rest of the lines
// play_remove_lines::@7
// while(w!=$ff)
// while(w!=0xff)
// [359] if((byte) play_remove_lines::w#6!=(byte) $ff) goto play_remove_lines::@8 -- vbuxx_neq_vbuc1_then_la1
cpx #$ff
bne __b8
@ -26171,7 +26171,7 @@ play_lock_current: {
// xp++;
// [372] (byte) play_lock_current::xp#1 ← ++ (byte) play_lock_current::xp#2 -- vbuz1=_inc_vbuz1
inc.z xp
// for(byte c:0..3)
// for(char c:0..3)
// [373] (byte) play_lock_current::c#1 ← ++ (byte) play_lock_current::c#2 -- vbuxx=_inc_vbuxx
inx
// [374] if((byte) play_lock_current::c#1!=(byte) 4) goto play_lock_current::@7 -- vbuxx_neq_vbuc1_then_la1
@ -26181,7 +26181,7 @@ play_lock_current: {
// yp++;
// [375] (byte) play_lock_current::yp#1 ← ++ (byte) play_lock_current::yp#2 -- vbuz1=_inc_vbuz1
inc.z yp
// for(byte l:0..3)
// for(char l:0..3)
// [376] (byte) play_lock_current::l#1 ← ++ (byte) play_lock_current::l#6 -- vbuz1=_inc_vbuz1
inc.z l
// [377] if((byte) play_lock_current::l#1!=(byte) 4) goto play_lock_current::@6 -- vbuz1_neq_vbuc1_then_la1
@ -26516,7 +26516,7 @@ keyboard_matrix_read: {
rts
}
// render_show
// Update $D018 to show the current screen (used for double buffering)
// Update 0xD018 to show the current screen (used for double buffering)
render_show: {
.const toD0181_return = (>(PLAYFIELD_SCREEN_1&$3fff)*4)|(>PLAYFIELD_CHARSET)/4&$f
.const toD0182_return = (>(PLAYFIELD_SCREEN_2&$3fff)*4)|(>PLAYFIELD_CHARSET)/4&$f
@ -26610,7 +26610,7 @@ play_init: {
lax.z idx
axs #-[PLAYFIELD_COLS]
stx.z idx
// for(byte j:0..PLAYFIELD_LINES-1)
// for(char j:0..PLAYFIELD_LINES-1)
// [464] (byte) play_init::j#1 ← ++ (byte) play_init::j#2 -- vbuyy=_inc_vbuyy
iny
// [465] if((byte) play_init::j#1!=(const byte) PLAYFIELD_LINES-(byte) 1+(byte) 1) goto play_init::@1 -- vbuyy_neq_vbuc1_then_la1
@ -26649,7 +26649,7 @@ play_init: {
sta score_add_bcd+2,y
lda SCORE_BASE_BCD+3,y
sta score_add_bcd+3,y
// for(byte b: 0..4)
// for(char b: 0..4)
// [471] (byte) play_init::b#1 ← ++ (byte) play_init::b#2 -- vbuxx=_inc_vbuxx
inx
// [472] if((byte) play_init::b#1!=(byte) 5) goto play_init::@3 -- vbuxx_neq_vbuc1_then_la1
@ -26688,7 +26688,7 @@ sprites_irq_init: {
// Disable CIA 1 Timer IRQ
lda #CIA_INTERRUPT_CLEAR
sta CIA1_INTERRUPT
// *VIC_CONTROL &=$7f
// *VIC_CONTROL &=0x7f
// [480] *((const byte*) VIC_CONTROL) ← *((const byte*) VIC_CONTROL) & (byte) $7f -- _deref_pbuc1=_deref_pbuc1_band_vbuc2
// Set raster line
lda #$7f
@ -26765,7 +26765,7 @@ sprites_init: {
lax.z xpos
axs #-[$18]
stx.z xpos
// for(byte s:0..3)
// for(char s:0..3)
// [495] (byte) sprites_init::s#1 ← ++ (byte) sprites_init::s#2 -- vbuyy=_inc_vbuyy
iny
// [496] if((byte) sprites_init::s#1!=(byte) 4) goto sprites_init::@1 -- vbuyy_neq_vbuc1_then_la1
@ -26892,7 +26892,7 @@ render_init: {
bcc !+
inc.z li_2+1
!:
// for(byte i:0..PLAYFIELD_LINES-1)
// for(char i:0..PLAYFIELD_LINES-1)
// [517] (byte) render_init::i#1 ← ++ (byte) render_init::i#2 -- vbuyy=_inc_vbuyy
iny
// [518] if((byte) render_init::i#1!=(const byte) PLAYFIELD_LINES-(byte) 1+(byte) 1) goto render_init::@1 -- vbuyy_neq_vbuc1_then_la1
@ -26905,7 +26905,7 @@ render_init: {
}
// render_screen_original
// Copy the original screen data to the passed screen
// Also copies colors to $d800
// Also copies colors to 0xd800
// render_screen_original(byte* zeropage($24) screen)
render_screen_original: {
.const SPACE = 0
@ -27062,7 +27062,7 @@ render_screen_original: {
cpx #$28
bne __b4
// render_screen_original::@5
// for(byte y:0..24)
// for(char y:0..24)
// [545] (byte) render_screen_original::y#1 ← ++ (byte) render_screen_original::y#6 -- vbuz1=_inc_vbuz1
inc.z y
// [546] if((byte) render_screen_original::y#1!=(byte) $19) goto render_screen_original::@1 -- vbuz1_neq_vbuc1_then_la1
@ -27077,7 +27077,7 @@ render_screen_original: {
// sid_rnd_init
// Initialize SID voice 3 for random number generation
sid_rnd_init: {
// *SID_VOICE3_FREQ = $ffff
// *SID_VOICE3_FREQ = 0xffff
// [548] *((const word*) SID_VOICE3_FREQ) ← (word) $ffff -- _deref_pwuc1=vwuc2
lda #<$ffff
sta SID_VOICE3_FREQ
@ -27335,7 +27335,7 @@ sprites_irq: {
// These values are updated based on the players level and the base values from SCORE_BASE_BCD
score_add_bcd: .fill 4*5, 0
// Pointers to the screen address for rendering each playfield line
// The lines for screen 1 is aligned with $80 and screen 2 with $40 - so XOR'ing with $40 gives screen 2 lines.
// The lines for screen 1 is aligned with 0x80 and screen 2 with 0x40 - so XOR'ing with 0x40 gives screen 2 lines.
.align $80
screen_lines_1: .fill 2*PLAYFIELD_LINES, 0
.align $40