use std::str::FromStr;
use crate::{Board, ChessMove, Color, Square};
#[derive(Copy, Clone, Eq, PartialEq, Debug)]
pub enum GameAction {
OfferDraw(Color),
AcceptDraw,
RefuseDraw,
Resign(Color),
}
#[derive(Copy, Clone, Eq, PartialEq, Debug)]
pub enum GameState {
Ongoing,
Checkmates(Color),
Stalemate,
DrawByRequest,
Resigns(Color),
}
impl GameState {
pub fn winner(&self) -> Option<Color> {
match *self {
GameState::Ongoing => None,
GameState::Checkmates(color) => Some(!color),
GameState::Stalemate => None,
GameState::DrawByRequest => None,
GameState::Resigns(color) => Some(!color),
}
}
}
#[derive(Clone, Eq, PartialEq, Default, Debug)]
pub struct Chess {
pub(crate) board: Board,
pub(crate) square_focused: Option<Square>,
pub(crate) history: Vec<String>,
}
impl Chess {
pub fn new(board: Board) -> Self {
Chess {
board,
square_focused: Default::default(),
history: Default::default(),
}
}
pub fn history(&self) -> Vec<String> {
self.history.clone()
}
pub fn undo(&mut self) {
if let Some(fen) = self.history.pop() {
self.board = Board::from_str(fen.as_str()).expect("valid fen from history");
}
}
pub fn reset(&mut self) {
self.board = Board::default();
self.square_focused = None;
self.history = vec![];
}
pub fn state(&self) -> GameState {
let state = self.board.state();
state
}
pub fn play(&mut self, from: Square, to: Square) {
let m = ChessMove::new(from, to);
if self.board.is_legal(m) {
self.history.push(self.board.to_string());
self.board.update(m);
}
self.square_focused = None;
}
}