Age | Commit message (Collapse) | Author |
|
* free_board should not return anything.
* is_valid_move and has_valid_moves accept a board.
* Implemented primitives for Scheme strategies to get the current
player, and to get the board, and the validity of a move.
* Removed game logic from is_valid_move. Instead simply apply the move
to a temp board, and see if the move worked.
* Created a very simple strategy for testing these primitives. It only
hardcodes the first move, and then fails since that move is no longer
valid.
|
|
Also was able to print the current board from scheme, so we should be
able to do basic analysis at least. Should add more primitives for use
from scheme.
|
|
This was how it originally was, but I changed it to use a global
variable instead. I want to be able to use the apply_move function in
the is_valid_move implementation, to have all the logic for checking if
a move is valid in one place.
Moved the apply_move function out of board.c, since it no longer
needs a direct reference to the board.
|
|
Also fixed a bug where we could have gone off the upper bounds of the
board.
|
|
|
|
These functions will use the standard get_board and a function for
getting the current player.
|
|
Instead use the get_board() function to get a reference to the board.
|
|
|
|
If the player is an AI one, it will point to a function that will return
the move from the AI. If the player is a human, it will point to a
function that will prompt the user for input.
|
|
|
|
We are not aiming for high portability with this program. Anywhere that
Guile is available, we should be able to access _GNU_SOURCE extensions.
|
|
|
|
|
|
|
|
The player_color type already is set to char, but this is a bit clearer
as to what the actual return values are
|
|
We wont need to mutate the board in the print function.
|
|
|