[INFO] cloning repository https://github.com/itotallyrock/oxide [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/itotallyrock/oxide" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fitotallyrock%2Foxide", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fitotallyrock%2Foxide'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] d6f4f14c632fc03cec8c676e802a7a43993fe5eb [INFO] testing itotallyrock/oxide against master#99e3aef02079e9c10583638520cd0c134dc3a01d for pr-85530 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fitotallyrock%2Foxide" "/workspace/builds/worker-2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-2/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/itotallyrock/oxide on toolchain 99e3aef02079e9c10583638520cd0c134dc3a01d [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+99e3aef02079e9c10583638520cd0c134dc3a01d" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/itotallyrock/oxide [INFO] finished tweaking git repo https://github.com/itotallyrock/oxide [INFO] tweaked toml for git repo https://github.com/itotallyrock/oxide written to /workspace/builds/worker-2/source/Cargo.toml [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+99e3aef02079e9c10583638520cd0c134dc3a01d" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }` [INFO] [stderr] warning: profiles for the non root package will be ignored, specify profiles at the workspace root: [INFO] [stderr] package: /workspace/builds/worker-2/source/oxide-interface/Cargo.toml [INFO] [stderr] workspace: /workspace/builds/worker-2/source/Cargo.toml [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+99e3aef02079e9c10583638520cd0c134dc3a01d" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] warning: profiles for the non root package will be ignored, specify profiles at the workspace root: [INFO] [stderr] package: /workspace/builds/worker-2/source/oxide-interface/Cargo.toml [INFO] [stderr] workspace: /workspace/builds/worker-2/source/Cargo.toml [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/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:20528e8c29e4536546f0102ce88568b16ea7538393a33fcca951030f7af10457" "/opt/rustwide/cargo-home/bin/cargo" "+99e3aef02079e9c10583638520cd0c134dc3a01d" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 611561084e8591261e575c35ed611edee0b9121e51337369a8462dd866c9cd60 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "611561084e8591261e575c35ed611edee0b9121e51337369a8462dd866c9cd60", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "611561084e8591261e575c35ed611edee0b9121e51337369a8462dd866c9cd60", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "611561084e8591261e575c35ed611edee0b9121e51337369a8462dd866c9cd60", kill_on_drop: false }` [INFO] [stdout] 611561084e8591261e575c35ed611edee0b9121e51337369a8462dd866c9cd60 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/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" "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:20528e8c29e4536546f0102ce88568b16ea7538393a33fcca951030f7af10457" "/opt/rustwide/cargo-home/bin/cargo" "+99e3aef02079e9c10583638520cd0c134dc3a01d" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 9244e4b2cbf6d8ce73168f8fc9074f9f52aab239975ac4a86b0a4cf11126f04f [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "9244e4b2cbf6d8ce73168f8fc9074f9f52aab239975ac4a86b0a4cf11126f04f", kill_on_drop: false }` [INFO] [stderr] warning: profiles for the non root package will be ignored, specify profiles at the workspace root: [INFO] [stderr] package: /opt/rustwide/workdir/oxide-interface/Cargo.toml [INFO] [stderr] workspace: /opt/rustwide/workdir/Cargo.toml [INFO] [stderr] Compiling interface v0.1.0 (/opt/rustwide/workdir/interface) [INFO] [stderr] Compiling lazy_static v1.4.0 [INFO] [stderr] Compiling smallvec v1.6.1 [INFO] [stdout] warning: unused import: `std::convert::TryFrom` [INFO] [stdout] --> interface/src/game/castle.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::convert::TryFrom; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling attacks v0.1.0 (/opt/rustwide/workdir/attacks) [INFO] [stdout] warning: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling oxide-interface v0.1.0 (/opt/rustwide/workdir/oxide-interface) [INFO] [stderr] Compiling move-gen v0.1.0 (/opt/rustwide/workdir/move-gen) [INFO] [stdout] warning: unused imports: `CastleRights`, `ChessMove`, `Square` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:58 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `OxideSidedPiece` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:3:89 [INFO] [stdout] | [INFO] [stdout] 3 | use crate::game::{OxidePiece, OxideBitboard, OxideSquare, OxideCastleRights, OxideSide, OxideSidedPiece, OxideMove, OxideSimpleMove, Oxid... [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::engine::OxideFenParseError` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use crate::engine::OxideFenParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `const_generics` is incomplete and may not be safe to use and/or cause compiler crashes [INFO] [stdout] --> move-gen/src/lib.rs:1:12 [INFO] [stdout] | [INFO] [stdout] 1 | #![feature(const_generics)] [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(incomplete_features)]` on by default [INFO] [stdout] = note: see issue #44580 for more information [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:283:5 [INFO] [stdout] | [INFO] [stdout] 281 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 282 | [INFO] [stdout] 283 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:276:9 [INFO] [stdout] | [INFO] [stdout] 276 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [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: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:292:5 [INFO] [stdout] | [INFO] [stdout] 290 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 291 | [INFO] [stdout] 292 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:288:9 [INFO] [stdout] | [INFO] [stdout] 288 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:301:5 [INFO] [stdout] | [INFO] [stdout] 299 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 300 | [INFO] [stdout] 301 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:297:9 [INFO] [stdout] | [INFO] [stdout] 297 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:312:5 [INFO] [stdout] | [INFO] [stdout] 310 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 311 | [INFO] [stdout] 312 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:308:9 [INFO] [stdout] | [INFO] [stdout] 308 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `side_moving` [INFO] [stdout] --> move-gen/src/lib.rs:208:68 [INFO] [stdout] | [INFO] [stdout] 208 | fn can_castle, const N: usize>(board: &B, side_moving: P::Side, castle_in_question: P::CastleRights) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_side_moving` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:276:13 [INFO] [stdout] | [INFO] [stdout] 276 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `target_mask` [INFO] [stdout] --> move-gen/src/lib.rs:279:9 [INFO] [stdout] | [INFO] [stdout] 279 | let target_mask = board.position().mask_for_side(opposite_side); [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_mask` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:288:13 [INFO] [stdout] | [INFO] [stdout] 288 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> move-gen/src/lib.rs:287:46 [INFO] [stdout] | [INFO] [stdout] 287 | pub fn quiet_moves>(board: &B) -> impl Iterator { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:297:13 [INFO] [stdout] | [INFO] [stdout] 297 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> move-gen/src/lib.rs:296:52 [INFO] [stdout] | [INFO] [stdout] 296 | pub fn quiet_check_moves>(board: &B) -> impl Iterator { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:308:13 [INFO] [stdout] | [INFO] [stdout] 308 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 17 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PieceArrangement` [INFO] [stdout] --> oxide-interface/src/game/oxide_bitboard/line.rs:2:33 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{LineMask, PieceArrangement, Position, Square, BoardMask}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `interface::engine::Board` [INFO] [stdout] --> oxide-interface/src/game/chess_move/mod.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use interface::engine::Board; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PieceArrangement` [INFO] [stdout] --> oxide-interface/src/game/castle.rs:1:43 [INFO] [stdout] | [INFO] [stdout] 1 | use interface::game::{CastleRights, Side, PieceArrangement, BoardMask}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PieceArrangement` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:23 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `SimpleChessMove` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:41 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Piece` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:100 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `SidedPiece` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:107 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> oxide-interface/src/game/chess_move/mod.rs:196:55 [INFO] [stdout] | [INFO] [stdout] 196 | fn from_simple_move(simple_move: OxideSimpleMove, board: &OxideBoard) -> Self { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:142:29 [INFO] [stdout] | [INFO] [stdout] 142 | fn make_move(&mut self, chess_move: Self::Move) -> Result { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:146:39 [INFO] [stdout] | [INFO] [stdout] 146 | fn make_move_unchecked(&mut self, chess_move: Self::Move) -> Self::BoardState { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:150:29 [INFO] [stdout] | [INFO] [stdout] 150 | fn undo_move(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) -> Result<(), Self::UndoMoveError> { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `previous_state` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:150:53 [INFO] [stdout] | [INFO] [stdout] 150 | fn undo_move(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) -> Result<(), Self::UndoMoveError> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_previous_state` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:154:39 [INFO] [stdout] | [INFO] [stdout] 154 | fn undo_move_unchecked(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `previous_state` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:154:63 [INFO] [stdout] | [INFO] [stdout] 154 | fn undo_move_unchecked(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_previous_state` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:162:28 [INFO] [stdout] | [INFO] [stdout] 162 | fn is_discovery(&self, chess_move: &Self::Move) -> bool { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:166:27 [INFO] [stdout] | [INFO] [stdout] 166 | fn gives_check(&self, chess_move: &Self::Move) -> bool { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:170:24 [INFO] [stdout] | [INFO] [stdout] 170 | fn is_legal(&self, chess_move: &Self::Move) -> bool { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 21 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling uci-engine v0.1.0 (/opt/rustwide/workdir/uci-engine) [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> uci-engine/src/main.rs:16:9 [INFO] [stdout] | [INFO] [stdout] 16 | let mut t = OxideMove::new_promoting_capture(E7, F8, OxidePiece::Queen); [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: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 3.66s [INFO] running `Command { std: "docker" "inspect" "9244e4b2cbf6d8ce73168f8fc9074f9f52aab239975ac4a86b0a4cf11126f04f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "9244e4b2cbf6d8ce73168f8fc9074f9f52aab239975ac4a86b0a4cf11126f04f", kill_on_drop: false }` [INFO] [stdout] 9244e4b2cbf6d8ce73168f8fc9074f9f52aab239975ac4a86b0a4cf11126f04f [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/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" "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:20528e8c29e4536546f0102ce88568b16ea7538393a33fcca951030f7af10457" "/opt/rustwide/cargo-home/bin/cargo" "+99e3aef02079e9c10583638520cd0c134dc3a01d" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 458fa179ccf2507d7febb4baf81aad02adcb87181a66abe72a1ff6058192d271 [INFO] running `Command { std: "docker" "start" "-a" "458fa179ccf2507d7febb4baf81aad02adcb87181a66abe72a1ff6058192d271", kill_on_drop: false }` [INFO] [stderr] warning: profiles for the non root package will be ignored, specify profiles at the workspace root: [INFO] [stderr] package: /opt/rustwide/workdir/oxide-interface/Cargo.toml [INFO] [stderr] workspace: /opt/rustwide/workdir/Cargo.toml [INFO] [stdout] warning: unused import: `std::convert::TryFrom` [INFO] [stdout] --> interface/src/game/castle.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::convert::TryFrom; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling interface v0.1.0 (/opt/rustwide/workdir/interface) [INFO] [stdout] warning: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling oxide-interface v0.1.0 (/opt/rustwide/workdir/oxide-interface) [INFO] [stderr] Compiling move-gen v0.1.0 (/opt/rustwide/workdir/move-gen) [INFO] [stderr] Compiling uci-engine v0.1.0 (/opt/rustwide/workdir/uci-engine) [INFO] [stderr] Compiling attacks v0.1.0 (/opt/rustwide/workdir/attacks) [INFO] [stdout] warning: unused imports: `CastleRights`, `ChessMove`, `Square` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:58 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `OxideSidedPiece` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:3:89 [INFO] [stdout] | [INFO] [stdout] 3 | use crate::game::{OxidePiece, OxideBitboard, OxideSquare, OxideCastleRights, OxideSide, OxideSidedPiece, OxideMove, OxideSimpleMove, Oxid... [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::engine::OxideFenParseError` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use crate::engine::OxideFenParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PieceArrangement` [INFO] [stdout] --> oxide-interface/src/game/oxide_bitboard/line.rs:2:33 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{LineMask, PieceArrangement, Position, Square, BoardMask}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `interface::engine::Board` [INFO] [stdout] --> oxide-interface/src/game/chess_move/mod.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use interface::engine::Board; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PieceArrangement` [INFO] [stdout] --> oxide-interface/src/game/castle.rs:1:43 [INFO] [stdout] | [INFO] [stdout] 1 | use interface::game::{CastleRights, Side, PieceArrangement, BoardMask}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PieceArrangement` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:23 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `SimpleChessMove` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:41 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Piece` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:100 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `SidedPiece` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:107 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> oxide-interface/src/game/chess_move/mod.rs:196:55 [INFO] [stdout] | [INFO] [stdout] 196 | fn from_simple_move(simple_move: OxideSimpleMove, board: &OxideBoard) -> Self { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:142:29 [INFO] [stdout] | [INFO] [stdout] 142 | fn make_move(&mut self, chess_move: Self::Move) -> Result { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:146:39 [INFO] [stdout] | [INFO] [stdout] 146 | fn make_move_unchecked(&mut self, chess_move: Self::Move) -> Self::BoardState { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:150:29 [INFO] [stdout] | [INFO] [stdout] 150 | fn undo_move(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) -> Result<(), Self::UndoMoveError> { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `previous_state` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:150:53 [INFO] [stdout] | [INFO] [stdout] 150 | fn undo_move(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) -> Result<(), Self::UndoMoveError> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_previous_state` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:154:39 [INFO] [stdout] | [INFO] [stdout] 154 | fn undo_move_unchecked(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `previous_state` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:154:63 [INFO] [stdout] | [INFO] [stdout] 154 | fn undo_move_unchecked(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_previous_state` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:162:28 [INFO] [stdout] | [INFO] [stdout] 162 | fn is_discovery(&self, chess_move: &Self::Move) -> bool { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:166:27 [INFO] [stdout] | [INFO] [stdout] 166 | fn gives_check(&self, chess_move: &Self::Move) -> bool { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:170:24 [INFO] [stdout] | [INFO] [stdout] 170 | fn is_legal(&self, chess_move: &Self::Move) -> bool { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 21 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the feature `const_generics` is incomplete and may not be safe to use and/or cause compiler crashes [INFO] [stdout] --> move-gen/src/lib.rs:1:12 [INFO] [stdout] | [INFO] [stdout] 1 | #![feature(const_generics)] [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(incomplete_features)]` on by default [INFO] [stdout] = note: see issue #44580 for more information [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:283:5 [INFO] [stdout] | [INFO] [stdout] 281 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 282 | [INFO] [stdout] 283 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:276:9 [INFO] [stdout] | [INFO] [stdout] 276 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [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: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:292:5 [INFO] [stdout] | [INFO] [stdout] 290 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 291 | [INFO] [stdout] 292 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:288:9 [INFO] [stdout] | [INFO] [stdout] 288 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:301:5 [INFO] [stdout] | [INFO] [stdout] 299 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 300 | [INFO] [stdout] 301 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:297:9 [INFO] [stdout] | [INFO] [stdout] 297 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:312:5 [INFO] [stdout] | [INFO] [stdout] 310 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 311 | [INFO] [stdout] 312 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:308:9 [INFO] [stdout] | [INFO] [stdout] 308 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `side_moving` [INFO] [stdout] --> move-gen/src/lib.rs:208:68 [INFO] [stdout] | [INFO] [stdout] 208 | fn can_castle, const N: usize>(board: &B, side_moving: P::Side, castle_in_question: P::CastleRights) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_side_moving` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:276:13 [INFO] [stdout] | [INFO] [stdout] 276 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `target_mask` [INFO] [stdout] --> move-gen/src/lib.rs:279:9 [INFO] [stdout] | [INFO] [stdout] 279 | let target_mask = board.position().mask_for_side(opposite_side); [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_mask` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:288:13 [INFO] [stdout] | [INFO] [stdout] 288 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> move-gen/src/lib.rs:287:46 [INFO] [stdout] | [INFO] [stdout] 287 | pub fn quiet_moves>(board: &B) -> impl Iterator { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:297:13 [INFO] [stdout] | [INFO] [stdout] 297 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> move-gen/src/lib.rs:296:52 [INFO] [stdout] | [INFO] [stdout] 296 | pub fn quiet_check_moves>(board: &B) -> impl Iterator { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:308:13 [INFO] [stdout] | [INFO] [stdout] 308 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 17 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::convert::TryFrom` [INFO] [stdout] --> interface/src/game/castle.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::convert::TryFrom; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> uci-engine/src/main.rs:16:9 [INFO] [stdout] | [INFO] [stdout] 16 | let mut t = OxideMove::new_promoting_capture(E7, F8, OxidePiece::Queen); [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: the feature `const_generics` is incomplete and may not be safe to use and/or cause compiler crashes [INFO] [stdout] --> move-gen/src/lib.rs:1:12 [INFO] [stdout] | [INFO] [stdout] 1 | #![feature(const_generics)] [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(incomplete_features)]` on by default [INFO] [stdout] = note: see issue #44580 for more information [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `OxideSimpleMove` [INFO] [stdout] --> move-gen/src/lib.rs:330:44 [INFO] [stdout] | [INFO] [stdout] 330 | use oxide_interface::game::{OxideMove, OxideSimpleMove, OxideSquare::*}; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:283:5 [INFO] [stdout] | [INFO] [stdout] 281 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 282 | [INFO] [stdout] 283 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:276:9 [INFO] [stdout] | [INFO] [stdout] 276 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [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: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:292:5 [INFO] [stdout] | [INFO] [stdout] 290 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 291 | [INFO] [stdout] 292 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:288:9 [INFO] [stdout] | [INFO] [stdout] 288 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:301:5 [INFO] [stdout] | [INFO] [stdout] 299 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 300 | [INFO] [stdout] 301 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:297:9 [INFO] [stdout] | [INFO] [stdout] 297 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> move-gen/src/lib.rs:312:5 [INFO] [stdout] | [INFO] [stdout] 310 | todo!(); [INFO] [stdout] | -------- any code following this expression is unreachable [INFO] [stdout] 311 | [INFO] [stdout] 312 | list.into_iter() [INFO] [stdout] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> move-gen/src/lib.rs:308:9 [INFO] [stdout] | [INFO] [stdout] 308 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `side_moving` [INFO] [stdout] --> move-gen/src/lib.rs:208:68 [INFO] [stdout] | [INFO] [stdout] 208 | fn can_castle, const N: usize>(board: &B, side_moving: P::Side, castle_in_question: P::CastleRights) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_side_moving` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:276:13 [INFO] [stdout] | [INFO] [stdout] 276 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `target_mask` [INFO] [stdout] --> move-gen/src/lib.rs:279:9 [INFO] [stdout] | [INFO] [stdout] 279 | let target_mask = board.position().mask_for_side(opposite_side); [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_mask` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:288:13 [INFO] [stdout] | [INFO] [stdout] 288 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> move-gen/src/lib.rs:287:46 [INFO] [stdout] | [INFO] [stdout] 287 | pub fn quiet_moves>(board: &B) -> impl Iterator { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:297:13 [INFO] [stdout] | [INFO] [stdout] 297 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> move-gen/src/lib.rs:296:52 [INFO] [stdout] | [INFO] [stdout] 296 | pub fn quiet_check_moves>(board: &B) -> impl Iterator { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `list` [INFO] [stdout] --> move-gen/src/lib.rs:308:13 [INFO] [stdout] | [INFO] [stdout] 308 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `CastleRights`, `ChessMove`, `Square` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:58 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `OxideSidedPiece` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:3:89 [INFO] [stdout] | [INFO] [stdout] 3 | use crate::game::{OxidePiece, OxideBitboard, OxideSquare, OxideCastleRights, OxideSide, OxideSidedPiece, OxideMove, OxideSimpleMove, Oxid... [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::engine::OxideFenParseError` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use crate::engine::OxideFenParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 18 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PieceArrangement` [INFO] [stdout] --> oxide-interface/src/game/oxide_bitboard/line.rs:2:33 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{LineMask, PieceArrangement, Position, Square, BoardMask}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `interface::engine::Board` [INFO] [stdout] --> oxide-interface/src/game/chess_move/mod.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use interface::engine::Board; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PieceArrangement` [INFO] [stdout] --> oxide-interface/src/game/castle.rs:1:43 [INFO] [stdout] | [INFO] [stdout] 1 | use interface::game::{CastleRights, Side, PieceArrangement, BoardMask}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PieceArrangement` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:23 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `SimpleChessMove` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:41 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Piece` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:100 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `SidedPiece` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:2:107 [INFO] [stdout] | [INFO] [stdout] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `board` [INFO] [stdout] --> oxide-interface/src/game/chess_move/mod.rs:196:55 [INFO] [stdout] | [INFO] [stdout] 196 | fn from_simple_move(simple_move: OxideSimpleMove, board: &OxideBoard) -> Self { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:142:29 [INFO] [stdout] | [INFO] [stdout] 142 | fn make_move(&mut self, chess_move: Self::Move) -> Result { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:146:39 [INFO] [stdout] | [INFO] [stdout] 146 | fn make_move_unchecked(&mut self, chess_move: Self::Move) -> Self::BoardState { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:150:29 [INFO] [stdout] | [INFO] [stdout] 150 | fn undo_move(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) -> Result<(), Self::UndoMoveError> { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `previous_state` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:150:53 [INFO] [stdout] | [INFO] [stdout] 150 | fn undo_move(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) -> Result<(), Self::UndoMoveError> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_previous_state` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:154:39 [INFO] [stdout] | [INFO] [stdout] 154 | fn undo_move_unchecked(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `previous_state` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:154:63 [INFO] [stdout] | [INFO] [stdout] 154 | fn undo_move_unchecked(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_previous_state` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:162:28 [INFO] [stdout] | [INFO] [stdout] 162 | fn is_discovery(&self, chess_move: &Self::Move) -> bool { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:166:27 [INFO] [stdout] | [INFO] [stdout] 166 | fn gives_check(&self, chess_move: &Self::Move) -> bool { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `chess_move` [INFO] [stdout] --> oxide-interface/src/engine/board/mod.rs:170:24 [INFO] [stdout] | [INFO] [stdout] 170 | fn is_legal(&self, chess_move: &Self::Move) -> bool { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 21 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 5.27s [INFO] running `Command { std: "docker" "inspect" "458fa179ccf2507d7febb4baf81aad02adcb87181a66abe72a1ff6058192d271", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "458fa179ccf2507d7febb4baf81aad02adcb87181a66abe72a1ff6058192d271", kill_on_drop: false }` [INFO] [stdout] 458fa179ccf2507d7febb4baf81aad02adcb87181a66abe72a1ff6058192d271 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/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" "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:20528e8c29e4536546f0102ce88568b16ea7538393a33fcca951030f7af10457" "/opt/rustwide/cargo-home/bin/cargo" "+99e3aef02079e9c10583638520cd0c134dc3a01d" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 6d210ec3dc61303128aa02385a24a366a44911d1ae9f6083d8eef13d576e832c [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "6d210ec3dc61303128aa02385a24a366a44911d1ae9f6083d8eef13d576e832c", kill_on_drop: false }` [INFO] [stdout] [INFO] [stderr] warning: profiles for the non root package will be ignored, specify profiles at the workspace root: [INFO] [stdout] running 18 tests [INFO] [stderr] package: /opt/rustwide/workdir/oxide-interface/Cargo.toml [INFO] [stdout] test king::bench::king_attack_bench ... ok [INFO] [stderr] workspace: /opt/rustwide/workdir/Cargo.toml [INFO] [stdout] test king::test::king_attacks_works ... ok [INFO] [stderr] warning: unused import: `std::convert::TryFrom` [INFO] [stdout] test knight::bench::knight_attack_bench ... ok [INFO] [stderr] --> interface/src/game/castle.rs:4:5 [INFO] [stdout] test pawn::bench::white_pawn_attacks_bench ... ok [INFO] [stderr] | [INFO] [stdout] test pawn::bench::white_pawn_pushes_bench ... ok [INFO] [stderr] 4 | use std::convert::TryFrom; [INFO] [stdout] test pawn::test::pawn_attacks_works ... ok [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] test pawn::test::pawn_pushes_works ... ok [INFO] [stderr] | [INFO] [stdout] test sliding::bench::queen_attacks_bench ... ok [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] test sliding::bench::rook_attacks_bench ... ok [INFO] [stderr] [INFO] [stdout] test sliding::test::bishop_attack_works ... ok [INFO] [stderr] warning: 1 warning emitted [INFO] [stdout] test sliding::test::queen_attack_works ... ok [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::convert::TryFrom` [INFO] [stderr] --> interface/src/game/castle.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::convert::TryFrom; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] warning: unused imports: `CastleRights`, `ChessMove`, `Square` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:2:58 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stderr] | ^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `OxideSidedPiece` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:3:89 [INFO] [stderr] | [INFO] [stderr] 3 | use crate::game::{OxidePiece, OxideBitboard, OxideSquare, OxideCastleRights, OxideSide, OxideSidedPiece, OxideMove, OxideSimpleMove, Oxid... [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `crate::engine::OxideFenParseError` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use crate::engine::OxideFenParseError; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `PieceArrangement` [INFO] [stderr] --> oxide-interface/src/game/oxide_bitboard/line.rs:2:33 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{LineMask, PieceArrangement, Position, Square, BoardMask}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `interface::engine::Board` [INFO] [stderr] --> oxide-interface/src/game/chess_move/mod.rs:15:5 [INFO] [stderr] | [INFO] [stderr] 15 | use interface::engine::Board; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `PieceArrangement` [INFO] [stderr] --> oxide-interface/src/game/castle.rs:1:43 [INFO] [stderr] | [INFO] [stderr] 1 | use interface::game::{CastleRights, Side, PieceArrangement, BoardMask}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `PieceArrangement` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:2:23 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `SimpleChessMove` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:2:41 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Piece` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:2:100 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `SidedPiece` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:2:107 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `board` [INFO] [stderr] --> oxide-interface/src/game/chess_move/mod.rs:196:55 [INFO] [stderr] | [INFO] [stderr] 196 | fn from_simple_move(simple_move: OxideSimpleMove, board: &OxideBoard) -> Self { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:142:29 [INFO] [stderr] | [INFO] [stderr] 142 | fn make_move(&mut self, chess_move: Self::Move) -> Result { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:146:39 [INFO] [stderr] | [INFO] [stderr] 146 | fn make_move_unchecked(&mut self, chess_move: Self::Move) -> Self::BoardState { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:150:29 [INFO] [stderr] | [INFO] [stderr] 150 | fn undo_move(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) -> Result<(), Self::UndoMoveError> { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `previous_state` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:150:53 [INFO] [stderr] | [INFO] [stderr] 150 | fn undo_move(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) -> Result<(), Self::UndoMoveError> { [INFO] [stderr] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_previous_state` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:154:39 [INFO] [stderr] | [INFO] [stderr] 154 | fn undo_move_unchecked(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `previous_state` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:154:63 [INFO] [stderr] | [INFO] [stderr] 154 | fn undo_move_unchecked(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) { [INFO] [stderr] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_previous_state` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:162:28 [INFO] [stderr] | [INFO] [stderr] 162 | fn is_discovery(&self, chess_move: &Self::Move) -> bool { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:166:27 [INFO] [stderr] | [INFO] [stderr] 166 | fn gives_check(&self, chess_move: &Self::Move) -> bool { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:170:24 [INFO] [stderr] | [INFO] [stderr] 170 | fn is_legal(&self, chess_move: &Self::Move) -> bool { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: 21 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: unused imports: `CastleRights`, `ChessMove`, `Square` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:2:58 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stderr] | ^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `OxideSidedPiece` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:3:89 [INFO] [stderr] | [INFO] [stderr] 3 | use crate::game::{OxidePiece, OxideBitboard, OxideSquare, OxideCastleRights, OxideSide, OxideSidedPiece, OxideMove, OxideSimpleMove, Oxid... [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `crate::engine::OxideFenParseError` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use crate::engine::OxideFenParseError; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `PieceArrangement` [INFO] [stderr] --> oxide-interface/src/game/oxide_bitboard/line.rs:2:33 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{LineMask, PieceArrangement, Position, Square, BoardMask}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `interface::engine::Board` [INFO] [stderr] --> oxide-interface/src/game/chess_move/mod.rs:15:5 [INFO] [stderr] | [INFO] [stderr] 15 | use interface::engine::Board; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `PieceArrangement` [INFO] [stderr] --> oxide-interface/src/game/castle.rs:1:43 [INFO] [stderr] | [INFO] [stderr] 1 | use interface::game::{CastleRights, Side, PieceArrangement, BoardMask}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `PieceArrangement` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:2:23 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `SimpleChessMove` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:2:41 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Piece` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:2:100 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `SidedPiece` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:2:107 [INFO] [stderr] | [INFO] [stderr] 2 | use interface::game::{PieceArrangement, SimpleChessMove, ChessMove, Side, BoardMask, CastleRights, Piece, SidedPiece, Square, Position}; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `board` [INFO] [stderr] --> oxide-interface/src/game/chess_move/mod.rs:196:55 [INFO] [stderr] | [INFO] [stderr] 196 | fn from_simple_move(simple_move: OxideSimpleMove, board: &OxideBoard) -> Self { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:142:29 [INFO] [stderr] | [INFO] [stderr] 142 | fn make_move(&mut self, chess_move: Self::Move) -> Result { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:146:39 [INFO] [stderr] | [INFO] [stderr] 146 | fn make_move_unchecked(&mut self, chess_move: Self::Move) -> Self::BoardState { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:150:29 [INFO] [stderr] | [INFO] [stderr] 150 | fn undo_move(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) -> Result<(), Self::UndoMoveError> { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `previous_state` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:150:53 [INFO] [stderr] | [INFO] [stderr] 150 | fn undo_move(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) -> Result<(), Self::UndoMoveError> { [INFO] [stderr] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_previous_state` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:154:39 [INFO] [stderr] | [INFO] [stderr] 154 | fn undo_move_unchecked(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `previous_state` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:154:63 [INFO] [stderr] | [INFO] [stderr] 154 | fn undo_move_unchecked(&mut self, chess_move: Self::Move, previous_state: Self::BoardState) { [INFO] [stderr] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_previous_state` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:162:28 [INFO] [stderr] | [INFO] [stderr] 162 | fn is_discovery(&self, chess_move: &Self::Move) -> bool { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:166:27 [INFO] [stderr] | [INFO] [stderr] 166 | fn gives_check(&self, chess_move: &Self::Move) -> bool { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `chess_move` [INFO] [stderr] --> oxide-interface/src/engine/board/mod.rs:170:24 [INFO] [stderr] | [INFO] [stderr] 170 | fn is_legal(&self, chess_move: &Self::Move) -> bool { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chess_move` [INFO] [stderr] [INFO] [stderr] warning: 21 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: the feature `const_generics` is incomplete and may not be safe to use and/or cause compiler crashes [INFO] [stderr] --> move-gen/src/lib.rs:1:12 [INFO] [stderr] | [INFO] [stderr] 1 | #![feature(const_generics)] [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(incomplete_features)]` on by default [INFO] [stderr] = note: see issue #44580 for more information [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> move-gen/src/lib.rs:283:5 [INFO] [stderr] | [INFO] [stderr] 281 | todo!(); [INFO] [stderr] | -------- any code following this expression is unreachable [INFO] [stderr] 282 | [INFO] [stderr] 283 | list.into_iter() [INFO] [stderr] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unreachable_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> move-gen/src/lib.rs:276:9 [INFO] [stderr] | [INFO] [stderr] 276 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> move-gen/src/lib.rs:292:5 [INFO] [stderr] | [INFO] [stderr] 290 | todo!(); [INFO] [stderr] | -------- any code following this expression is unreachable [INFO] [stderr] 291 | [INFO] [stderr] 292 | list.into_iter() [INFO] [stderr] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> move-gen/src/lib.rs:288:9 [INFO] [stderr] | [INFO] [stderr] 288 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> move-gen/src/lib.rs:301:5 [INFO] [stderr] | [INFO] [stderr] 299 | todo!(); [INFO] [stderr] | -------- any code following this expression is unreachable [INFO] [stderr] 300 | [INFO] [stderr] 301 | list.into_iter() [INFO] [stderr] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> move-gen/src/lib.rs:297:9 [INFO] [stderr] | [INFO] [stderr] 297 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> move-gen/src/lib.rs:312:5 [INFO] [stderr] | [INFO] [stderr] 310 | todo!(); [INFO] [stderr] | -------- any code following this expression is unreachable [INFO] [stderr] 311 | [INFO] [stderr] 312 | list.into_iter() [INFO] [stderr] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> move-gen/src/lib.rs:308:9 [INFO] [stderr] | [INFO] [stderr] 308 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `side_moving` [INFO] [stderr] --> move-gen/src/lib.rs:208:68 [INFO] [stderr] | [INFO] [stderr] 208 | fn can_castle, const N: usize>(board: &B, side_moving: P::Side, castle_in_question: P::CastleRights) -> bool { [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_side_moving` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `list` [INFO] [stderr] --> move-gen/src/lib.rs:276:13 [INFO] [stderr] | [INFO] [stderr] 276 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `target_mask` [INFO] [stderr] --> move-gen/src/lib.rs:279:9 [INFO] [stderr] | [INFO] [stderr] 279 | let target_mask = board.position().mask_for_side(opposite_side); [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_mask` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `list` [INFO] [stderr] --> move-gen/src/lib.rs:288:13 [INFO] [stderr] | [INFO] [stderr] 288 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `board` [INFO] [stderr] --> move-gen/src/lib.rs:287:46 [INFO] [stderr] | [INFO] [stderr] 287 | pub fn quiet_moves>(board: &B) -> impl Iterator { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `list` [INFO] [stderr] --> move-gen/src/lib.rs:297:13 [INFO] [stderr] | [INFO] [stderr] 297 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `board` [INFO] [stderr] --> move-gen/src/lib.rs:296:52 [INFO] [stderr] | [INFO] [stderr] 296 | pub fn quiet_check_moves>(board: &B) -> impl Iterator { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `list` [INFO] [stderr] --> move-gen/src/lib.rs:308:13 [INFO] [stderr] | [INFO] [stderr] 308 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stderr] [INFO] [stderr] warning: 17 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: the feature `const_generics` is incomplete and may not be safe to use and/or cause compiler crashes [INFO] [stderr] --> move-gen/src/lib.rs:1:12 [INFO] [stderr] | [INFO] [stderr] 1 | #![feature(const_generics)] [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(incomplete_features)]` on by default [INFO] [stderr] = note: see issue #44580 for more information [INFO] [stderr] [INFO] [stderr] warning: unused import: `OxideSimpleMove` [INFO] [stderr] --> move-gen/src/lib.rs:330:44 [INFO] [stderr] | [INFO] [stderr] 330 | use oxide_interface::game::{OxideMove, OxideSimpleMove, OxideSquare::*}; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> move-gen/src/lib.rs:283:5 [INFO] [stderr] | [INFO] [stderr] 281 | todo!(); [INFO] [stderr] | -------- any code following this expression is unreachable [INFO] [stderr] 282 | [INFO] [stderr] 283 | list.into_iter() [INFO] [stderr] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unreachable_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> move-gen/src/lib.rs:276:9 [INFO] [stderr] | [INFO] [stderr] 276 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> move-gen/src/lib.rs:292:5 [INFO] [stderr] | [INFO] [stderr] 290 | todo!(); [INFO] [stderr] | -------- any code following this expression is unreachable [INFO] [stderr] 291 | [INFO] [stderr] 292 | list.into_iter() [INFO] [stderr] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> move-gen/src/lib.rs:288:9 [INFO] [stderr] | [INFO] [stderr] 288 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> move-gen/src/lib.rs:301:5 [INFO] [stderr] | [INFO] [stderr] 299 | todo!(); [INFO] [stderr] | -------- any code following this expression is unreachable [INFO] [stderr] 300 | [INFO] [stderr] 301 | list.into_iter() [INFO] [stderr] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> move-gen/src/lib.rs:297:9 [INFO] [stderr] | [INFO] [stderr] 297 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> move-gen/src/lib.rs:312:5 [INFO] [stderr] | [INFO] [stderr] 310 | todo!(); [INFO] [stderr] | -------- any code following this expression is unreachable [INFO] [stderr] 311 | [INFO] [stderr] 312 | list.into_iter() [INFO] [stderr] | ^^^^^^^^^^^^^^^^ unreachable expression [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> move-gen/src/lib.rs:308:9 [INFO] [stderr] | [INFO] [stderr] 308 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `side_moving` [INFO] [stderr] --> move-gen/src/lib.rs:208:68 [INFO] [stderr] | [INFO] [stderr] 208 | fn can_castle, const N: usize>(board: &B, side_moving: P::Side, castle_in_question: P::CastleRights) -> bool { [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_side_moving` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `list` [INFO] [stderr] --> move-gen/src/lib.rs:276:13 [INFO] [stderr] | [INFO] [stderr] 276 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `target_mask` [INFO] [stderr] --> move-gen/src/lib.rs:279:9 [INFO] [stderr] | [INFO] [stderr] 279 | let target_mask = board.position().mask_for_side(opposite_side); [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_mask` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `list` [INFO] [stderr] --> move-gen/src/lib.rs:288:13 [INFO] [stderr] | [INFO] [stderr] 288 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `board` [INFO] [stderr] --> move-gen/src/lib.rs:287:46 [INFO] [stderr] | [INFO] [stderr] 287 | pub fn quiet_moves>(board: &B) -> impl Iterator { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `list` [INFO] [stderr] --> move-gen/src/lib.rs:297:13 [INFO] [stderr] | [INFO] [stderr] 297 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `board` [INFO] [stderr] --> move-gen/src/lib.rs:296:52 [INFO] [stderr] | [INFO] [stderr] 296 | pub fn quiet_check_moves>(board: &B) -> impl Iterator { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_board` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `list` [INFO] [stderr] --> move-gen/src/lib.rs:308:13 [INFO] [stderr] | [INFO] [stderr] 308 | let mut list = SmallVec::<[B::Move; BASE_MOVES_CAPACITY]>::new(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_list` [INFO] [stderr] [INFO] [stderr] warning: 18 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> uci-engine/src/main.rs:16:9 [INFO] [stderr] | [INFO] [stderr] 16 | let mut t = OxideMove::new_promoting_capture(E7, F8, OxidePiece::Queen); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.02s [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/attacks-52fc6be27aa43321) [INFO] [stdout] test sliding::test::rook_attack_works ... ok [INFO] [stdout] test pawn::bench::black_pawn_attacks_bench ... ok [INFO] [stdout] test pawn::bench::black_pawn_pushes_bench ... ok [INFO] [stdout] test pawn::test::pawn_east_attacks_works ... ok [INFO] [stdout] test knight::test::knight_attacks_works ... ok [INFO] [stdout] test pawn::test::pawn_west_attacks_works ... ok [INFO] [stdout] test sliding::bench::bishop_attacks_bench ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 18 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/interface-fa1356113c2c15d7) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/move_gen-a33c79af6c94e121) [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/oxide_interface-297458c0ad835ef5) [INFO] [stdout] [INFO] [stdout] running 1 test [INFO] [stdout] test tests::default_position_legal_works ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 127 tests [INFO] [stdout] test game::chess_move::test::test::is_queen_castle_works ... ok [INFO] [stdout] test game::castle::test::for_side_works ... ok [INFO] [stdout] test game::chess_move::test::test::is_quiet_works ... ok [INFO] [stdout] test game::chess_move::test::test::new_capture_works ... ok [INFO] [stdout] test engine::position::test::from_default_fen_works ... ok [INFO] [stdout] test game::castle::test::display_works ... ok [INFO] [stdout] test game::chess_move::test::test::new_promotion_works ... ok [INFO] [stdout] test game::chess_move::test::test::promotion_works ... ok [INFO] [stdout] test game::chess_move::test::test::is_capture_works ... ok [INFO] [stdout] test game::chess_move::test::test::is_king_castle_works ... ok [INFO] [stdout] test game::oxide_bitboard::bench::cardinal_fill_bench ... ok [INFO] [stdout] test game::chess_move::test::test::simple_move_works ... ok [INFO] [stdout] test game::oxide_bitboard::bench::cardinal_ray_attacks_bench ... ok [INFO] [stdout] test game::oxide_bitboard::bench::diagonal_fill_bench ... ok [INFO] [stdout] test game::oxide_bitboard::bench::north_fill_bench ... ok [INFO] [stdout] test game::oxide_bitboard::bench::south_east_fill_bench ... ok [INFO] [stdout] test game::oxide_bitboard::bench::north_west_fill_bench ... ok [INFO] [stdout] test game::oxide_bitboard::bench::south_fill_bench ... ok [INFO] [stdout] test game::oxide_bitboard::bench::south_west_fill_bench ... ok [INFO] [stdout] test game::oxide_bitboard::bench::west_fill_bench ... ok [INFO] [stdout] test game::oxide_bitboard::line::bench::between_fill_connected_bench ... ok [INFO] [stdout] test game::chess_move::test::test::castles_work ... ok [INFO] [stdout] test game::chess_move::test::test::is_double_pawn_push_works ... ok [INFO] [stdout] test game::oxide_bitboard::line::bench::between_fill_disconnected_bench ... ok [INFO] [stdout] test game::oxide_bitboard::line::bench::line_fill_connected_bench ... ok [INFO] [stdout] test game::oxide_bitboard::line::bench::line_fill_disconnected_bench ... ok [INFO] [stdout] test game::oxide_bitboard::bench::diagonal_ray_attacks_bench ... ok [INFO] [stdout] test game::chess_move::test::test::new_en_passant_capture_works ... ok [INFO] [stdout] test game::chess_move::test::test::new_double_pawn_push_works ... ok [INFO] [stdout] test game::chess_move::test::test::new_promoting_capture_works ... ok [INFO] [stdout] test game::castle::test::try_from_str_works ... ok [INFO] [stdout] test game::oxide_bitboard::bench::east_fill_bench ... ok [INFO] [stdout] test game::chess_move::test::test::is_castle_works ... ok [INFO] [stdout] test game::oxide_bitboard::bench::north_east_fill_bench ... ok [INFO] [stdout] test game::chess_move::test::test::is_en_passant_capture_works ... ok [INFO] [stdout] test game::chess_move::test::test::is_promotion_works ... ok [INFO] [stdout] test game::oxide_bitboard::shiftable::test::edge_consts_match ... ok [INFO] [stdout] test game::oxide_bitboard::shiftable::test::shift_east_works ... ok [INFO] [stdout] test game::oxide_bitboard::shiftable::test::shift_north_west_works ... ok [INFO] [stdout] test game::oxide_bitboard::shiftable::test::shift_north_east_works ... ok [INFO] [stdout] test game::oxide_bitboard::shiftable::test::shift_north_works ... ok [INFO] [stdout] test game::oxide_bitboard::shiftable::test::shift_south_east_works ... ok [INFO] [stdout] test game::oxide_bitboard::shiftable::test::shift_south_west_works ... ok [INFO] [stdout] test game::oxide_bitboard::shiftable::test::shift_south_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::bitboard_from_square_iterator_works ... ok [INFO] [stdout] test game::oxide_bitboard::shiftable::test::shift_west_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::cardinal_ray_attacks_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::diagonal_ray_attacks_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::east_ray_attacks_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::file_fill_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_east_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_north_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_occluded_east_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_occluded_north_east_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_occluded_north_west_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_occluded_north_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_occluded_south_east_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_occluded_south_west_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_occluded_south_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_occluded_west_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_south_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::fill_west_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::masks_are_valid ... ok [INFO] [stdout] test game::oxide_bitboard::test::north_east_ray_attacks_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::north_ray_attacks_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::north_west_ray_attacks_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::rank_fill_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::south_east_ray_attacks_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::south_ray_attacks_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::south_west_ray_attacks_works ... ok [INFO] [stdout] test game::oxide_bitboard::test::west_ray_attacks_works ... ok [INFO] [stdout] test game::piece::test::default_pieces_are_empty ... ok [INFO] [stdout] test game::piece::test::remove_side_works ... ok [INFO] [stdout] test game::chess_move::test::test::from_simple_move_works ... FAILED [INFO] [stdout] test game::oxide_bitboard::line::test::line_fill_works ... ok [INFO] [stdout] test game::oxide_bitboard::mask_iter::test::is_equivalent_to_from_square_iter ... ok [INFO] [stdout] test game::piece::test::unsided_display_works ... ok [INFO] [stdout] test game::side::test::display_works ... ok [INFO] [stdout] test game::side::test::is_black_works ... ok [INFO] [stdout] test game::side::test::is_white_works ... ok [INFO] [stdout] test game::oxide_bitboard::pop_square::tests::blsr_works ... ok [INFO] [stdout] test game::oxide_bitboard::numeric_impl::test::bit_xor_works ... ok [INFO] [stdout] test game::oxide_bitboard::line::test::between_fill_works ... ok [INFO] [stdout] test game::oxide_bitboard::numeric_impl::test::bit_or_works ... ok [INFO] [stdout] test game::oxide_bitboard::mask_iter::test::works_for_multiple_squares ... ok [INFO] [stdout] test game::oxide_bitboard::numeric_impl::test::not_works ... ok [INFO] [stdout] test game::oxide_bitboard::pop_square::tests::pop_square_works ... ok [INFO] [stdout] test game::oxide_bitboard::mask_iter::test::works_for_empty ... ok [INFO] [stdout] test game::oxide_bitboard::line::test::aligned_works ... ok [INFO] [stdout] test game::oxide_bitboard::mask_iter::test::works_for_single_square ... ok [INFO] [stdout] test game::side::test::switch_sides_works ... ok [INFO] [stdout] test game::oxide_bitboard::numeric_impl::test::bit_and_works ... ok [INFO] [stdout] test game::piece::test::sided_display_works ... ok [INFO] [stdout] test game::piece::test::side_of_none_panics ... ok [INFO] [stdout] test game::piece::test::side_of_sided_works ... ok [INFO] [stdout] test game::square::test::north_east_shift_off_board_panics ... ok [INFO] [stdout] test game::square::test::offset_works ... ok [INFO] [stdout] test game::square::test::south_east_shift_off_board_panics ... ok [INFO] [stdout] test game::square::test::south_east_shift_off_east_board_panics ... ok [INFO] [stdout] test game::square::test::south_east_shift_off_south_board_panics ... ok [INFO] [stdout] test game::square::test::south_east_shift_works ... ok [INFO] [stdout] test game::square::test::south_shift_off_board_panics ... ok [INFO] [stdout] test game::square::test::south_shift_works ... ok [INFO] [stdout] test game::square::test::south_west_shift_off_board_panics ... ok [INFO] [stdout] test game::square::test::south_west_shift_off_south_board_panics ... ok [INFO] [stdout] test game::square::test::south_west_shift_off_west_board_panics ... ok [INFO] [stdout] test game::square::test::south_west_shift_works ... ok [INFO] [stdout] test game::square::test::square_shift_matches_board_mask_shift ... ok [INFO] [stdout] test game::square::test::north_shift_works ... ok [INFO] [stdout] test game::square::test::from_offset_works ... ok [INFO] [stdout] test game::square::test::from_mask_matches_to_mask ... ok [INFO] [stdout] test game::square::test::north_east_shift_works ... ok [INFO] [stdout] test game::square::test::north_west_shift_works ... ok [INFO] [stdout] test game::square::test::from_mask_works ... ok [INFO] [stdout] test game::square::test::east_shift_works ... ok [INFO] [stdout] test game::square::test::east_shift_off_board_panics ... ok [INFO] [stdout] test game::square::test::north_east_shift_off_east_board_panics ... ok [INFO] [stdout] test game::square::test::x_offset_works ... ok [INFO] [stdout] test game::square::test::north_west_shift_off_north_board_panics ... ok [INFO] [stdout] test game::square::test::north_west_shift_off_west_board_panics ... ok [INFO] [stdout] test game::square::test::north_east_shift_off_north_board_panics ... ok [INFO] [stdout] test game::square::test::north_west_shift_off_board_panics ... ok [INFO] [stdout] test game::square::test::y_offset_works ... ok [INFO] [stdout] test game::square::test::to_bitboard_works ... ok [INFO] [stdout] test game::square::test::north_shift_off_board_panics ... ok [INFO] [stdout] test game::square::test::west_shift_works ... ok [INFO] [stdout] test game::square::test::west_shift_off_board_panics ... ok [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- game::chess_move::test::test::from_simple_move_works stdout ---- [INFO] [stdout] thread 'game::chess_move::test::test::from_simple_move_works' panicked at 'not yet implemented: Test a bunch of simple moves that are actually side-effect moves', oxide-interface/src/game/chess_move/test.rs:128:9 [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x556bc4140850 - std::backtrace_rs::backtrace::libunwind::trace::h1037ca7e6eeef65c [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/../../backtrace/src/backtrace/libunwind.rs:90:5 [INFO] [stdout] 1: 0x556bc4140850 - std::backtrace_rs::backtrace::trace_unsynchronized::haaefac1bc3669450 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/../../backtrace/src/backtrace/mod.rs:66:5 [INFO] [stdout] 2: 0x556bc4140850 - std::sys_common::backtrace::_print_fmt::h863a6f5e6d995885 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/sys_common/backtrace.rs:67:5 [INFO] [stdout] 3: 0x556bc4140850 - ::fmt::h767e17e1aa7df6a8 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/sys_common/backtrace.rs:46:22 [INFO] [stdout] 4: 0x556bc416300c - core::fmt::write::h7aa6cd0067dca82a [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/core/src/fmt/mod.rs:1110:17 [INFO] [stdout] 5: 0x556bc413d8c5 - std::io::Write::write_fmt::h6f1a9b91376a1376 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/io/mod.rs:1584:15 [INFO] [stdout] 6: 0x556bc41429bb - std::sys_common::backtrace::_print::h2769edb26a7eb606 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/sys_common/backtrace.rs:49:5 [INFO] [stdout] 7: 0x556bc41429bb - std::sys_common::backtrace::print::ha71f3549862b4cb6 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/sys_common/backtrace.rs:36:9 [INFO] [stdout] 8: 0x556bc41429bb - std::panicking::default_hook::{{closure}}::h95488a3bade217f6 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panicking.rs:208:50 [INFO] [stdout] 9: 0x556bc41424cc - std::panicking::default_hook::h290aa602c0fb11df [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panicking.rs:222:9 [INFO] [stdout] 10: 0x556bc4143061 - std::panicking::rust_panic_with_hook::hf32c4fa635e215f2 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panicking.rs:622:17 [INFO] [stdout] 11: 0x556bc4142b67 - std::panicking::begin_panic_handler::{{closure}}::h95197ccd88846f7a [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panicking.rs:519:13 [INFO] [stdout] 12: 0x556bc4140d2c - std::sys_common::backtrace::__rust_end_short_backtrace::h7641df9566f7b7d0 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/sys_common/backtrace.rs:141:18 [INFO] [stdout] 13: 0x556bc4142ac9 - rust_begin_unwind [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panicking.rs:515:5 [INFO] [stdout] 14: 0x556bc40ae4b1 - core::panicking::panic_fmt::hbe99dddd3092ba3c [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/core/src/panicking.rs:92:14 [INFO] [stdout] 15: 0x556bc40de86e - oxide_interface::game::chess_move::test::test::from_simple_move_works::h071c5878b162e265 [INFO] [stdout] at /opt/rustwide/workdir/oxide-interface/src/game/chess_move/test.rs:128:9 [INFO] [stdout] 16: 0x556bc40de7ba - oxide_interface::game::chess_move::test::test::from_simple_move_works::{{closure}}::hede453565b6d99ef [INFO] [stdout] at /opt/rustwide/workdir/oxide-interface/src/game/chess_move/test.rs:127:5 [INFO] [stdout] 17: 0x556bc40c31ae - core::ops::function::FnOnce::call_once::h7704bef1a16f906a [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/core/src/ops/function.rs:227:5 [INFO] [stdout] 18: 0x556bc4117eb3 - core::ops::function::FnOnce::call_once::h673fbe3f96486fd2 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/core/src/ops/function.rs:227:5 [INFO] [stdout] 19: 0x556bc4117eb3 - test::__rust_begin_short_backtrace::h8eedc24e104ef6a0 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/test/src/lib.rs:577:5 [INFO] [stdout] 20: 0x556bc4116960 - as core::ops::function::FnOnce>::call_once::h028d0969d3f94d78 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/alloc/src/boxed.rs:1575:9 [INFO] [stdout] 21: 0x556bc4116960 - as core::ops::function::FnOnce<()>>::call_once::h7634b01590b1722b [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panic.rs:346:9 [INFO] [stdout] 22: 0x556bc4116960 - std::panicking::try::do_call::hf74f869706dec63b [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panicking.rs:401:40 [INFO] [stdout] 23: 0x556bc4116960 - std::panicking::try::hd0b7346ebfaaae44 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panicking.rs:365:19 [INFO] [stdout] 24: 0x556bc4116960 - std::panic::catch_unwind::hdbf6904f7c253080 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panic.rs:433:14 [INFO] [stdout] 25: 0x556bc4116960 - test::run_test_in_process::h87e95a014ac91067 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/test/src/lib.rs:600:18 [INFO] [stdout] 26: 0x556bc4116960 - test::run_test::run_test_inner::{{closure}}::hdd69ae44aaab3470 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/test/src/lib.rs:492:39 [INFO] [stdout] 27: 0x556bc40f1a52 - test::run_test::run_test_inner::{{closure}}::hc159305704d5b68a [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/test/src/lib.rs:519:37 [INFO] [stdout] 28: 0x556bc40f1a52 - std::sys_common::backtrace::__rust_begin_short_backtrace::h33d8a8ad5f788fcc [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/sys_common/backtrace.rs:125:18 [INFO] [stdout] 29: 0x556bc40f57c8 - std::thread::Builder::spawn_unchecked::{{closure}}::{{closure}}::h6181011ddf4b8353 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/thread/mod.rs:481:17 [INFO] [stdout] 30: 0x556bc40f57c8 - as core::ops::function::FnOnce<()>>::call_once::hf924ea0a0f25a1c0 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panic.rs:346:9 [INFO] [stdout] 31: 0x556bc40f57c8 - std::panicking::try::do_call::hd58061792d05fa5c [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panicking.rs:401:40 [INFO] [stdout] 32: 0x556bc40f57c8 - std::panicking::try::h3080747417e5af37 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panicking.rs:365:19 [INFO] [stdout] 33: 0x556bc40f57c8 - std::panic::catch_unwind::hfeba515dcf36cb66 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/panic.rs:433:14 [INFO] [stdout] 34: 0x556bc40f57c8 - std::thread::Builder::spawn_unchecked::{{closure}}::h29d57a62faff749b [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/thread/mod.rs:480:30 [INFO] [stdout] 35: 0x556bc40f57c8 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h44709d312d2a9c59 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/core/src/ops/function.rs:227:5 [INFO] [stdout] 36: 0x556bc4147b17 - as core::ops::function::FnOnce>::call_once::h902e2cf6655e1b0c [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/alloc/src/boxed.rs:1575:9 [INFO] [stdout] 37: 0x556bc4147b17 - as core::ops::function::FnOnce>::call_once::h893a5452154309d1 [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/alloc/src/boxed.rs:1575:9 [INFO] [stdout] 38: 0x556bc4147b17 - std::sys::unix::thread::Thread::new::thread_start::hdedcb57c96ab37cd [INFO] [stdout] at /rustc/99e3aef02079e9c10583638520cd0c134dc3a01d/library/std/src/sys/unix/thread.rs:71:17 [INFO] [stdout] 39: 0x7f697b756609 - start_thread [INFO] [stdout] 40: 0x7f697b528293 - clone [INFO] [stdout] 41: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] game::chess_move::test::test::from_simple_move_works [INFO] [stdout] [INFO] [stdout] test result: FAILED. 126 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.06s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass '-p oxide-interface --lib' [INFO] running `Command { std: "docker" "inspect" "6d210ec3dc61303128aa02385a24a366a44911d1ae9f6083d8eef13d576e832c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6d210ec3dc61303128aa02385a24a366a44911d1ae9f6083d8eef13d576e832c", kill_on_drop: false }` [INFO] [stdout] 6d210ec3dc61303128aa02385a24a366a44911d1ae9f6083d8eef13d576e832c