[INFO] cloning repository https://github.com/BKTB888/General_MiniMax
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/BKTB888/General_MiniMax" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBKTB888%2FGeneral_MiniMax", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBKTB888%2FGeneral_MiniMax'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] b4050723f662cc3ad41f4769436a3568bef5874b
[INFO] checking BKTB888/General_MiniMax against try#012cd62c9add58ab3910e44c137d87db3ab70f61 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBKTB888%2FGeneral_MiniMax" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-6-tc2/source/rust-toolchain.toml
[INFO] started tweaking git repo https://github.com/BKTB888/General_MiniMax
[INFO] finished tweaking git repo https://github.com/BKTB888/General_MiniMax
[INFO] tweaked toml for git repo https://github.com/BKTB888/General_MiniMax written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/BKTB888/General_MiniMax on toolchain 012cd62c9add58ab3910e44c137d87db3ab70f61
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/BKTB888/General_MiniMax already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2f85405e7a3c1744cfb1e218b4d0e3045de729b21de82e528f7c59cc0f52b6d0
[INFO] running `Command { std: "docker" "start" "-a" "2f85405e7a3c1744cfb1e218b4d0e3045de729b21de82e528f7c59cc0f52b6d0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2f85405e7a3c1744cfb1e218b4d0e3045de729b21de82e528f7c59cc0f52b6d0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2f85405e7a3c1744cfb1e218b4d0e3045de729b21de82e528f7c59cc0f52b6d0", kill_on_drop: false }`
[INFO] [stdout] 2f85405e7a3c1744cfb1e218b4d0e3045de729b21de82e528f7c59cc0f52b6d0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d7025d10a4e53615ee9eac1ecb5a9e988c8920972648b0943b5b7867fb8f0163
[INFO] running `Command { std: "docker" "start" "-a" "d7025d10a4e53615ee9eac1ecb5a9e988c8920972648b0943b5b7867fb8f0163", kill_on_drop: false }`
[INFO] [stderr]    Compiling rustix v1.1.4
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling getrandom v0.4.2
[INFO] [stderr]     Checking rand_core v0.10.0
[INFO] [stderr]     Checking cpufeatures v0.3.0
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking mio v1.1.1
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking colored v3.1.1
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]     Checking signal-hook v0.3.18
[INFO] [stderr]     Checking chacha20 v0.10.0
[INFO] [stderr]     Checking signal-hook-mio v0.2.5
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking rayon v1.11.0
[INFO] [stderr]     Checking rand v0.10.0
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]     Checking derive_more v2.1.1
[INFO] [stderr]     Checking crossterm v0.29.0
[INFO] [stderr]     Checking General_MiniMax v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the feature `generic_const_exprs` is incomplete and may not be safe to use and/or cause compiler crashes
[INFO] [stdout]  --> src/main.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | #![feature(generic_const_exprs)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: see issue #76560 <https://github.com/rust-lang/rust/issues/76560> for more information
[INFO] [stdout]   = note: `#[warn(incomplete_features)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::evals::Evaluation`
[INFO] [stdout]  --> src/main.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::evals::Evaluation;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::search::Search`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::search::Search;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused macro definition: `play`
[INFO] [stdout]   --> src/game.rs:82:7
[INFO] [stdout]    |
[INFO] [stdout] 82 | macro play {
[INFO] [stdout]    |       ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_macros)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `evaluation::eval`
[INFO] [stdout]  --> src/games/mancala/mod.rs:4:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub use evaluation::eval;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the feature `generic_const_exprs` is incomplete and may not be safe to use and/or cause compiler crashes
[INFO] [stdout]  --> src/main.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | #![feature(generic_const_exprs)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: see issue #76560 <https://github.com/rust-lang/rust/issues/76560> for more information
[INFO] [stdout]   = note: `#[warn(incomplete_features)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::evals::Evaluation`
[INFO] [stdout]  --> src/main.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::evals::Evaluation;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::search::Search`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::search::Search;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused macro definition: `play`
[INFO] [stdout]   --> src/game.rs:82:7
[INFO] [stdout]    |
[INFO] [stdout] 82 | macro play {
[INFO] [stdout]    |       ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_macros)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `evaluation::eval`
[INFO] [stdout]  --> src/games/mancala/mod.rs:4:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub use evaluation::eval;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_player` is never used
[INFO] [stdout]  --> src/evals.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub trait Evaluation<S: GameState>: Fn(&S) -> EvalResult {
[INFO] [stdout]   |           ---------- method in this trait
[INFO] [stdout] 9 |     fn to_player(self) -> impl Player<S>
[INFO] [stdout]   |        ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `print_play` is never used
[INFO] [stdout]   --> src/game.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | / impl<S: GameState> Game<S>
[INFO] [stdout] 14 | | where
[INFO] [stdout] 15 | |     [(); S::NUM_P as usize]:,
[INFO] [stdout]    | |_____________________________- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |       pub fn print_play(&mut self) {
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ConnectKState` is never constructed
[INFO] [stdout]  --> src/games/connect4/state.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct ConnectKState<const N: u8, const M: u8, const K: u8 = 4, const NUM_P: u8 = 2>
[INFO] [stdout]   |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `check_result` is never used
[INFO] [stdout]    --> src/games/connect4/state.rs:129:8
[INFO] [stdout]     |
[INFO] [stdout] 124 | / impl<const N: u8, const M: u8, const K: u8, const NUM_P: u8> ConnectKState<N, M, K, NUM_P>
[INFO] [stdout] 125 | | where
[INFO] [stdout] 126 | |     [(); M as usize]:,
[INFO] [stdout] 127 | |     [(); N as usize]:,
[INFO] [stdout]     | |______________________- method in this implementation
[INFO] [stdout] 128 |   {
[INFO] [stdout] 129 |       fn check_result(&self, col: usize) -> Option<GameResult> {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/games/coordinate.rs:58:33
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub struct ParseCoordinateError(String);
[INFO] [stdout]    |            -------------------- ^^^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout]    = note: `ParseCoordinateError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InfiniteConnect4State` is never constructed
[INFO] [stdout]  --> src/games/infinite_connect4/state.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct InfiniteConnect4State {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `eval` is never used
[INFO] [stdout]  --> src/games/mancala/evaluation.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn eval(state: &MancalaState) -> EvalResult {
[INFO] [stdout]   |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `opponent_side`, `current_side`, and `balls_in_play` are never used
[INFO] [stdout]   --> src/games/mancala/state.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl MancalaState {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn opponent_side(&self) -> [u8; 6] {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn current_side(&self) -> [u8; 6] {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn balls_in_play(&self) -> u16 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DIRS` is never used
[INFO] [stdout]  --> src/games/mega_tictactoe/evaluation.rs:7:7
[INFO] [stdout]   |
[INFO] [stdout] 7 | const DIRS: [(MapInt, MapInt); 4] = [(1, 0), (0, 1), (1, 1), (1, -1)];
[INFO] [stdout]   |       ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `player_score` is never used
[INFO] [stdout]   --> src/games/mega_tictactoe/evaluation.rs:11:4
[INFO] [stdout]    |
[INFO] [stdout] 11 | fn player_score<const K: u8, const NUM_P: u8>(state: &KInARowState<K, NUM_P>, player: u8) -> f32 {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `eval_kinrow` is never used
[INFO] [stdout]   --> src/games/mega_tictactoe/evaluation.rs:60:8
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub fn eval_kinrow<const K: u8, const NUM_P: u8>(state: &KInARowState<K, NUM_P>) -> EvalResult {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `human_kinrow` is never used
[INFO] [stdout]  --> src/games/mega_tictactoe/player.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn human_kinrow<const K: u8, const NUM_P: u8>(state: &KInARowState<K, NUM_P>) -> MapCoord {
[INFO] [stdout]   |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `MapInt` is never used
[INFO] [stdout]  --> src/games/mega_tictactoe/state.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub type MapInt = i16;
[INFO] [stdout]   |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `MapCoord` is never used
[INFO] [stdout]  --> src/games/mega_tictactoe/state.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub type MapCoord = Coordinate<MapInt, MapInt>;
[INFO] [stdout]   |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Map` is never used
[INFO] [stdout]   --> src/games/mega_tictactoe/state.rs:10:6
[INFO] [stdout]    |
[INFO] [stdout] 10 | type Map = BTreeMap<MapCoord, u8>;
[INFO] [stdout]    |      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `KInARowState` is never constructed
[INFO] [stdout]   --> src/games/mega_tictactoe/state.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct KInARowState<const K: u8, const NUM_P: u8 = 2> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `cells`, `has_n_from`, `player_has_n`, `has_won_from`, `check_result`, and `add_candidates` are never used
[INFO] [stdout]    --> src/games/mega_tictactoe/state.rs:88:12
[INFO] [stdout]     |
[INFO] [stdout]  87 | impl<const K: u8, const NUM_P: u8> KInARowState<K, NUM_P> {
[INFO] [stdout]     | --------------------------------------------------------- associated items in this implementation
[INFO] [stdout]  88 |     pub fn cells(&self) -> &Map {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  92 |     fn has_n_from((start, player): (MapCoord, u8), n: u8, cells: &mut Map) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub fn player_has_n(&self, player: u8, n: u8) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 128 |     pub fn has_won_from(&self, from: MapCoord) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub fn check_result(&self) -> Option<GameResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     fn add_candidates(&mut self, from: MapCoord) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `randy` is never used
[INFO] [stdout]   --> src/players.rs:28:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub fn randy<S: GameState>(state: &S) -> S::Choice {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `randys_from_seed` is never used
[INFO] [stdout]   --> src/players.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub fn randys_from_seed<S: GameState>(seed: u64) -> impl Player<S> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Draw` is never constructed
[INFO] [stdout]  --> src/result.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub enum GameResult {
[INFO] [stdout]   |          ---------- variant in this enum
[INFO] [stdout] 6 |     Player(u8),
[INFO] [stdout] 7 |     Draw
[INFO] [stdout]   |     ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `GameResult` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `print_result` is never used
[INFO] [stdout]   --> src/result.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | impl GameResult {
[INFO] [stdout]    | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn print_result(&self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_player_color` is never used
[INFO] [stdout]   --> src/result.rs:43:8
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub fn get_player_color(player: u8) -> Color {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Search` is never used
[INFO] [stdout]  --> src/search.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub trait Search<S: GameState>: Fn(&S, u8) -> EvalResult {
[INFO] [stdout]   |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_eval` and `to_player` are never used
[INFO] [stdout]   --> src/search.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub trait ABSearch<S: GameState>: Fn(&S, u8, EvalResult, EvalResult) -> EvalResult {
[INFO] [stdout]    |           -------- methods in this trait
[INFO] [stdout] 19 |     fn to_eval(self, depth: u8) -> impl Evaluation<S>
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     fn to_player(self, depth: u8) -> impl Player<S>
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_player` is never used
[INFO] [stdout]  --> src/evals.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub trait Evaluation<S: GameState>: Fn(&S) -> EvalResult {
[INFO] [stdout]   |           ---------- method in this trait
[INFO] [stdout] 9 |     fn to_player(self) -> impl Player<S>
[INFO] [stdout]   |        ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `print_play` is never used
[INFO] [stdout]   --> src/game.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | / impl<S: GameState> Game<S>
[INFO] [stdout] 14 | | where
[INFO] [stdout] 15 | |     [(); S::NUM_P as usize]:,
[INFO] [stdout]    | |_____________________________- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |       pub fn print_play(&mut self) {
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/games/coordinate.rs:58:33
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub struct ParseCoordinateError(String);
[INFO] [stdout]    |            -------------------- ^^^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout]    = note: `ParseCoordinateError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InfiniteConnect4State` is never constructed
[INFO] [stdout]  --> src/games/infinite_connect4/state.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct InfiniteConnect4State {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `eval` is never used
[INFO] [stdout]  --> src/games/mancala/evaluation.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn eval(state: &MancalaState) -> EvalResult {
[INFO] [stdout]   |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `opponent_side`, `current_side`, and `balls_in_play` are never used
[INFO] [stdout]   --> src/games/mancala/state.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl MancalaState {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn opponent_side(&self) -> [u8; 6] {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn current_side(&self) -> [u8; 6] {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn balls_in_play(&self) -> u16 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DIRS` is never used
[INFO] [stdout]  --> src/games/mega_tictactoe/evaluation.rs:7:7
[INFO] [stdout]   |
[INFO] [stdout] 7 | const DIRS: [(MapInt, MapInt); 4] = [(1, 0), (0, 1), (1, 1), (1, -1)];
[INFO] [stdout]   |       ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `player_score` is never used
[INFO] [stdout]   --> src/games/mega_tictactoe/evaluation.rs:11:4
[INFO] [stdout]    |
[INFO] [stdout] 11 | fn player_score<const K: u8, const NUM_P: u8>(state: &KInARowState<K, NUM_P>, player: u8) -> f32 {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `eval_kinrow` is never used
[INFO] [stdout]   --> src/games/mega_tictactoe/evaluation.rs:60:8
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub fn eval_kinrow<const K: u8, const NUM_P: u8>(state: &KInARowState<K, NUM_P>) -> EvalResult {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `human_kinrow` is never used
[INFO] [stdout]  --> src/games/mega_tictactoe/player.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn human_kinrow<const K: u8, const NUM_P: u8>(state: &KInARowState<K, NUM_P>) -> MapCoord {
[INFO] [stdout]   |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `cells`, `player_has_n`, `has_won_from`, and `check_result` are never used
[INFO] [stdout]    --> src/games/mega_tictactoe/state.rs:88:12
[INFO] [stdout]     |
[INFO] [stdout]  87 | impl<const K: u8, const NUM_P: u8> KInARowState<K, NUM_P> {
[INFO] [stdout]     | --------------------------------------------------------- methods in this implementation
[INFO] [stdout]  88 |     pub fn cells(&self) -> &Map {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub fn player_has_n(&self, player: u8, n: u8) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 128 |     pub fn has_won_from(&self, from: MapCoord) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub fn check_result(&self) -> Option<GameResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `randy` is never used
[INFO] [stdout]   --> src/players.rs:28:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub fn randy<S: GameState>(state: &S) -> S::Choice {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `randys_from_seed` is never used
[INFO] [stdout]   --> src/players.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub fn randys_from_seed<S: GameState>(seed: u64) -> impl Player<S> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `print_result` is never used
[INFO] [stdout]   --> src/result.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | impl GameResult {
[INFO] [stdout]    | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn print_result(&self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Search` is never used
[INFO] [stdout]  --> src/search.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub trait Search<S: GameState>: Fn(&S, u8) -> EvalResult {
[INFO] [stdout]   |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_eval` and `to_player` are never used
[INFO] [stdout]   --> src/search.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub trait ABSearch<S: GameState>: Fn(&S, u8, EvalResult, EvalResult) -> EvalResult {
[INFO] [stdout]    |           -------- methods in this trait
[INFO] [stdout] 19 |     fn to_eval(self, depth: u8) -> impl Evaluation<S>
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     fn to_player(self, depth: u8) -> impl Player<S>
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 7.04s
[INFO] running `Command { std: "docker" "inspect" "d7025d10a4e53615ee9eac1ecb5a9e988c8920972648b0943b5b7867fb8f0163", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d7025d10a4e53615ee9eac1ecb5a9e988c8920972648b0943b5b7867fb8f0163", kill_on_drop: false }`
[INFO] [stdout] d7025d10a4e53615ee9eac1ecb5a9e988c8920972648b0943b5b7867fb8f0163
