X-Git-Url: https://git.cworth.org/git?p=ttt;a=blobdiff_plain;f=src%2Fttt-board.c;h=bafa0fd56fae79a0873daee57cf06152b4f93f2a;hp=273702185d8695ab312ef68275fcd4fecdcd3d1f;hb=81fa711bc04271a8c0a0926e6c198f91e797f59a;hpb=026b745559a0e7df3422f3e44594519a6d4358a9 diff --git a/src/ttt-board.c b/src/ttt-board.c index 2737021..bafa0fd 100644 --- a/src/ttt-board.c +++ b/src/ttt-board.c @@ -44,9 +44,21 @@ void ttt_board_init_from_string (ttt_board_t *board, const char *s) { - /* XXX: NYI */ + int i, j; + j = 0; + for (i = 0; i < strlen (s); i++) + { + if ((s[i] == 'X') | + (s[i] == 'O') | + (s[i] == '_')) + { + board->cells[j] = s[i]; + j++; + } + } } + /* Return the string representation of a board. * * The return value is a malloc()ed string that should be free()ed @@ -94,15 +106,20 @@ ttt_board_write (ttt_board_t *board, FILE *file) * 3|4|5 * 6|7|8 * - * 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). + * 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_NOT_GRID if the move is + * impossible (user input 'a' or '9' etc.) */ ttt_error_t ttt_board_make_move (ttt_board_t *board, int move) { + if (move < 0 || move > 8) + return TTT_ERROR_NOT_GRID; + if (board->cells[move] != TTT_CELL_EMPTY) return TTT_ERROR_NOT_VALID_MOVE; - + board->cells[move] = board->current_player; if (board->current_player == TTT_CELL_X) @@ -146,14 +163,14 @@ ttt_cell_t ttt_board_is_won (ttt_board_t *board) if (board->cells[0] != TTT_CELL_EMPTY && board->cells[0] == board->cells[4] && - board->cells[0]== board->cells[8]) + board->cells[0] == board->cells[8]) { return board->cells[0]; } if (board->cells[2] != TTT_CELL_EMPTY && board->cells[2] == board->cells[4] && - board->cells[2]== board->cells[6]) + board->cells[2] == board->cells[6]) { return board->cells[2]; }