[INFO] updating cached repository davetttt/ttt_rust_2 [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/davetttt/ttt_rust_2 [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/davetttt/ttt_rust_2" "work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/davetttt/ttt_rust_2"` [INFO] [stderr] Cloning into 'work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/davetttt/ttt_rust_2'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/davetttt/ttt_rust_2" "work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/gh/davetttt/ttt_rust_2"` [INFO] [stderr] Cloning into 'work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/gh/davetttt/ttt_rust_2'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 44ebdbd5f3afa5acc94ccdcac24f0b487ec608b7 [INFO] sha for GitHub repo davetttt/ttt_rust_2: 44ebdbd5f3afa5acc94ccdcac24f0b487ec608b7 [INFO] validating manifest of davetttt/ttt_rust_2 on toolchain master#60960a260f7b5c695fd0717311d72ce62dd4eb43 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of davetttt/ttt_rust_2 on toolchain try#266783e4e09e4e9d5307c1c8e695659c58bbcac7 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+266783e4e09e4e9d5307c1c8e695659c58bbcac7-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing davetttt/ttt_rust_2 [INFO] finished frobbing davetttt/ttt_rust_2 [INFO] frobbed toml for davetttt/ttt_rust_2 written to work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/davetttt/ttt_rust_2/Cargo.toml [INFO] started frobbing davetttt/ttt_rust_2 [INFO] finished frobbing davetttt/ttt_rust_2 [INFO] frobbed toml for davetttt/ttt_rust_2 written to work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/gh/davetttt/ttt_rust_2/Cargo.toml [INFO] crate davetttt/ttt_rust_2 already has a lockfile, it will not be regenerated [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+266783e4e09e4e9d5307c1c8e695659c58bbcac7-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] checking davetttt/ttt_rust_2 against master#60960a260f7b5c695fd0717311d72ce62dd4eb43 for pr-63376 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-63376/worker-0/master#60960a260f7b5c695fd0717311d72ce62dd4eb43:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/davetttt/ttt_rust_2:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "check" "--frozen" "--all" "--all-targets"` [INFO] [stdout] 66e5372dffa6a783370ae069eee7c1e530f620f1ed29f61efba025d96e4b1ab4 [INFO] running `"docker" "start" "-a" "66e5372dffa6a783370ae069eee7c1e530f620f1ed29f61efba025d96e4b1ab4"` [INFO] [stderr] Checking ttt_rust_2 v0.0.1 (/opt/crater/workdir) [INFO] [stderr] warning: unknown lint: `unstable` [INFO] [stderr] --> src/main.rs:1:10 [INFO] [stderr] | [INFO] [stderr] 1 | #![allow(unstable)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unknown_lints)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unknown lint: `unstable` [INFO] [stderr] --> src/main.rs:1:10 [INFO] [stderr] | [INFO] [stderr] 1 | #![allow(unstable)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unknown_lints)]` on by default [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::num::Float` [INFO] [stderr] --> src/board.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::num::Float; [INFO] [stderr] | ^^^^^^^^^^^^^^^ no `Float` in `num` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::io::BufferedReader` [INFO] [stderr] --> src/io.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::io::BufferedReader; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ no `BufferedReader` in `io` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::io::stdio::set_stdout` [INFO] [stderr] --> src/tests/io_tests.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::io::stdio::set_stdout; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ no `set_stdout` in `io::stdio` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::io::MemWriter` [INFO] [stderr] --> src/tests/io_tests.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::MemWriter; [INFO] [stderr] | ^^^^^^^^^--------- [INFO] [stderr] | | | [INFO] [stderr] | | help: a similar name exists in the module: `BufWriter` [INFO] [stderr] | no `MemWriter` in `io` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::num::Float` [INFO] [stderr] --> src/board.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::num::Float; [INFO] [stderr] | ^^^^^^^^^^^^^^^ no `Float` in `num` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::io::BufferedReader` [INFO] [stderr] --> src/io.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::io::BufferedReader; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ no `BufferedReader` in `io` [INFO] [stderr] [INFO] [stderr] error: cannot find derive macro `Show` in this scope [INFO] [stderr] --> src/token.rs:1:21 [INFO] [stderr] | [INFO] [stderr] 1 | #[derive(PartialEq, Show)] // so that tokens can be compared [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/board.rs:7:14 [INFO] [stderr] | [INFO] [stderr] 7 | for i in range(0, width * width) { [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/board.rs:32:25 [INFO] [stderr] | [INFO] [stderr] 32 | let space_numbers = range(0, board.len()). [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/board.rs:42:23 [INFO] [stderr] | [INFO] [stderr] 42 | for row_number in range(0, width) { [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/board.rs:52:26 [INFO] [stderr] | [INFO] [stderr] 52 | for column_number in range(0, width) { [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/board.rs:83:5 [INFO] [stderr] | [INFO] [stderr] 83 | range(0, board.len()). [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/io.rs:60:18 [INFO] [stderr] | [INFO] [stderr] 60 | for i in range(0, row.len()) { [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/io.rs:87:27 [INFO] [stderr] | [INFO] [stderr] 87 | for row_number in range(0, rows.len()) { [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/game.rs:6:36 [INFO] [stderr] | [INFO] [stderr] 6 | pub fn game_loop(players: &Vec>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn player::Player` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/game.rs:24:43 [INFO] [stderr] | [INFO] [stderr] 24 | pub fn play_game(players: &Vec>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn player::Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:5:31 [INFO] [stderr] | [INFO] [stderr] 5 | fn human_cpu<'a>() -> Vec> { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Player + 'a` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:6:30 [INFO] [stderr] | [INFO] [stderr] 6 | let mut players: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:12:31 [INFO] [stderr] | [INFO] [stderr] 12 | fn cpu_human<'a>() -> Vec> { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Player + 'a` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:13:30 [INFO] [stderr] | [INFO] [stderr] 13 | let mut players: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:19:33 [INFO] [stderr] | [INFO] [stderr] 19 | fn human_human<'a>() -> Vec> { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Player + 'a` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:20:30 [INFO] [stderr] | [INFO] [stderr] 20 | let mut players: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:26:56 [INFO] [stderr] | [INFO] [stderr] 26 | pub fn configure_players<'a, I: Io>(io: &I) -> Vec> { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Player + 'a` [INFO] [stderr] [INFO] [stderr] error: cannot find derive macro `Show` in this scope [INFO] [stderr] --> src/token.rs:1:21 [INFO] [stderr] | [INFO] [stderr] 1 | #[derive(PartialEq, Show)] // so that tokens can be compared [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/board.rs:7:14 [INFO] [stderr] | [INFO] [stderr] 7 | for i in range(0, width * width) { [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/board.rs:32:25 [INFO] [stderr] | [INFO] [stderr] 32 | let space_numbers = range(0, board.len()). [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/board.rs:42:23 [INFO] [stderr] | [INFO] [stderr] 42 | for row_number in range(0, width) { [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/board.rs:52:26 [INFO] [stderr] | [INFO] [stderr] 52 | for column_number in range(0, width) { [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/board.rs:83:5 [INFO] [stderr] | [INFO] [stderr] 83 | range(0, board.len()). [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/io.rs:60:18 [INFO] [stderr] | [INFO] [stderr] 60 | for i in range(0, row.len()) { [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `range` in this scope [INFO] [stderr] --> src/io.rs:87:27 [INFO] [stderr] | [INFO] [stderr] 87 | for row_number in range(0, rows.len()) { [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0603]: module `stdio` is private [INFO] [stderr] --> src/tests/io_tests.rs:2:14 [INFO] [stderr] | [INFO] [stderr] 2 | use std::io::stdio::set_stdout; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/tests/game_tests.rs:11:30 [INFO] [stderr] | [INFO] [stderr] 11 | let mut players: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/tests/game_tests.rs:22:30 [INFO] [stderr] | [INFO] [stderr] 22 | let mut players: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/tests/game_tests.rs:39:30 [INFO] [stderr] | [INFO] [stderr] 39 | let mut players: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/tests/config_tests.rs:14:31 [INFO] [stderr] | [INFO] [stderr] 14 | let mut expected: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/tests/config_tests.rs:31:31 [INFO] [stderr] | [INFO] [stderr] 31 | let mut expected: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/tests/config_tests.rs:48:31 [INFO] [stderr] | [INFO] [stderr] 48 | let mut expected: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/game.rs:6:36 [INFO] [stderr] | [INFO] [stderr] 6 | pub fn game_loop(players: &Vec>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn player::Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/game.rs:24:43 [INFO] [stderr] | [INFO] [stderr] 24 | pub fn play_game(players: &Vec>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn player::Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:5:31 [INFO] [stderr] | [INFO] [stderr] 5 | fn human_cpu<'a>() -> Vec> { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Player + 'a` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:6:30 [INFO] [stderr] | [INFO] [stderr] 6 | let mut players: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:12:31 [INFO] [stderr] | [INFO] [stderr] 12 | fn cpu_human<'a>() -> Vec> { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Player + 'a` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:13:30 [INFO] [stderr] | [INFO] [stderr] 13 | let mut players: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:19:33 [INFO] [stderr] | [INFO] [stderr] 19 | fn human_human<'a>() -> Vec> { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Player + 'a` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:20:30 [INFO] [stderr] | [INFO] [stderr] 20 | let mut players: Vec> = Vec::new(); [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/config.rs:26:56 [INFO] [stderr] | [INFO] [stderr] 26 | pub fn configure_players<'a, I: Io>(io: &I) -> Vec> { [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Player + 'a` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `std::string::String` in the current scope [INFO] [stderr] --> src/io.rs:62:69 [INFO] [stderr] | [INFO] [stderr] 62 | result.push_str(self.format_space(row[i], space_number).as_slice()); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `&&str` in the current scope [INFO] [stderr] --> src/io.rs:77:44 [INFO] [stderr] | [INFO] [stderr] 77 | position(|option| option.as_slice() == answer.trim()) { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `std::string::String` in the current scope [INFO] [stderr] --> src/io.rs:90:59 [INFO] [stderr] | [INFO] [stderr] 90 | row_number * board_width).as_slice()); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `std::string::String` in the current scope [INFO] [stderr] --> src/io.rs:92:29 [INFO] [stderr] | [INFO] [stderr] 92 | print!("{}", result.as_slice()) [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `&std::string::String` in the current scope [INFO] [stderr] --> src/player.rs:31:60 [INFO] [stderr] | [INFO] [stderr] 31 | let options = empty_space_strings.iter().map(|s| s.as_slice()).collect(); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for type `std::vec::Vec>` in the current scope [INFO] [stderr] --> src/rules.rs:14:11 [INFO] [stderr] | [INFO] [stderr] 14 | lines.push_all(board::get_columns(board).as_slice()); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for type `std::vec::Vec>` in the current scope [INFO] [stderr] --> src/rules.rs:15:11 [INFO] [stderr] | [INFO] [stderr] 15 | lines.push_all(board::get_diagonals(board).as_slice()); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0593]: closure is expected to take 2 arguments, but it takes 1 argument [INFO] [stderr] --> src/minimax.rs:37:29 [INFO] [stderr] | [INFO] [stderr] 37 | max_by(|tuple| tuple.1).unwrap(), [INFO] [stderr] | ^^^^^^ ------- takes 1 argument [INFO] [stderr] | | [INFO] [stderr] | expected closure that takes 2 arguments [INFO] [stderr] [INFO] [stderr] error[E0593]: closure is expected to take 2 arguments, but it takes 1 argument [INFO] [stderr] --> src/minimax.rs:39:29 [INFO] [stderr] | [INFO] [stderr] 39 | min_by(|tuple| tuple.1).unwrap(), [INFO] [stderr] | ^^^^^^ ------- takes 1 argument [INFO] [stderr] | | [INFO] [stderr] | expected closure that takes 2 arguments [INFO] [stderr] [INFO] [stderr] error: aborting due to 19 previous errors [INFO] [stderr] [INFO] [stderr] Some errors have detailed explanations: E0425, E0432, E0593, E0599. [INFO] [stderr] For more information about an error, try `rustc --explain E0425`. [INFO] [stderr] error: Could not compile `ttt_rust_2`. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | assert_eq!(board, expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | assert_eq!(board, expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:48:5 [INFO] [stderr] | [INFO] [stderr] 48 | assert_eq!(board, expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:48:5 [INFO] [stderr] | [INFO] [stderr] 48 | assert_eq!(board, expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:66:5 [INFO] [stderr] | [INFO] [stderr] 66 | assert_eq!(get_rows(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:66:5 [INFO] [stderr] | [INFO] [stderr] 66 | assert_eq!(get_rows(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:77:5 [INFO] [stderr] | [INFO] [stderr] 77 | assert_eq!(get_rows(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:77:5 [INFO] [stderr] | [INFO] [stderr] 77 | assert_eq!(get_rows(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:88:5 [INFO] [stderr] | [INFO] [stderr] 88 | assert_eq!(get_columns(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:88:5 [INFO] [stderr] | [INFO] [stderr] 88 | assert_eq!(get_columns(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:99:5 [INFO] [stderr] | [INFO] [stderr] 99 | assert_eq!(get_columns(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:99:5 [INFO] [stderr] | [INFO] [stderr] 99 | assert_eq!(get_columns(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:109:5 [INFO] [stderr] | [INFO] [stderr] 109 | assert_eq!(get_diagonals(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:109:5 [INFO] [stderr] | [INFO] [stderr] 109 | assert_eq!(get_diagonals(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:119:5 [INFO] [stderr] | [INFO] [stderr] 119 | assert_eq!(get_diagonals(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/board_tests.rs:119:5 [INFO] [stderr] | [INFO] [stderr] 119 | assert_eq!(get_diagonals(&board), expected); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec>` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec>` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/player_tests.rs:13:5 [INFO] [stderr] | [INFO] [stderr] 13 | / assert_eq!(cpu_player.make_move(&board), [INFO] [stderr] 14 | | board::set_space(&board, 0, Token::X)); [INFO] [stderr] | |______________________________________________________^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/player_tests.rs:13:5 [INFO] [stderr] | [INFO] [stderr] 13 | / assert_eq!(cpu_player.make_move(&board), [INFO] [stderr] 14 | | board::set_space(&board, 0, Token::X)); [INFO] [stderr] | |______________________________________________________^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/player_tests.rs:25:5 [INFO] [stderr] | [INFO] [stderr] 25 | / assert_eq!(cpu_player.make_move(&board), [INFO] [stderr] 26 | | board::set_space(&board, 7, Token::X)); [INFO] [stderr] | |______________________________________________________^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/player_tests.rs:25:5 [INFO] [stderr] | [INFO] [stderr] 25 | / assert_eq!(cpu_player.make_move(&board), [INFO] [stderr] 26 | | board::set_space(&board, 7, Token::X)); [INFO] [stderr] | |______________________________________________________^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/player_tests.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | / assert_eq!(cpu_player.make_move(&board), [INFO] [stderr] 38 | | board::set_space(&board, 5, Token::O)); [INFO] [stderr] | |______________________________________________________^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/player_tests.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | / assert_eq!(cpu_player.make_move(&board), [INFO] [stderr] 38 | | board::set_space(&board, 5, Token::O)); [INFO] [stderr] | |______________________________________________________^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/player_tests.rs:51:5 [INFO] [stderr] | [INFO] [stderr] 51 | assert_eq!(human_player.make_move(&board), expected_result); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/player_tests.rs:51:5 [INFO] [stderr] | [INFO] [stderr] 51 | assert_eq!(human_player.make_move(&board), expected_result); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::vec::Vec` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::vec::Vec` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/rules_tests.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | assert_eq!(get_winner(&board), Some(Token::O)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::option::Option` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::option::Option` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/rules_tests.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | assert_eq!(get_winner(&board), Some(Token::O)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::option::Option` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::option::Option` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/rules_tests.rs:46:5 [INFO] [stderr] | [INFO] [stderr] 46 | assert_eq!(get_winner(&board), None); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::option::Option` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::option::Option` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/rules_tests.rs:46:5 [INFO] [stderr] | [INFO] [stderr] 46 | assert_eq!(get_winner(&board), None); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::option::Option` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::option::Option` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/rules_tests.rs:53:5 [INFO] [stderr] | [INFO] [stderr] 53 | assert_eq!(get_winner(&board), None); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::option::Option` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::option::Option` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/rules_tests.rs:53:5 [INFO] [stderr] | [INFO] [stderr] 53 | assert_eq!(get_winner(&board), None); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `std::option::Option` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&std::option::Option` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/rules_tests.rs:60:5 [INFO] [stderr] | [INFO] [stderr] 60 | assert_eq!(get_turn_token(&board), Token::X); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/rules_tests.rs:60:5 [INFO] [stderr] | [INFO] [stderr] 60 | assert_eq!(get_turn_token(&board), Token::X); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/rules_tests.rs:69:5 [INFO] [stderr] | [INFO] [stderr] 69 | assert_eq!(get_turn_token(&board), Token::O); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/rules_tests.rs:69:5 [INFO] [stderr] | [INFO] [stderr] 69 | assert_eq!(get_turn_token(&board), Token::O); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/game_tests.rs:33:5 [INFO] [stderr] | [INFO] [stderr] 33 | assert_eq!(winner.unwrap(), Token::X); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/game_tests.rs:33:5 [INFO] [stderr] | [INFO] [stderr] 33 | assert_eq!(winner.unwrap(), Token::X); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/game_tests.rs:50:5 [INFO] [stderr] | [INFO] [stderr] 50 | assert_eq!(winner.unwrap(), Token::O); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/game_tests.rs:50:5 [INFO] [stderr] | [INFO] [stderr] 50 | assert_eq!(winner.unwrap(), Token::O); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:20:5 [INFO] [stderr] | [INFO] [stderr] 20 | assert_eq!(players[0].get_token(), Token::X); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:20:5 [INFO] [stderr] | [INFO] [stderr] 20 | assert_eq!(players[0].get_token(), Token::X); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:21:5 [INFO] [stderr] | [INFO] [stderr] 21 | assert_eq!(players[1].get_token(), Token::O); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:21:5 [INFO] [stderr] | [INFO] [stderr] 21 | assert_eq!(players[1].get_token(), Token::O); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | assert_eq!(players[0].get_token(), Token::X); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | assert_eq!(players[0].get_token(), Token::X); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | assert_eq!(players[1].get_token(), Token::O); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | assert_eq!(players[1].get_token(), Token::O); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:54:5 [INFO] [stderr] | [INFO] [stderr] 54 | assert_eq!(players[0].get_token(), Token::X); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:54:5 [INFO] [stderr] | [INFO] [stderr] 54 | assert_eq!(players[0].get_token(), Token::X); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:55:5 [INFO] [stderr] | [INFO] [stderr] 55 | assert_eq!(players[1].get_token(), Token::O); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0277]: `token::Token` doesn't implement `std::fmt::Debug` [INFO] [stderr] --> src/tests/config_tests.rs:55:5 [INFO] [stderr] | [INFO] [stderr] 55 | assert_eq!(players[1].get_token(), Token::O); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `token::Token` cannot be formatted using `{:?}` [INFO] [stderr] | [INFO] [stderr] = help: the trait `std::fmt::Debug` is not implemented for `token::Token` [INFO] [stderr] = note: add `#[derive(Debug)]` or manually implement `std::fmt::Debug` [INFO] [stderr] = note: required because of the requirements on the impl of `std::fmt::Debug` for `&token::Token` [INFO] [stderr] = note: required by `std::fmt::Debug::fmt` [INFO] [stderr] = note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `std::string::String` in the current scope [INFO] [stderr] --> src/io.rs:62:69 [INFO] [stderr] | [INFO] [stderr] 62 | result.push_str(self.format_space(row[i], space_number).as_slice()); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `&&str` in the current scope [INFO] [stderr] --> src/io.rs:77:44 [INFO] [stderr] | [INFO] [stderr] 77 | position(|option| option.as_slice() == answer.trim()) { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `std::string::String` in the current scope [INFO] [stderr] --> src/io.rs:90:59 [INFO] [stderr] | [INFO] [stderr] 90 | row_number * board_width).as_slice()); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `std::string::String` in the current scope [INFO] [stderr] --> src/io.rs:92:29 [INFO] [stderr] | [INFO] [stderr] 92 | print!("{}", result.as_slice()) [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `&std::string::String` in the current scope [INFO] [stderr] --> src/player.rs:31:60 [INFO] [stderr] | [INFO] [stderr] 31 | let options = empty_space_strings.iter().map(|s| s.as_slice()).collect(); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for type `std::vec::Vec>` in the current scope [INFO] [stderr] --> src/rules.rs:14:11 [INFO] [stderr] | [INFO] [stderr] 14 | lines.push_all(board::get_columns(board).as_slice()); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for type `std::vec::Vec>` in the current scope [INFO] [stderr] --> src/rules.rs:15:11 [INFO] [stderr] | [INFO] [stderr] 15 | lines.push_all(board::get_diagonals(board).as_slice()); [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0593]: closure is expected to take 2 arguments, but it takes 1 argument [INFO] [stderr] --> src/minimax.rs:37:29 [INFO] [stderr] | [INFO] [stderr] 37 | max_by(|tuple| tuple.1).unwrap(), [INFO] [stderr] | ^^^^^^ ------- takes 1 argument [INFO] [stderr] | | [INFO] [stderr] | expected closure that takes 2 arguments [INFO] [stderr] [INFO] [stderr] error[E0593]: closure is expected to take 2 arguments, but it takes 1 argument [INFO] [stderr] --> src/minimax.rs:39:29 [INFO] [stderr] | [INFO] [stderr] 39 | min_by(|tuple| tuple.1).unwrap(), [INFO] [stderr] | ^^^^^^ ------- takes 1 argument [INFO] [stderr] | | [INFO] [stderr] | expected closure that takes 2 arguments [INFO] [stderr] [INFO] [stderr] error: aborting due to 72 previous errors [INFO] [stderr] [INFO] [stderr] Some errors have detailed explanations: E0277, E0425, E0432, E0593, E0599, E0603. [INFO] [stderr] For more information about an error, try `rustc --explain E0277`. [INFO] [stderr] error: Could not compile `ttt_rust_2`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] running `"docker" "inspect" "66e5372dffa6a783370ae069eee7c1e530f620f1ed29f61efba025d96e4b1ab4"` [INFO] running `"docker" "rm" "-f" "66e5372dffa6a783370ae069eee7c1e530f620f1ed29f61efba025d96e4b1ab4"` [INFO] [stdout] 66e5372dffa6a783370ae069eee7c1e530f620f1ed29f61efba025d96e4b1ab4