From: Kevin Worth Date: Wed, 14 Dec 2005 04:57:25 +0000 (+0000) Subject: Second draft attempt at ttt_board_is_won X-Git-Url: https://git.cworth.org/git?p=ttt;a=commitdiff_plain;h=a17b73b1671accfb7d68f6e07616a265ae64e500 Second draft attempt at ttt_board_is_won --- diff --git a/src/test-board.c b/src/test-board.c index 4630a19..3135735 100644 --- a/src/test-board.c +++ b/src/test-board.c @@ -2,22 +2,22 @@ #include "ttt-board.h" -int ttt_board_is_won (ttt_board_t *board); - int ttt_board_is_won (ttt_board_t *board) { if ( - board->cells[0] == board->cells[3] && board->cells[3] == board->cells[6] || - board->cells[1] == board->cells[4] && board->cells[4] == board->cells[7] || - board->cells[2] == board->cells[5] && board->cells[5] == board->cells[8] || - board->cells[0] == board->cells[1] && board->cells[1] == board->cells[2] || - board->cells[3] == board->cells[4] && board->cells[4] == board->cells[5] || - board->cells[6] == board->cells[7] && board->cells[7] == board->cells[8] || - board->cells[0] == board->cells[4] && board->cells[4] == board->cells[8] || - board->cells[2] == board->cells[4] && board->cells[4] == board->cells[6] + (board->cells[0] == board->cells[3] && board->cells[3] == board->cells[6] && board->cells[0] != TTT_CELL_EMPTY) || + (board->cells[1] == board->cells[4] && board->cells[4] == board->cells[7] && board->cells[1] != TTT_CELL_EMPTY) || + (board->cells[2] == board->cells[5] && board->cells[5] == board->cells[8] && board->cells[2] != TTT_CELL_EMPTY) || + (board->cells[0] == board->cells[1] && board->cells[1] == board->cells[2] && board->cells[0] != TTT_CELL_EMPTY) || + (board->cells[3] == board->cells[4] && board->cells[4] == board->cells[5] && board->cells[3] != TTT_CELL_EMPTY) || + (board->cells[6] == board->cells[7] && board->cells[7] == board->cells[8] && board->cells[6] != TTT_CELL_EMPTY) || + (board->cells[0] == board->cells[4] && board->cells[4] == board->cells[8] && board->cells[0] != TTT_CELL_EMPTY) || + (board->cells[2] == board->cells[4] && board->cells[4] == board->cells[6] && board->cells[2] != TTT_CELL_EMPTY) ) -/* printf ("'board->current_player''s Win!") */ + { + printf ("%c's Win! ", board->current_player); return(1); + } else return(0); } diff --git a/src/ttt-board.c b/src/ttt-board.c index 8c34b3e..dfddf35 100644 --- a/src/ttt-board.c +++ b/src/ttt-board.c @@ -94,14 +94,10 @@ ttt_board_write (ttt_board_t *board, FILE *file) * 3|4|5 * 6|7|8 * - * Returns: 1 if a move is made succesfully. O if a move is invalid - * (the given cell is not empty). - * - * Bugs: Currently this function always places X for all moves. So, - * yeah, we'll need to fix that. + * Returns: TTT_ERROR_NONE if a move is made succesfully. TTT_ERROR_NOT_VALID_MOVE + * if a move is invalid (the given cell is not empty). */ - ttt_error_t ttt_board_make_move (ttt_board_t *board, int move) { if (board->cells[move] != TTT_CELL_EMPTY) @@ -110,10 +106,13 @@ ttt_error_t ttt_board_make_move (ttt_board_t *board, int move) board->cells[move] = board->current_player; if (board->current_player == TTT_CELL_X) + { + ttt_board_is_won (board); board->current_player = TTT_CELL_O; + } else board->current_player = TTT_CELL_X; - + return TTT_ERROR_NONE; } diff --git a/src/ttt-board.h b/src/ttt-board.h index c75c168..0b7723d 100644 --- a/src/ttt-board.h +++ b/src/ttt-board.h @@ -54,6 +54,9 @@ ttt_board_write (ttt_board_t *board, FILE *file); ttt_error_t ttt_board_make_move (ttt_board_t *board, int move); +int +ttt_board_is_won (ttt_board_t *board); + #endif