X-Git-Url: http://git.scottworley.com/pluta-lesnura/blobdiff_plain/7d0aa2d61de043373796dd07a4d8467e1463ef95..aa8493741589b32f3c4211919c0bda33eb02900d:/src/lib.rs diff --git a/src/lib.rs b/src/lib.rs index 59a47a9..19d003a 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -178,7 +178,6 @@ impl Hand { fn len(&self) -> usize { self.cards.len() } - #[cfg(test)] fn random(&self) -> Option<&Card> { self.cards.choose(&mut rand::thread_rng()) } @@ -204,6 +203,7 @@ pub enum Phase { Momentum, } +#[derive(Debug)] pub enum GameOutcome { Loss, Win, @@ -347,7 +347,7 @@ impl Game { .progress .iter() .zip(self.path_lengths.iter()) - .any(|(&prog, len)| prog >= len.0 .0.try_into().expect("wat?")) + .any(|(&prog, len)| prog >= len.0.value().try_into().expect("wat?")) { GameOutcome::Win } else { @@ -395,9 +395,18 @@ impl Default for Game { } pub struct Player(Box Play>); +impl Player { + #[must_use] + pub fn new(f: T) -> Self + where + T: FnMut(&Game) -> Play + 'static, + { + Self(Box::new(f)) + } +} -#[cfg(test)] -fn random_player(game: &Game) -> Play { +#[must_use] +pub fn random_player(game: &Game) -> Play { match game.phase { Phase::Play => Play::Play( *game @@ -491,7 +500,7 @@ mod tests { #[test] fn test_game() { for num_players in 1..10 { - let players: Vec<_> = std::iter::from_fn(|| Some(Player(Box::new(random_player)))) + let players: Vec<_> = std::iter::from_fn(|| Some(Player::new(random_player))) .take(num_players) .collect(); let mut game = Game::default();