[INFO] cloning repository https://github.com/gregpennefather/four-monties [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/gregpennefather/four-monties" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgregpennefather%2Ffour-monties", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgregpennefather%2Ffour-monties'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 642dcf4344cb53f27e0430900fa1d964ed24a23f [INFO] checking gregpennefather/four-monties against master#385fa9d845dd326c6bbfd58c22244215e431948a for absurd-question-mark-desugar [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgregpennefather%2Ffour-monties" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/gregpennefather/four-monties on toolchain 385fa9d845dd326c6bbfd58c22244215e431948a [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+385fa9d845dd326c6bbfd58c22244215e431948a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/gregpennefather/four-monties [INFO] finished tweaking git repo https://github.com/gregpennefather/four-monties [INFO] tweaked toml for git repo https://github.com/gregpennefather/four-monties written to /workspace/builds/worker-2-tc1/source/Cargo.toml [INFO] crate git repo https://github.com/gregpennefather/four-monties 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" "+385fa9d845dd326c6bbfd58c22244215e431948a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded log4rs v1.2.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+385fa9d845dd326c6bbfd58c22244215e431948a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] a2934657572d53cefa9548ca8f5c224b15b2af01e52698dc7adc9a222b41a6a2 [INFO] running `Command { std: "docker" "start" "-a" "a2934657572d53cefa9548ca8f5c224b15b2af01e52698dc7adc9a222b41a6a2", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "a2934657572d53cefa9548ca8f5c224b15b2af01e52698dc7adc9a222b41a6a2", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "a2934657572d53cefa9548ca8f5c224b15b2af01e52698dc7adc9a222b41a6a2", kill_on_drop: false }` [INFO] [stdout] a2934657572d53cefa9548ca8f5c224b15b2af01e52698dc7adc9a222b41a6a2 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+385fa9d845dd326c6bbfd58c22244215e431948a" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] c9459dba9422a3c52b957d06794a0d22652a012a10e7080fa93bb4573dbce1a1 [INFO] running `Command { std: "docker" "start" "-a" "c9459dba9422a3c52b957d06794a0d22652a012a10e7080fa93bb4573dbce1a1", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.76 [INFO] [stderr] Compiling libc v0.2.152 [INFO] [stderr] Compiling serde v1.0.195 [INFO] [stderr] Compiling num-traits v0.2.17 [INFO] [stderr] Compiling indexmap v1.9.3 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling anyhow v1.0.79 [INFO] [stderr] Checking smallvec v1.11.2 [INFO] [stderr] Checking hashbrown v0.12.3 [INFO] [stderr] Checking linked-hash-map v0.5.6 [INFO] [stderr] Checking ryu v1.0.16 [INFO] [stderr] Compiling thiserror v1.0.56 [INFO] [stderr] Checking destructure_traitobject v0.2.0 [INFO] [stderr] Compiling serde_json v1.0.111 [INFO] [stderr] Checking ppv-lite86 v0.2.17 [INFO] [stderr] Checking iana-time-zone v0.1.59 [INFO] [stderr] Checking unsafe-any-ors v1.0.0 [INFO] [stderr] Checking arc-swap v1.6.0 [INFO] [stderr] Checking log-mdc v0.1.0 [INFO] [stderr] Checking typemap-ors v1.0.0 [INFO] [stderr] Checking colored v2.1.0 [INFO] [stderr] Checking yaml-rust v0.4.5 [INFO] [stderr] Compiling quote v1.0.35 [INFO] [stderr] Compiling syn v2.0.48 [INFO] [stderr] Checking getrandom v0.2.11 [INFO] [stderr] Checking parking_lot_core v0.9.9 [INFO] [stderr] Checking thread-id v4.2.1 [INFO] [stderr] Checking rand_core v0.6.4 [INFO] [stderr] Checking parking_lot v0.12.1 [INFO] [stderr] Checking rand_chacha v0.3.1 [INFO] [stderr] Checking rand v0.8.5 [INFO] [stderr] Checking ordered-float v2.10.1 [INFO] [stderr] Checking chrono v0.4.31 [INFO] [stderr] Compiling serde_derive v1.0.195 [INFO] [stderr] Compiling thiserror-impl v1.0.56 [INFO] [stderr] Compiling derivative v2.2.0 [INFO] [stderr] Checking serde-value v0.7.0 [INFO] [stderr] Checking serde_yaml v0.8.26 [INFO] [stderr] Checking log v0.4.20 [INFO] [stderr] Checking log4rs v1.2.0 [INFO] [stderr] Checking four-monties v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `std::default` [INFO] [stdout] --> src/main.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::default; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `WIDTH`, `mcst::SearchTree`, `randy::Randy`, `result::GameResult`, `yu::Yu` [INFO] [stdout] --> src/main.rs:5:24 [INFO] [stdout] | [INFO] [stdout] 5 | board::{Board, WIDTH}, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 6 | result::GameResult, player::Player, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 7 | }, [INFO] [stdout] 8 | agent::{monty::Monty, randy::Randy, yu::Yu}, [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^ [INFO] [stdout] 9 | tournament::Tournament, mcst::SearchTree, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/main.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `E`, `RwLock` [INFO] [stdout] --> src/mcst/mod.rs:2:19 [INFO] [stdout] | [INFO] [stdout] 2 | f32::consts::{E, SQRT_2}, [INFO] [stdout] | ^ [INFO] [stdout] 3 | sync::{Arc, RwLock}, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/mcst/mod.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Mutex`, `iter::Once` [INFO] [stdout] --> src/mcst/node.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | iter::Once, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 5 | sync::{Arc, Mutex, RwLock, Weak}, [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt::Write` [INFO] [stdout] --> src/mcst/playout.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::fmt::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::game::result::GameResult` [INFO] [stdout] --> src/mcst/record.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::game::result::GameResult; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `game::board::Board`, `mcst::SearchTree` [INFO] [stdout] --> src/mcst/tests.rs:1:13 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::{game::board::Board, mcst::SearchTree}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::default` [INFO] [stdout] --> src/main.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::default; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `node::Node` [INFO] [stdout] --> src/agent/monty.rs:3:12 [INFO] [stdout] | [INFO] [stdout] 3 | mcst::{node::Node, SearchTree}, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `f32::consts::E`, `self` [INFO] [stdout] --> src/agent/yu.rs:1:16 [INFO] [stdout] | [INFO] [stdout] 1 | use std::{io::{self, stdin}, f32::consts::E}; [INFO] [stdout] | ^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `WIDTH`, `mcst::SearchTree`, `randy::Randy`, `result::GameResult`, `yu::Yu` [INFO] [stdout] --> src/main.rs:5:24 [INFO] [stdout] | [INFO] [stdout] 5 | board::{Board, WIDTH}, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 6 | result::GameResult, player::Player, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 7 | }, [INFO] [stdout] 8 | agent::{monty::Monty, randy::Randy, yu::Yu}, [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^ [INFO] [stdout] 9 | tournament::Tournament, mcst::SearchTree, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/agent/yu.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/main.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `colored::Colorize` [INFO] [stdout] --> src/tournament.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use colored::Colorize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around function argument [INFO] [stdout] --> src/game/board.rs:258:36 [INFO] [stdout] | [INFO] [stdout] 258 | assert!(check_vertical(bb, (file + WIDTH * 3))) [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 258 - assert!(check_vertical(bb, (file + WIDTH * 3))) [INFO] [stdout] 258 + assert!(check_vertical(bb, file + WIDTH * 3)) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `E`, `RwLock` [INFO] [stdout] --> src/mcst/mod.rs:2:19 [INFO] [stdout] | [INFO] [stdout] 2 | f32::consts::{E, SQRT_2}, [INFO] [stdout] | ^ [INFO] [stdout] 3 | sync::{Arc, RwLock}, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/mcst/mod.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Mutex`, `iter::Once` [INFO] [stdout] --> src/mcst/node.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | iter::Once, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 5 | sync::{Arc, Mutex, RwLock, Weak}, [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::BorrowMut` [INFO] [stdout] --> src/mcst/node.rs:172:9 [INFO] [stdout] | [INFO] [stdout] 172 | use std::borrow::BorrowMut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt::Write` [INFO] [stdout] --> src/mcst/playout.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::fmt::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::game::result::GameResult` [INFO] [stdout] --> src/mcst/record.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::game::result::GameResult; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ArcNode`, `NodeContent` [INFO] [stdout] --> src/mcst/mod.rs:291:20 [INFO] [stdout] | [INFO] [stdout] 291 | node::{ArcNode, NodeContent}, [INFO] [stdout] | ^^^^^^^ ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `node::Node` [INFO] [stdout] --> src/agent/monty.rs:3:12 [INFO] [stdout] | [INFO] [stdout] 3 | mcst::{node::Node, SearchTree}, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `f32::consts::E`, `self` [INFO] [stdout] --> src/agent/yu.rs:1:16 [INFO] [stdout] | [INFO] [stdout] 1 | use std::{io::{self, stdin}, f32::consts::E}; [INFO] [stdout] | ^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/agent/yu.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `colored::Colorize` [INFO] [stdout] --> src/tournament.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use colored::Colorize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/mcst/node.rs:119:25 [INFO] [stdout] | [INFO] [stdout] 119 | fn new_child(&self, index: usize, board: Board) -> Self { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/mcst/node.rs:119:25 [INFO] [stdout] | [INFO] [stdout] 119 | fn new_child(&self, index: usize, board: Board) -> Self { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/mcst/tests.rs:9:9 [INFO] [stdout] | [INFO] [stdout] 9 | for i in 0..10 { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/mcst/tests.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | for i in 0..8 { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/mcst/tests.rs:46:9 [INFO] [stdout] | [INFO] [stdout] 46 | for i in 0..50 { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/mcst/mod.rs:147:33 [INFO] [stdout] | [INFO] [stdout] 147 | ... for i in 0..self.simulations { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/mcst/mod.rs:147:33 [INFO] [stdout] | [INFO] [stdout] 147 | ... for i in 0..self.simulations { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/mcst/mod.rs:191:33 [INFO] [stdout] | [INFO] [stdout] 191 | pub fn expansion(&mut self, mut leaf: ArcNode) { [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/mcst/mod.rs:191:33 [INFO] [stdout] | [INFO] [stdout] 191 | pub fn expansion(&mut self, mut leaf: ArcNode) { [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/agent/monty.rs:26:13 [INFO] [stdout] | [INFO] [stdout] 26 | for i in 0..self.iterations { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> src/agent/monty.rs:23:31 [INFO] [stdout] | [INFO] [stdout] 23 | fn select_move(&mut self, board: Board) -> usize { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/agent/monty.rs:26:13 [INFO] [stdout] | [INFO] [stdout] 26 | for i in 0..self.iterations { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> src/agent/monty.rs:23:31 [INFO] [stdout] | [INFO] [stdout] 23 | fn select_move(&mut self, board: Board) -> usize { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/agent/randy.rs:17:31 [INFO] [stdout] | [INFO] [stdout] 17 | fn record_move(&mut self, index: usize, board: Board) -> crate::game::board::Board { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/agent/yu.rs:21:21 [INFO] [stdout] | [INFO] [stdout] 21 | Err(e) => println!("Invalid move please select another") [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/agent/yu.rs:26:31 [INFO] [stdout] | [INFO] [stdout] 26 | fn record_move(&mut self, index: usize, board: Board) -> crate::game::board::Board { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `m_count` is assigned to, but never used [INFO] [stdout] --> src/tournament.rs:20:17 [INFO] [stdout] | [INFO] [stdout] 20 | let mut m_count = 0; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: consider using `_m_count` instead [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/agent/randy.rs:17:31 [INFO] [stdout] | [INFO] [stdout] 17 | fn record_move(&mut self, index: usize, board: Board) -> crate::game::board::Board { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/agent/yu.rs:21:21 [INFO] [stdout] | [INFO] [stdout] 21 | Err(e) => println!("Invalid move please select another") [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/agent/yu.rs:26:31 [INFO] [stdout] | [INFO] [stdout] 26 | fn record_move(&mut self, index: usize, board: Board) -> crate::game::board::Board { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `cell_empty` and `setup` are never used [INFO] [stdout] --> src/game/board.rs:64:8 [INFO] [stdout] | [INFO] [stdout] 51 | impl Board { [INFO] [stdout] | ---------- associated items in this implementation [INFO] [stdout] ... [INFO] [stdout] 64 | fn cell_empty(self, x: usize, y: usize) -> bool { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 140 | pub fn setup(yellow_bb: u64, blue_bb: u64, column_pieces: [usize; WIDTH]) -> Self { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `print_state` is never used [INFO] [stdout] --> src/mcst/mod.rs:63:12 [INFO] [stdout] | [INFO] [stdout] 33 | impl SearchTree { [INFO] [stdout] | --------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 63 | pub fn print_state(&self) { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `is_valid` is never used [INFO] [stdout] --> src/mcst/valid_move.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 8 | impl ValidMove { [INFO] [stdout] | -------------------- method in this implementation [INFO] [stdout] 9 | pub fn is_valid(&self) -> bool { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `m_count` is assigned to, but never used [INFO] [stdout] --> src/tournament.rs:20:17 [INFO] [stdout] | [INFO] [stdout] 20 | let mut m_count = 0; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: consider using `_m_count` instead [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `cell_empty` is never used [INFO] [stdout] --> src/game/board.rs:64:8 [INFO] [stdout] | [INFO] [stdout] 51 | impl Board { [INFO] [stdout] | ---------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 64 | fn cell_empty(self, x: usize, y: usize) -> bool { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/mcst/mod.rs:224:9 [INFO] [stdout] | [INFO] [stdout] 224 | leaf.children.set(new_leaves); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 224 | let _ = leaf.children.set(new_leaves); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/agent/yu.rs:18:13 [INFO] [stdout] | [INFO] [stdout] 18 | stdin().read_line(&mut entry); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 18 | let _ = stdin().read_line(&mut entry); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `is_valid` is never used [INFO] [stdout] --> src/mcst/valid_move.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 8 | impl ValidMove { [INFO] [stdout] | -------------------- method in this implementation [INFO] [stdout] 9 | pub fn is_valid(&self) -> bool { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 27 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/mcst/mod.rs:224:9 [INFO] [stdout] | [INFO] [stdout] 224 | leaf.children.set(new_leaves); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 224 | let _ = leaf.children.set(new_leaves); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/agent/yu.rs:18:13 [INFO] [stdout] | [INFO] [stdout] 18 | stdin().read_line(&mut entry); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 18 | let _ = stdin().read_line(&mut entry); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 31 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 18.02s [INFO] running `Command { std: "docker" "inspect" "c9459dba9422a3c52b957d06794a0d22652a012a10e7080fa93bb4573dbce1a1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c9459dba9422a3c52b957d06794a0d22652a012a10e7080fa93bb4573dbce1a1", kill_on_drop: false }` [INFO] [stdout] c9459dba9422a3c52b957d06794a0d22652a012a10e7080fa93bb4573dbce1a1 [INFO] checking gregpennefather/four-monties against try#645bb72776a6a56a1a8f52631a44bd082b2ba509 for absurd-question-mark-desugar [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgregpennefather%2Ffour-monties" "/workspace/builds/worker-2-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc2/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/gregpennefather/four-monties on toolchain 645bb72776a6a56a1a8f52631a44bd082b2ba509 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+645bb72776a6a56a1a8f52631a44bd082b2ba509" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/gregpennefather/four-monties [INFO] finished tweaking git repo https://github.com/gregpennefather/four-monties [INFO] tweaked toml for git repo https://github.com/gregpennefather/four-monties written to /workspace/builds/worker-2-tc2/source/Cargo.toml [INFO] crate git repo https://github.com/gregpennefather/four-monties 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" "+645bb72776a6a56a1a8f52631a44bd082b2ba509" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+645bb72776a6a56a1a8f52631a44bd082b2ba509" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] c65c26b53a2756e2e215641c04468c322e184b0b54d3ef65906ff47dfd9fa2cb [INFO] running `Command { std: "docker" "start" "-a" "c65c26b53a2756e2e215641c04468c322e184b0b54d3ef65906ff47dfd9fa2cb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "c65c26b53a2756e2e215641c04468c322e184b0b54d3ef65906ff47dfd9fa2cb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c65c26b53a2756e2e215641c04468c322e184b0b54d3ef65906ff47dfd9fa2cb", kill_on_drop: false }` [INFO] [stdout] c65c26b53a2756e2e215641c04468c322e184b0b54d3ef65906ff47dfd9fa2cb [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+645bb72776a6a56a1a8f52631a44bd082b2ba509" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 1ba72f2504d795edd414237861c985f70509dc0be28056c69ecef30d4af8145b [INFO] running `Command { std: "docker" "start" "-a" "1ba72f2504d795edd414237861c985f70509dc0be28056c69ecef30d4af8145b", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.76 [INFO] [stderr] Compiling libc v0.2.152 [INFO] [stderr] Compiling serde v1.0.195 [INFO] [stderr] Compiling num-traits v0.2.17 [INFO] [stderr] Compiling indexmap v1.9.3 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Checking destructure_traitobject v0.2.0 [INFO] [stderr] Compiling thiserror v1.0.56 [INFO] [stderr] Checking hashbrown v0.12.3 [INFO] [stderr] Compiling serde_json v1.0.111 [INFO] [stderr] Checking ryu v1.0.16 [INFO] [stderr] Compiling anyhow v1.0.79 [INFO] [stderr] Checking smallvec v1.11.2 [INFO] [stderr] Checking linked-hash-map v0.5.6 [INFO] [stderr] Checking ppv-lite86 v0.2.17 [INFO] [stderr] Checking iana-time-zone v0.1.59 [INFO] [stderr] Checking unsafe-any-ors v1.0.0 [INFO] [stderr] Checking typemap-ors v1.0.0 [INFO] [stderr] Checking log-mdc v0.1.0 [INFO] [stderr] Checking yaml-rust v0.4.5 [INFO] [stderr] Checking arc-swap v1.6.0 [INFO] [stderr] Checking colored v2.1.0 [INFO] [stderr] Compiling quote v1.0.35 [INFO] [stderr] Compiling syn v2.0.48 [INFO] [stderr] Checking getrandom v0.2.11 [INFO] [stderr] Checking parking_lot_core v0.9.9 [INFO] [stderr] Checking thread-id v4.2.1 [INFO] [stderr] Checking rand_core v0.6.4 [INFO] [stderr] Checking parking_lot v0.12.1 [INFO] [stderr] Checking rand_chacha v0.3.1 [INFO] [stderr] Checking ordered-float v2.10.1 [INFO] [stderr] Checking chrono v0.4.31 [INFO] [stderr] Checking rand v0.8.5 [INFO] [stderr] Compiling serde_derive v1.0.195 [INFO] [stderr] Compiling thiserror-impl v1.0.56 [INFO] [stderr] Compiling derivative v2.2.0 [INFO] [stderr] Checking serde-value v0.7.0 [INFO] [stderr] Checking log v0.4.20 [INFO] [stderr] Checking serde_yaml v0.8.26 [INFO] [stderr] Checking log4rs v1.2.0 [INFO] [stderr] Checking four-monties v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `std::default` [INFO] [stdout] --> src/main.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::default; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `WIDTH`, `mcst::SearchTree`, `randy::Randy`, `result::GameResult`, `yu::Yu` [INFO] [stdout] --> src/main.rs:5:24 [INFO] [stdout] | [INFO] [stdout] 5 | board::{Board, WIDTH}, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 6 | result::GameResult, player::Player, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 7 | }, [INFO] [stdout] 8 | agent::{monty::Monty, randy::Randy, yu::Yu}, [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^ [INFO] [stdout] 9 | tournament::Tournament, mcst::SearchTree, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/main.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::default` [INFO] [stdout] --> src/main.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::default; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around function argument [INFO] [stdout] --> src/game/board.rs:258:36 [INFO] [stdout] | [INFO] [stdout] 258 | assert!(check_vertical(bb, (file + WIDTH * 3))) [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 258 - assert!(check_vertical(bb, (file + WIDTH * 3))) [INFO] [stdout] 258 + assert!(check_vertical(bb, file + WIDTH * 3)) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `E`, `RwLock` [INFO] [stdout] --> src/mcst/mod.rs:2:19 [INFO] [stdout] | [INFO] [stdout] 2 | f32::consts::{E, SQRT_2}, [INFO] [stdout] | ^ [INFO] [stdout] 3 | sync::{Arc, RwLock}, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/mcst/mod.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Mutex`, `iter::Once` [INFO] [stdout] --> src/mcst/node.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | iter::Once, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 5 | sync::{Arc, Mutex, RwLock, Weak}, [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::BorrowMut` [INFO] [stdout] --> src/mcst/node.rs:172:9 [INFO] [stdout] | [INFO] [stdout] 172 | use std::borrow::BorrowMut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt::Write` [INFO] [stdout] --> src/mcst/playout.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::fmt::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::game::result::GameResult` [INFO] [stdout] --> src/mcst/record.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::game::result::GameResult; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ArcNode`, `NodeContent` [INFO] [stdout] --> src/mcst/mod.rs:291:20 [INFO] [stdout] | [INFO] [stdout] 291 | node::{ArcNode, NodeContent}, [INFO] [stdout] | ^^^^^^^ ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `WIDTH`, `mcst::SearchTree`, `randy::Randy`, `result::GameResult`, `yu::Yu` [INFO] [stdout] --> src/main.rs:5:24 [INFO] [stdout] | [INFO] [stdout] 5 | board::{Board, WIDTH}, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 6 | result::GameResult, player::Player, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 7 | }, [INFO] [stdout] 8 | agent::{monty::Monty, randy::Randy, yu::Yu}, [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^ [INFO] [stdout] 9 | tournament::Tournament, mcst::SearchTree, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `node::Node` [INFO] [stdout] --> src/agent/monty.rs:3:12 [INFO] [stdout] | [INFO] [stdout] 3 | mcst::{node::Node, SearchTree}, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/main.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `f32::consts::E`, `self` [INFO] [stdout] --> src/agent/yu.rs:1:16 [INFO] [stdout] | [INFO] [stdout] 1 | use std::{io::{self, stdin}, f32::consts::E}; [INFO] [stdout] | ^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `E`, `RwLock` [INFO] [stdout] --> src/mcst/mod.rs:2:19 [INFO] [stdout] | [INFO] [stdout] 2 | f32::consts::{E, SQRT_2}, [INFO] [stdout] | ^ [INFO] [stdout] 3 | sync::{Arc, RwLock}, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/mcst/mod.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/agent/yu.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Mutex`, `iter::Once` [INFO] [stdout] --> src/mcst/node.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | iter::Once, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 5 | sync::{Arc, Mutex, RwLock, Weak}, [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt::Write` [INFO] [stdout] --> src/mcst/playout.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::fmt::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `colored::Colorize` [INFO] [stdout] --> src/tournament.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use colored::Colorize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::game::result::GameResult` [INFO] [stdout] --> src/mcst/record.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::game::result::GameResult; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `game::board::Board`, `mcst::SearchTree` [INFO] [stdout] --> src/mcst/tests.rs:1:13 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::{game::board::Board, mcst::SearchTree}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `node::Node` [INFO] [stdout] --> src/agent/monty.rs:3:12 [INFO] [stdout] | [INFO] [stdout] 3 | mcst::{node::Node, SearchTree}, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `f32::consts::E`, `self` [INFO] [stdout] --> src/agent/yu.rs:1:16 [INFO] [stdout] | [INFO] [stdout] 1 | use std::{io::{self, stdin}, f32::consts::E}; [INFO] [stdout] | ^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::RngCore` [INFO] [stdout] --> src/agent/yu.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use rand::RngCore; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `colored::Colorize` [INFO] [stdout] --> src/tournament.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use colored::Colorize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/mcst/node.rs:119:25 [INFO] [stdout] | [INFO] [stdout] 119 | fn new_child(&self, index: usize, board: Board) -> Self { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/mcst/tests.rs:9:9 [INFO] [stdout] | [INFO] [stdout] 9 | for i in 0..10 { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/mcst/tests.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | for i in 0..8 { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/mcst/tests.rs:46:9 [INFO] [stdout] | [INFO] [stdout] 46 | for i in 0..50 { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/mcst/mod.rs:147:33 [INFO] [stdout] | [INFO] [stdout] 147 | ... for i in 0..self.simulations { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/mcst/mod.rs:191:33 [INFO] [stdout] | [INFO] [stdout] 191 | pub fn expansion(&mut self, mut leaf: ArcNode) { [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/agent/monty.rs:26:13 [INFO] [stdout] | [INFO] [stdout] 26 | for i in 0..self.iterations { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> src/agent/monty.rs:23:31 [INFO] [stdout] | [INFO] [stdout] 23 | fn select_move(&mut self, board: Board) -> usize { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/agent/randy.rs:17:31 [INFO] [stdout] | [INFO] [stdout] 17 | fn record_move(&mut self, index: usize, board: Board) -> crate::game::board::Board { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/agent/yu.rs:21:21 [INFO] [stdout] | [INFO] [stdout] 21 | Err(e) => println!("Invalid move please select another") [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/agent/yu.rs:26:31 [INFO] [stdout] | [INFO] [stdout] 26 | fn record_move(&mut self, index: usize, board: Board) -> crate::game::board::Board { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `m_count` is assigned to, but never used [INFO] [stdout] --> src/tournament.rs:20:17 [INFO] [stdout] | [INFO] [stdout] 20 | let mut m_count = 0; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: consider using `_m_count` instead [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `cell_empty` is never used [INFO] [stdout] --> src/game/board.rs:64:8 [INFO] [stdout] | [INFO] [stdout] 51 | impl Board { [INFO] [stdout] | ---------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 64 | fn cell_empty(self, x: usize, y: usize) -> bool { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `is_valid` is never used [INFO] [stdout] --> src/mcst/valid_move.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 8 | impl ValidMove { [INFO] [stdout] | -------------------- method in this implementation [INFO] [stdout] 9 | pub fn is_valid(&self) -> bool { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/mcst/node.rs:119:25 [INFO] [stdout] | [INFO] [stdout] 119 | fn new_child(&self, index: usize, board: Board) -> Self { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/mcst/mod.rs:224:9 [INFO] [stdout] | [INFO] [stdout] 224 | leaf.children.set(new_leaves); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 224 | let _ = leaf.children.set(new_leaves); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/agent/yu.rs:18:13 [INFO] [stdout] | [INFO] [stdout] 18 | stdin().read_line(&mut entry); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 18 | let _ = stdin().read_line(&mut entry); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/mcst/mod.rs:147:33 [INFO] [stdout] | [INFO] [stdout] 147 | ... for i in 0..self.simulations { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 31 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/mcst/mod.rs:191:33 [INFO] [stdout] | [INFO] [stdout] 191 | pub fn expansion(&mut self, mut leaf: ArcNode) { [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/agent/monty.rs:26:13 [INFO] [stdout] | [INFO] [stdout] 26 | for i in 0..self.iterations { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> src/agent/monty.rs:23:31 [INFO] [stdout] | [INFO] [stdout] 23 | fn select_move(&mut self, board: Board) -> usize { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/agent/randy.rs:17:31 [INFO] [stdout] | [INFO] [stdout] 17 | fn record_move(&mut self, index: usize, board: Board) -> crate::game::board::Board { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `e` [INFO] [stdout] --> src/agent/yu.rs:21:21 [INFO] [stdout] | [INFO] [stdout] 21 | Err(e) => println!("Invalid move please select another") [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_e` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `index` [INFO] [stdout] --> src/agent/yu.rs:26:31 [INFO] [stdout] | [INFO] [stdout] 26 | fn record_move(&mut self, index: usize, board: Board) -> crate::game::board::Board { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `m_count` is assigned to, but never used [INFO] [stdout] --> src/tournament.rs:20:17 [INFO] [stdout] | [INFO] [stdout] 20 | let mut m_count = 0; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: consider using `_m_count` instead [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `cell_empty` and `setup` are never used [INFO] [stdout] --> src/game/board.rs:64:8 [INFO] [stdout] | [INFO] [stdout] 51 | impl Board { [INFO] [stdout] | ---------- associated items in this implementation [INFO] [stdout] ... [INFO] [stdout] 64 | fn cell_empty(self, x: usize, y: usize) -> bool { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 140 | pub fn setup(yellow_bb: u64, blue_bb: u64, column_pieces: [usize; WIDTH]) -> Self { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `print_state` is never used [INFO] [stdout] --> src/mcst/mod.rs:63:12 [INFO] [stdout] | [INFO] [stdout] 33 | impl SearchTree { [INFO] [stdout] | --------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 63 | pub fn print_state(&self) { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `is_valid` is never used [INFO] [stdout] --> src/mcst/valid_move.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 8 | impl ValidMove { [INFO] [stdout] | -------------------- method in this implementation [INFO] [stdout] 9 | pub fn is_valid(&self) -> bool { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/mcst/mod.rs:224:9 [INFO] [stdout] | [INFO] [stdout] 224 | leaf.children.set(new_leaves); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 224 | let _ = leaf.children.set(new_leaves); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/agent/yu.rs:18:13 [INFO] [stdout] | [INFO] [stdout] 18 | stdin().read_line(&mut entry); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 18 | let _ = stdin().read_line(&mut entry); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 27 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 10.91s [INFO] running `Command { std: "docker" "inspect" "1ba72f2504d795edd414237861c985f70509dc0be28056c69ecef30d4af8145b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1ba72f2504d795edd414237861c985f70509dc0be28056c69ecef30d4af8145b", kill_on_drop: false }` [INFO] [stdout] 1ba72f2504d795edd414237861c985f70509dc0be28056c69ecef30d4af8145b