From: Scott Worley Date: Tue, 18 Jul 2023 18:26:27 +0000 (-0700) Subject: Play multiple games per run X-Git-Url: http://git.scottworley.com/pluta-lesnura/commitdiff_plain/aa8493741589b32f3c4211919c0bda33eb02900d Play multiple games per run --- diff --git a/src/main.rs b/src/main.rs index 172d58e..16bb4f7 100644 --- a/src/main.rs +++ b/src/main.rs @@ -12,8 +12,11 @@ struct Cli { enum Commands { /// Runs simulations Sim { + /// How many games? + #[arg(short = 'g', long, default_value_t = 1)] + num_games: usize, /// How many players? - #[arg(short, long)] + #[arg(short = 'p', long)] num_players: usize, }, } @@ -22,16 +25,21 @@ fn main() -> Result<(), &'static str> { let cli = Cli::parse(); match &cli.command { - Some(Commands::Sim { num_players }) => { - let players: Vec<_> = std::iter::from_fn(|| Some(Player::new(random_player))) - .take(*num_players) - .collect(); - let mut game = Game::default(); - for _ in 0..*num_players { - game.add_player(); + Some(Commands::Sim { + num_games, + num_players, + }) => { + for _ in 0..*num_games { + let players: Vec<_> = std::iter::from_fn(|| Some(Player::new(random_player))) + .take(*num_players) + .collect(); + let mut game = Game::default(); + for _ in 0..*num_players { + game.add_player(); + } + let result = play(game, players)?; + println!("Result: {result:?}"); } - let result = play(game, players)?; - println!("Result: {result:?}"); Ok(()) } None => unreachable!(),