From 31afd275f81480eb140dd9b92d0811162f2e2e6e Mon Sep 17 00:00:00 2001 From: Jacob B <20913473+0xjmux@users.noreply.github.com> Date: Sat, 23 Mar 2024 13:14:54 -0700 Subject: [PATCH] gravity bugfix, update display_board signature * Fix bug introduced in last commit when I tried to explicitly cast a uint to an int variable; it prevented the gravity check from ever activating, so pieces wouldn't ever actually be added to be board. * Changed display_board to take TetrisBoard instead of TetrisBoard* --- include/driver_tetris.h | 2 +- src/driver_tetris.c | 11 ++++++----- tetris/tetris.c | 2 +- 3 files changed, 8 insertions(+), 7 deletions(-) diff --git a/include/driver_tetris.h b/include/driver_tetris.h index ca4f7e4..39a1126 100644 --- a/include/driver_tetris.h +++ b/include/driver_tetris.h @@ -39,7 +39,7 @@ waddch((w),' '|A_REVERSE|COLOR_PAIR(x)) #define ADD_EMPTY(w) waddch((w), ' '); waddch((w), ' ') -void display_board(WINDOW *w, TetrisBoard *b); +void display_board(WINDOW *w, TetrisBoard b); void update_score(WINDOW *w, TetrisGame *tg); // Debug functions diff --git a/src/driver_tetris.c b/src/driver_tetris.c index 59d5030..62306e9 100644 --- a/src/driver_tetris.c +++ b/src/driver_tetris.c @@ -84,7 +84,7 @@ int main(void) { tg_tick(tg, move); // display board - display_board(g_win, &tg->active_board); + display_board(g_win, tg->active_board); update_score(s_win, tg); switch(getch()) { @@ -161,7 +161,7 @@ int main(void) { /** * Draw board array presented by tetris game */ -void display_board(WINDOW *w, TetrisBoard *tb) { +void display_board(WINDOW *w, TetrisBoard tb) { static struct timeval last_update; @@ -179,8 +179,8 @@ void display_board(WINDOW *w, TetrisBoard *tb) { wmove(w, 1 + i, 1); for (int j = 0; j < TETRIS_COLS; j++) { - if (tb->board[i][j] >= 0) { - ADD_BLOCK(w, tb->board[i][j]); + if (tb.board[i][j] >= 0) { + ADD_BLOCK(w, tb.board[i][j]); } else { ADD_EMPTY(w); @@ -191,10 +191,11 @@ void display_board(WINDOW *w, TetrisBoard *tb) { last_update = curr_time_usec; wrefresh(w); + #ifdef DEBUG_T // fprintf(gamelog, "display_board()\n"); // print_board_state(*tb, gamelog); - fflush(gamelog); + // fflush(gamelog); #endif #ifdef DEBUG_T_WIN diff --git a/tetris/tetris.c b/tetris/tetris.c index 845d46c..e06c1e5 100644 --- a/tetris/tetris.c +++ b/tetris/tetris.c @@ -411,7 +411,7 @@ bool check_do_piece_gravity(TetrisGame *tg) { // check if it's time for piece to be moved down int32_t time_diff_usec = get_elapsed_us(tg->last_gravity_tick_usec, curr_time_usec); - if (time_diff_usec > (int32_t)tg->gravity_tick_rate_usec) { + if (time_diff_usec > tg->gravity_tick_rate_usec) { // if can move down if(check_valid_move(tg, T_DOWN)) {