[INFO] cloning repository https://github.com/brken11/rusty_chess
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/brken11/rusty_chess" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbrken11%2Frusty_chess", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbrken11%2Frusty_chess'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] b44b06e45c69980552b371cebd31939bd5ed6e07
[INFO] testing brken11/rusty_chess against 1.90.0 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbrken11%2Frusty_chess" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/brken11/rusty_chess
[INFO] finished tweaking git repo https://github.com/brken11/rusty_chess
[INFO] tweaked toml for git repo https://github.com/brken11/rusty_chess written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/brken11/rusty_chess on toolchain 1.90.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/brken11/rusty_chess already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] e0ba10d7443729b35c0a45da41a1b592f23241a6350bb3edf56e840ee7122ecf
[INFO] running `Command { std: "docker" "start" "-a" "e0ba10d7443729b35c0a45da41a1b592f23241a6350bb3edf56e840ee7122ecf", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "e0ba10d7443729b35c0a45da41a1b592f23241a6350bb3edf56e840ee7122ecf", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e0ba10d7443729b35c0a45da41a1b592f23241a6350bb3edf56e840ee7122ecf", kill_on_drop: false }`
[INFO] [stdout] e0ba10d7443729b35c0a45da41a1b592f23241a6350bb3edf56e840ee7122ecf
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6931d37f25b9852e0035aafad4d47df20f16650d771a78be8ce40966b16632b6
[INFO] running `Command { std: "docker" "start" "-a" "6931d37f25b9852e0035aafad4d47df20f16650d771a78be8ce40966b16632b6", kill_on_drop: false }`
[INFO] [stderr]    Compiling rusty_chess v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]  --> src/chess_bot.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::error::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::player_agent`
[INFO] [stdout]  --> src/game.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::player_agent;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]   --> src/game.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::thread;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ProtoMove`
[INFO] [stdout]  --> src/player_agent/player_actor.rs:3:61
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::move_parser::{chess_notation_parser, ParseError, ProtoMove};
[INFO] [stdout]   |                                                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Instant`
[INFO] [stdout]  --> src/rules.rs:1:27
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::time::{Duration, Instant};
[INFO] [stdout]   |                           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Config`
[INFO] [stdout]   --> src/main.rs:24:35
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::config::{parse_config, Config, ConfigResult};
[INFO] [stdout]    |                                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game_id`
[INFO] [stdout]   --> src/chess_bot.rs:42:35
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `move_notation`
[INFO] [stdout]   --> src/chess_bot.rs:42:50
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_move_notation`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game_id`
[INFO] [stdout]   --> src/chess_bot.rs:48:40
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stdout]    |                                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file`
[INFO] [stdout]    --> src/log.rs:273:29
[INFO] [stdout]     |
[INFO] [stdout] 273 |             LogOutput::File(file) => {
[INFO] [stdout]     |                             ^^^^ help: if this is intentional, prefix it with an underscore: `_file`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/ui.rs:81:12
[INFO] [stdout]    |
[INFO] [stdout] 81 |     fn run(mut self) -> UIManager {
[INFO] [stdout]    |            ----^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `log_handle`
[INFO] [stdout]   --> src/main.rs:67:10
[INFO] [stdout]    |
[INFO] [stdout] 67 |     let (log_handle, log_channel) = common_lib::init_logger(main_id, log_output);
[INFO] [stdout]    |          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_log_handle`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `can_castle`, `king_moved`, and `rook_moved` are never used
[INFO] [stdout]   --> src/board.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub trait CastlingRightsExt{
[INFO] [stdout]    |           ----------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 32 |     fn can_castle(self, color: Color, kingside: bool) -> bool;
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     fn king_moved(&mut self, king_color: Color);
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 38 |     fn rook_moved(&mut self, rook_color: Color, kingside: bool);
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `BitboardExt` is never used
[INFO] [stdout]   --> src/board.rs:97:11
[INFO] [stdout]    |
[INFO] [stdout] 97 | pub trait BitboardExt{
[INFO] [stdout]    |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BOARD_TEMPLATE` is never used
[INFO] [stdout]    --> src/board.rs:135:7
[INFO] [stdout]     |
[INFO] [stdout] 135 | const BOARD_TEMPLATE: &'static str =
[INFO] [stdout]     |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/board.rs:199:12
[INFO] [stdout]     |
[INFO] [stdout] 149 | impl Board {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn clone(&self) -> Board {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 239 |     pub fn get_piece_count(&self) -> u8 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     pub fn get_piece_color_at(&self, square: Square) -> Option<Color> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 338 |     pub fn find_piece_positions(&self, piece: Piece) -> Vec<Square> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 439 |     pub fn get_char_at(&self, square: Square) -> char {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 619 |     pub fn sees_down_file(&self, square:Square, ascending: bool) -> Bitboard {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 664 |     pub fn sees_down_diagonal(&self, square:Square, ascending_row: bool, ascending_col: bool) -> Bitboard {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 683 |     pub fn sees_like_knight(&self, square:Square) -> Bitboard {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 791 |     pub fn get_pieces_at_bitboard(&self, bitboard: Bitboard) -> Vec<(Piece, Square)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 801 |     pub fn get_piece_squares_from_bitboard(&self, piece: Piece, mut bitboard: Bitboard) -> Vec<Square> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 815 |     pub fn get_active_pieces(&self) -> Vec<(Piece, Square)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/board/pieces.rs:35:11
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl Piece {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  35 |     const PIECES_WITH_COLOR: [(Piece,Color); 12] = [
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  62 |     pub fn iter_with_color() -> impl Iterator<Item=(Piece, Color)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn is_rook(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn is_knight(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn is_bishop(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn is_queen(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub fn is_king(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 130 |     pub fn moves_diagonally(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 140 |     pub fn captures_diagonally(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub fn moves_n_captures_straight(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 164 |     pub fn is_promotion_candidate(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 171 |     pub fn to_index(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 175 |     pub fn from_index(index: usize) -> Option<Piece> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_pawn_row_offset`, `king_starting_square`, and `king_castle_target` are never used
[INFO] [stdout]    --> src/board/pieces.rs:234:18
[INFO] [stdout]     |
[INFO] [stdout] 212 | impl Color {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub const fn get_pawn_row_offset(&self) -> u8 {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 300 |     pub const fn king_starting_square(&self) -> Square {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 306 |     pub const fn king_castle_target(&self, castle_type: CastleType) -> Square {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/board/square.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout]  9 | ...trait SquareExt {
[INFO] [stdout]    |          --------- associated items in this trait
[INFO] [stdout] ...
[INFO] [stdout] 17 | ...const A1: Square; const A2: Square; const A3: Square; const A4: Square; const A5: Square; const A6: Square; const A7: Square; const A8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 18 | ...const B1: Square; const B2: Square; const B3: Square; const B4: Square; const B5: Square; const B6: Square; const B7: Square; const B8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 19 | ...const C1: Square; const C2: Square; const C3: Square; const C4: Square; const C5: Square; const C6: Square; const C7: Square; const C8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 20 | ...const D1: Square; const D2: Square; const D3: Square; const D4: Square; const D5: Square; const D6: Square; const D7: Square; const D8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 21 | ...const E1: Square; const E2: Square; const E3: Square; const E4: Square; const E5: Square; const E6: Square; const E7: Square; const E8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 22 | ...const F1: Square; const F2: Square; const F3: Square; const F4: Square; const F5: Square; const F6: Square; const F7: Square; const F8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 23 | ...const G1: Square; const G2: Square; const G3: Square; const G4: Square; const G5: Square; const G6: Square; const G7: Square; const G8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 24 | ...const H1: Square; const H2: Square; const H3: Square; const H4: Square; const H5: Square; const H6: Square; const H7: Square; const H8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 25 | .../// Array of square labels, from "a8","b8","c8" ... to ..., "f1", "g1", "h1".
[INFO] [stdout] 26 | ...const SQUARES: [&'static str; 64];
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 | ...fn get_rows(&self, ascending : bool) -> RowIterator;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 | ...fn get_cols(&self, ascending : bool) -> ColIterator;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 | ...fn get_pos_pair(&self) -> (Row, Col);
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 46 | .../// Returns the index of the square as a `usize`.
[INFO] [stdout] 47 | ...fn get_index(&self) -> usize;
[INFO] [stdout]    |       ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 | ...fn row_diff(&self, other_square: Square) -> u8;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] 58 | .../// Returns the absolute difference in columns between `Square`s
[INFO] [stdout] 59 | ...fn col_diff(&self, other_square: Square) -> u8;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] 60 | .../// Returns an iterator over the file letters.
[INFO] [stdout] 61 | ...fn iter_files() -> impl Iterator<Item = char>;
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 | ...fn iter_squares() -> impl Iterator<Item = Square>;
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 | ...fn to_square_str(&self) -> &str;
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `from_rank` and `to_rank` are never used
[INFO] [stdout]    --> src/board/square.rs:251:8
[INFO] [stdout]     |
[INFO] [stdout] 234 | pub trait RowExt {
[INFO] [stdout]     |           ------ associated items in this trait
[INFO] [stdout] ...
[INFO] [stdout] 251 |     fn from_rank(rank: u8) -> Self;
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 252 |     fn to_rank(&self) -> u8;
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `from_file` and `to_file` are never used
[INFO] [stdout]    --> src/board/square.rs:271:8
[INFO] [stdout]     |
[INFO] [stdout] 254 | pub trait ColExt {
[INFO] [stdout]     |           ------ associated items in this trait
[INFO] [stdout] ...
[INFO] [stdout] 271 |     fn from_file(file: char) -> Self;
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 272 |     fn to_file(&self) -> char;
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RowIterator` is never constructed
[INFO] [stdout]    --> src/board/square.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct RowIterator{
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ColIterator` is never constructed
[INFO] [stdout]    --> src/board/square.rs:344:12
[INFO] [stdout]     |
[INFO] [stdout] 344 | pub struct ColIterator{
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessApiConfig` is never constructed
[INFO] [stdout]  --> src/chess_bot.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ChessApiConfig {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ChessApiError` is never used
[INFO] [stdout]   --> src/chess_bot.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ChessApiError {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessApiClient` is never constructed
[INFO] [stdout]   --> src/chess_bot.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct ChessApiClient {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `authenticate`, `make_move`, and `get_game_state` are never used
[INFO] [stdout]   --> src/chess_bot.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 29 | impl ChessApiClient {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 30 |     /// Creates a new API client with the given configuration
[INFO] [stdout] 31 |     pub fn new(config: ChessApiConfig) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub async fn authenticate(&self) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/chess_moves.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub enum MoveData {
[INFO] [stdout]    |          -------- variants in this enum
[INFO] [stdout] 16 |     Normal = 0,
[INFO] [stdout] 17 |     NormalCheck = 1,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 18 |     NormalCheckmate = 2,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 19 |     NormalStalemate = 3,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 20 |     Castling = 4,
[INFO] [stdout] 21 |     CastlingCheck = 5,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 22 |     CastlingCheckmate = 6,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 23 |     CastlingStalemate = 7,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     Promotion = 8,
[INFO] [stdout] 25 |     PromotionCheck = 9,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 26 |     PromotionCheckmate = 10,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 27 |     PromotionStalemate = 11,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 28 |     EnPassant = 12,
[INFO] [stdout] 29 |     EnPassantCheck = 13,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 30 |     EnPassantCheckmate = 14,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 31 |     EnPassantStalemate = 15,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 32 |     EnableEnPassant = 16,
[INFO] [stdout] 33 |     EnableEnPassantCheck = 17,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 34 |     EnableEnPassantCheckmate = 18,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 35 |     EnableEnPassantStalemate = 19,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 36 |     Capture = 20,
[INFO] [stdout] 37 |     CaptureCheck = 21,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 38 |     CaptureCheckmate = 22,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 39 |     CaptureStalemate = 23,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 40 |     CapturePromotion = 24,
[INFO] [stdout] 41 |     CapturePromotionCheck = 25,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 42 |     CapturePromotionCheckmate = 26,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 43 |     CapturePromotionStalemate = 27,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 44 |     //Moves may be generated by the engine ahead of time, so they may need to be properly classified.
[INFO] [stdout] 45 |     GeneratedOnly,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SpecialMoveType` is never used
[INFO] [stdout]   --> src/chess_moves.rs:55:6
[INFO] [stdout]    |
[INFO] [stdout] 55 | enum SpecialMoveType {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/chess_moves.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub enum MoveError {
[INFO] [stdout]    |          --------- variants in this enum
[INFO] [stdout] 65 |     LeavesKingInCheck, //@TODO Return square of piece threatening King
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 66 |     PieceNotFound(Square),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 67 |     OriginNotFound(Piece),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 68 |     ObstructedMove,                 //@TODO Add blocking piece
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 69 |     DisambiguousMove(Disambiguity), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 70 |     IllegalMove, //@TODO remove any of these that aren't related to piece movement rules
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 71 |     CastleNotPermmited,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 72 |     KingCannotSeeRook, // @TODO ObscuredMove for Castle, should show blocking piece
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 73 |     PromotionRequired,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 74 |     IllegalPromotion,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `None`, `Rank`, `File`, and `Square` are never constructed
[INFO] [stdout]   --> src/chess_moves.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub enum Disambiguity {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] 79 |     None,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 80 |     Rank(Row),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 81 |     File(Col),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 82 |     Square(Square),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Disambiguity` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `WHITE_KINGSIDE_CASTLE` is never used
[INFO] [stdout]   --> src/chess_moves.rs:93:7
[INFO] [stdout]    |
[INFO] [stdout] 93 | const WHITE_KINGSIDE_CASTLE: ChessMove = ChessMove {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `WHITE_QUEENSIDE_CASTLE` is never used
[INFO] [stdout]   --> src/chess_moves.rs:99:7
[INFO] [stdout]    |
[INFO] [stdout] 99 | const WHITE_QUEENSIDE_CASTLE: ChessMove = ChessMove {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BLACK_KINGSIDE_CASTLE` is never used
[INFO] [stdout]    --> src/chess_moves.rs:105:7
[INFO] [stdout]     |
[INFO] [stdout] 105 | const BLACK_KINGSIDE_CASTLE: ChessMove = ChessMove {
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BLACK_QUEENSIDE_CASTLE` is never used
[INFO] [stdout]    --> src/chess_moves.rs:111:7
[INFO] [stdout]     |
[INFO] [stdout] 111 | const BLACK_QUEENSIDE_CASTLE: ChessMove = ChessMove {
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]     --> src/chess_moves.rs:158:12
[INFO] [stdout]      |
[INFO] [stdout]  130 | impl ChessMove {
[INFO] [stdout]      | -------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  158 |     pub fn valid_new( board: &mut Board, piece: Piece, origin: Square, target: Square, is_promotion: bool) -> Result<ChessMove, MoveError> {
[INFO] [stdout]      |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  170 |     pub fn new_castle(board: &mut Board, castle_type: CastleType) -> Result<ChessMove, MoveError> {
[INFO] [stdout]      |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  193 |     pub fn disambiguate_from_squares(possible_origins: &Vec<Square>) -> Disambiguity {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  228 |     pub fn new_with_disambiguation(
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  271 |     pub fn disambiguate_from_moves(possible_moves: &Vec<ChessMove>) -> Disambiguity {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  306 |     pub fn new_without_disambiguation(
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  442 |     pub fn new_from_squares(
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  455 |     fn assemble_special_move(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  517 |     pub fn to_simplified(&self) -> String {
[INFO] [stdout]      |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  594 |     pub fn make_move(&self, board: &mut Board) {
[INFO] [stdout]      |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  698 |     pub fn validate_move(&mut self, board: &mut Board) -> Result<(), MoveError> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  715 |     fn validate_movement(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  746 |     fn validate_capturable(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  757 |     fn validate_meta_data(&mut self, board: &mut Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  780 |     fn validate_pawn_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  873 |     fn validate_rook_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  892 |     fn validate_knight_move(&mut self) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  915 |     fn validate_bishop_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  933 |     fn validate_queen_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  963 |     fn validate_king_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1043 |     fn validate_promotion(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1093 |     fn validate_diagonal_move(&mut self, board: &Board) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1119 |     fn validate_straight_move(&mut self, board: &Board, down_file: bool) -> Result<(), MoveError> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `special_move_builder` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1634:4
[INFO] [stdout]      |
[INFO] [stdout] 1634 | fn special_move_builder(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_none_or_promotion` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1655:4
[INFO] [stdout]      |
[INFO] [stdout] 1655 | fn build_none_or_promotion(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_move_type` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1694:4
[INFO] [stdout]      |
[INFO] [stdout] 1694 | fn build_move_type(base: MoveData, result: MoveResult) -> MoveData {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]     --> src/chess_moves.rs:1760:12
[INFO] [stdout]      |
[INFO] [stdout] 1704 | impl MoveData {
[INFO] [stdout]      | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1760 |     pub fn is_check(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1771 |     pub fn is_checkmate(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1782 |     pub fn is_stalemate(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1810 |     pub fn is_en_passant(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1885 |     pub fn add_result_data(&mut self, move_checks: bool, opp_has_move: bool) {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1903 |     fn add_check(self) -> MoveData {
[INFO] [stdout]      |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1914 |     fn add_checkmate(self) -> MoveData {
[INFO] [stdout]      |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1925 |     fn add_stalemate(self) -> MoveData {
[INFO] [stdout]      |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessClock` is never constructed
[INFO] [stdout]  --> src/clock.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct ChessClock{
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/clock.rs:16:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl ChessClock{
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 16 |     fn new() -> Self{
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Network`, `Game`, `Terminal`, `GUI`, and `Other` are never constructed
[INFO] [stdout]   --> src/common.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub enum ThreadIdentifier {
[INFO] [stdout]    |          ---------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 17 |     Network(ThreadIdHash),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 18 |     Game(ThreadIdHash),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 19 |     UI(ThreadIdHash),
[INFO] [stdout] 20 |     Terminal(ThreadIdHash),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 21 |     GUI(ThreadIdHash),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 22 |     Other(ThreadIdHash, &'static str),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ThreadIdentifier` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PlayerType` is never used
[INFO] [stdout]   --> src/game.rs:42:10
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub enum PlayerType{
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GameMetadata` is never constructed
[INFO] [stdout]   --> src/game.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub struct GameMetadata {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Game` is never constructed
[INFO] [stdout]   --> src/game.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct Game{
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `FullMoveNumber` is never used
[INFO] [stdout]   --> src/game.rs:70:10
[INFO] [stdout]    |
[INFO] [stdout] 70 | pub type FullMoveNumber = rules::FullMoveNumber;
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GameThread` is never constructed
[INFO] [stdout]   --> src/game.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub struct GameThread{
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameMessage` is never used
[INFO] [stdout]   --> src/game.rs:82:10
[INFO] [stdout]    |
[INFO] [stdout] 82 | pub enum GameMessage {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameResponse` is never used
[INFO] [stdout]   --> src/game.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum GameResponse {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameController` is never used
[INFO] [stdout]   --> src/game.rs:96:10
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub enum GameController {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `new_with_time_controls`, and `start_game` are never used
[INFO] [stdout]    --> src/game.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | impl Game{
[INFO] [stdout]     | --------- associated items in this implementation
[INFO] [stdout] 103 |     pub fn new(white: PlayerType, black: PlayerType) -> Game {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub fn new_with_time_controls(white: PlayerType, black: PlayerType, time_controls: TimeControls) -> Option<Game> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     fn start_game(&mut self) {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `start`, and `run` are never used
[INFO] [stdout]    --> src/game.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout] 135 | impl GameThread {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn new(game: Game) -> (GameThread, Sender<GameController>) {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 172 |     pub fn start(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     fn run(&mut self) {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlayerHandler` is never constructed
[INFO] [stdout]  --> src/handler.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct PlayerHandler{
[INFO] [stdout]   |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/handler.rs:13:13
[INFO] [stdout]    |
[INFO] [stdout] 12 |  impl PlayerHandler{
[INFO] [stdout]    |  ------------------ associated function in this implementation
[INFO] [stdout] 13 |      pub fn new(player_type: PlayerType, player_sender: mpsc::Sender<GameMessage>, player_receiver: mpsc::Receiver<GameResponse>) -> Self {
[INFO] [stdout]    |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `SetOutput`, `SetPrintTimestamp`, `SetTimestampDisplay`, `SetPrintThreadIdentifier`, `SetPrintLevel`, and `SetPrintMessage` are never constructed
[INFO] [stdout]   --> src/log.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub enum LogInstruction {
[INFO] [stdout]    |          -------------- variants in this enum
[INFO] [stdout] 38 |     SetLevel(LogLevel),
[INFO] [stdout] 39 |     SetOutput(LogOutput),
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 40 |     SetPrintTimestamp(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 41 |     SetTimestampDisplay(time_format::DisplayMode),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 42 |     SetPrintThreadIdentifier(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 43 |     SetPrintLevel(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 44 |     SetPrintMessage(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_id_channel_in_and_out` is never used
[INFO] [stdout]    --> src/log.rs:108:12
[INFO] [stdout]     |
[INFO] [stdout]  77 | impl LogThread {
[INFO] [stdout]     | -------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 108 |     pub fn from_id_channel_in_and_out( parent_thread: ThreadIdentifier, channel_in: Receiver<LogMessage>, out: LogOutput, ) -> (LogThread...
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PIECE_MAP` is never used
[INFO] [stdout]  --> src/move_parser.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub const PIECE_MAP: &[(&str, char)] = &[
[INFO] [stdout]   |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SORTED_PIECE_MAP` is never used
[INFO] [stdout]   --> src/move_parser.rs:37:11
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub const SORTED_PIECE_MAP: &[(char, char)] = &[('+', '+'), ('-', '-'), ('0', '0'), ('1', '1'), ('2', '2'), ('3', '3'), ('4', '4'), ('5',...
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ParseError` is never used
[INFO] [stdout]   --> src/move_parser.rs:39:10
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub enum ParseError{
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Token` is never used
[INFO] [stdout]    --> src/move_parser.rs:113:10
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub enum Token {
[INFO] [stdout]     |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ProtoMove` is never constructed
[INFO] [stdout]    --> src/move_parser.rs:128:12
[INFO] [stdout]     |
[INFO] [stdout] 128 | pub struct ProtoMove {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `AlgebraicParseStage` is never used
[INFO] [stdout]    --> src/move_parser.rs:140:10
[INFO] [stdout]     |
[INFO] [stdout] 140 | pub enum AlgebraicParseStage{
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `finalize` is never used
[INFO] [stdout]    --> src/move_parser.rs:576:4
[INFO] [stdout]     |
[INFO] [stdout] 576 | fn finalize(proto_move: ProtoMove) -> Result<ProtoMove, ParseError>{
[INFO] [stdout]     |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tokenize_string` is never used
[INFO] [stdout]    --> src/move_parser.rs:665:4
[INFO] [stdout]     |
[INFO] [stdout] 665 | fn tokenize_string(string: &str, map:&[(char, char)], color: Color) -> Result<Vec<Token>, ParseError>{
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pre_process_tokens` is never used
[INFO] [stdout]    --> src/move_parser.rs:748:4
[INFO] [stdout]     |
[INFO] [stdout] 748 | fn pre_process_tokens(tokens: &Vec<Token>) -> Result<Vec<Token>, ParseError>{
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `from_simplified_algebraic_notation` is never used
[INFO] [stdout]    --> src/move_parser.rs:154:12
[INFO] [stdout]     |
[INFO] [stdout] 154 |     pub fn from_simplified_algebraic_notation(string: &str, active_player: Color) -> Result<ProtoMove, ParseError>{
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `from_long_algebraic_notation` is never used
[INFO] [stdout]    --> src/move_parser.rs:375:12
[INFO] [stdout]     |
[INFO] [stdout] 375 |     pub fn from_long_algebraic_notation(string: &str, active_player: Color) -> Result<ProtoMove, ParseError> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_from_proto` is never used
[INFO] [stdout]    --> src/move_parser.rs:518:16
[INFO] [stdout]     |
[INFO] [stdout] 517 |     impl ChessMove {
[INFO] [stdout]     |     -------------- associated function in this implementation
[INFO] [stdout] 518 |         pub fn new_from_proto(board: &mut Board, proto_move: ProtoMove) -> Result<ChessMove, ParseError> {
[INFO] [stdout]     |                ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PlayerClient` is never used
[INFO] [stdout]  --> src/player_agent.rs:3:10
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub enum PlayerClient {
[INFO] [stdout]   |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `PlayerController` is never used
[INFO] [stdout]  --> src/player_agent.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub trait PlayerController {
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Player` is never used
[INFO] [stdout]  --> src/player_agent/player_actor.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub trait Player {
[INFO] [stdout]   |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `FullMoveNumber` is never used
[INFO] [stdout]   --> src/rules.rs:19:10
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub type FullMoveNumber = u8;
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameState` is never used
[INFO] [stdout]   --> src/rules.rs:22:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub enum GameState {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TimeControls` is never constructed
[INFO] [stdout]    --> src/rules.rs:102:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | pub struct TimeControls {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Timer` is never used
[INFO] [stdout]    --> src/rules.rs:116:11
[INFO] [stdout]     |
[INFO] [stdout] 116 | pub trait Timer {
[INFO] [stdout]     |           ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Simple` and `Debug` are never constructed
[INFO] [stdout]   --> src/time.rs:64:9
[INFO] [stdout]    |
[INFO] [stdout] 62 |     pub enum DisplayMode {
[INFO] [stdout]    |              ----------- variants in this enum
[INFO] [stdout] 63 |         ISO8601,
[INFO] [stdout] 64 |         Simple,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 65 |         Debug,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DisplayMode` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `CurrentBackend` is never used
[INFO] [stdout]   --> src/ui.rs:16:6
[INFO] [stdout]    |
[INFO] [stdout] 16 | type CurrentBackend = backend_x11::X11Backend;
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Web` is never constructed
[INFO] [stdout]   --> src/ui.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub enum UIType {
[INFO] [stdout]    |          ------ variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 23 |     Web,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Game` is never constructed
[INFO] [stdout]   --> src/ui.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub enum UIState {
[INFO] [stdout]    |          ------- variant in this enum
[INFO] [stdout] 27 |     Menu,
[INFO] [stdout] 28 |     Game,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UserInput` is never used
[INFO] [stdout]   --> src/ui.rs:31:10
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub enum UserInput {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `ui_state` and `log_channel` are never read
[INFO] [stdout]   --> src/ui.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct UIManager {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     ui_state: UIState,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 40 |     log_channel: Option<mpsc::Sender<LogMessage>>,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `GraphicsBackend` is never used
[INFO] [stdout]   --> src/ui.rs:43:7
[INFO] [stdout]    |
[INFO] [stdout] 43 | trait GraphicsBackend {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UiUpdate` is never used
[INFO] [stdout]   --> src/ui.rs:50:10
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub enum UiUpdate {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UiMessage` is never used
[INFO] [stdout]   --> src/ui.rs:55:10
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub enum UiMessage {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WIN32Backend` is never constructed
[INFO] [stdout]  --> src/ui/backend_win32.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct WIN32Backend {
[INFO] [stdout]   |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `X11Backend` is never constructed
[INFO] [stdout]  --> src/ui/backend_x11.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct X11Backend {
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]   --> src/clock.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]   --> src/clock.rs:34:40
[INFO] [stdout]    |
[INFO] [stdout] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1.25s
[INFO] running `Command { std: "docker" "inspect" "6931d37f25b9852e0035aafad4d47df20f16650d771a78be8ce40966b16632b6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6931d37f25b9852e0035aafad4d47df20f16650d771a78be8ce40966b16632b6", kill_on_drop: false }`
[INFO] [stdout] 6931d37f25b9852e0035aafad4d47df20f16650d771a78be8ce40966b16632b6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cf49c8efead29ca67e81458e60c3d5aa08ce17b3e99c596bf28ca65ae2661a18
[INFO] running `Command { std: "docker" "start" "-a" "cf49c8efead29ca67e81458e60c3d5aa08ce17b3e99c596bf28ca65ae2661a18", kill_on_drop: false }`
[INFO] [stderr]    Compiling rusty_chess v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]  --> src/chess_bot.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::error::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::player_agent`
[INFO] [stdout]  --> src/game.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::player_agent;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]   --> src/game.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::thread;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ProtoMove`
[INFO] [stdout]  --> src/player_agent/player_actor.rs:3:61
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::move_parser::{chess_notation_parser, ParseError, ProtoMove};
[INFO] [stdout]   |                                                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Instant`
[INFO] [stdout]  --> src/rules.rs:1:27
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::time::{Duration, Instant};
[INFO] [stdout]   |                           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Config`
[INFO] [stdout]   --> src/main.rs:24:35
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::config::{parse_config, Config, ConfigResult};
[INFO] [stdout]    |                                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game_id`
[INFO] [stdout]   --> src/chess_bot.rs:42:35
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `move_notation`
[INFO] [stdout]   --> src/chess_bot.rs:42:50
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_move_notation`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game_id`
[INFO] [stdout]   --> src/chess_bot.rs:48:40
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stdout]    |                                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file`
[INFO] [stdout]    --> src/log.rs:273:29
[INFO] [stdout]     |
[INFO] [stdout] 273 |             LogOutput::File(file) => {
[INFO] [stdout]     |                             ^^^^ help: if this is intentional, prefix it with an underscore: `_file`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/ui.rs:81:12
[INFO] [stdout]    |
[INFO] [stdout] 81 |     fn run(mut self) -> UIManager {
[INFO] [stdout]    |            ----^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `log_handle`
[INFO] [stdout]   --> src/main.rs:67:10
[INFO] [stdout]    |
[INFO] [stdout] 67 |     let (log_handle, log_channel) = common_lib::init_logger(main_id, log_output);
[INFO] [stdout]    |          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_log_handle`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `king_moved` and `rook_moved` are never used
[INFO] [stdout]   --> src/board.rs:37:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub trait CastlingRightsExt{
[INFO] [stdout]    |           ----------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 37 |     fn king_moved(&mut self, king_color: Color);
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 38 |     fn rook_moved(&mut self, rook_color: Color, kingside: bool);
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BOARD_TEMPLATE` is never used
[INFO] [stdout]    --> src/board.rs:135:7
[INFO] [stdout]     |
[INFO] [stdout] 135 | const BOARD_TEMPLATE: &'static str =
[INFO] [stdout]     |       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/board.rs:199:12
[INFO] [stdout]     |
[INFO] [stdout] 149 | impl Board {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn clone(&self) -> Board {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 239 |     pub fn get_piece_count(&self) -> u8 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 338 |     pub fn find_piece_positions(&self, piece: Piece) -> Vec<Square> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 439 |     pub fn get_char_at(&self, square: Square) -> char {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 683 |     pub fn sees_like_knight(&self, square:Square) -> Bitboard {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 791 |     pub fn get_pieces_at_bitboard(&self, bitboard: Bitboard) -> Vec<(Piece, Square)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 815 |     pub fn get_active_pieces(&self) -> Vec<(Piece, Square)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/board/pieces.rs:35:11
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl Piece {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  35 |     const PIECES_WITH_COLOR: [(Piece,Color); 12] = [
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  62 |     pub fn iter_with_color() -> impl Iterator<Item=(Piece, Color)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn is_rook(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn is_knight(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn is_bishop(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn is_queen(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub fn is_king(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 130 |     pub fn moves_diagonally(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 171 |     pub fn to_index(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 175 |     pub fn from_index(index: usize) -> Option<Piece> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/board/square.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout]  9 | ...trait SquareExt {
[INFO] [stdout]    |          --------- associated items in this trait
[INFO] [stdout] ...
[INFO] [stdout] 17 | ...const A1: Square; const A2: Square; const A3: Square; const A4: Square; const A5: Square; const A6: Square; const A7: Square; const A8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 18 | ...const B1: Square; const B2: Square; const B3: Square; const B4: Square; const B5: Square; const B6: Square; const B7: Square; const B8: S...
[INFO] [stdout]    |                            ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 19 | ...const C1: Square; const C2: Square; const C3: Square; const C4: Square; const C5: Square; const C6: Square; const C7: Square; const C8: S...
[INFO] [stdout]    |                            ^^                                  ^^                ^^                ^^                ^^
[INFO] [stdout] 20 | ...const D1: Square; const D2: Square; const D3: Square; const D4: Square; const D5: Square; const D6: Square; const D7: Square; const D8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                                  ^^                                  ^^
[INFO] [stdout] 21 | ...const E1: Square; const E2: Square; const E3: Square; const E4: Square; const E5: Square; const E6: Square; const E7: Square; const E8: S...
[INFO] [stdout]    |                                              ^^                                  ^^                ^^                ^^
[INFO] [stdout] 22 | ...const F1: Square; const F2: Square; const F3: Square; const F4: Square; const F5: Square; const F6: Square; const F7: Square; const F8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                                  ^^                                  ^^
[INFO] [stdout] 23 | ...const G1: Square; const G2: Square; const G3: Square; const G4: Square; const G5: Square; const G6: Square; const G7: Square; const G8: S...
[INFO] [stdout]    |                            ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 24 | ...const H1: Square; const H2: Square; const H3: Square; const H4: Square; const H5: Square; const H6: Square; const H7: Square; const H8: S...
[INFO] [stdout]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stdout] 25 | .../// Array of square labels, from "a8","b8","c8" ... to ..., "f1", "g1", "h1".
[INFO] [stdout] 26 | ...const SQUARES: [&'static str; 64];
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 | ...fn get_rows(&self, ascending : bool) -> RowIterator;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 | ...fn get_cols(&self, ascending : bool) -> ColIterator;
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 | ...fn get_pos_pair(&self) -> (Row, Col);
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 46 | .../// Returns the index of the square as a `usize`.
[INFO] [stdout] 47 | ...fn get_index(&self) -> usize;
[INFO] [stdout]    |       ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61 | ...fn iter_files() -> impl Iterator<Item = char>;
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 | ...fn iter_squares() -> impl Iterator<Item = Square>;
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 | ...fn to_square_str(&self) -> &str;
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_rank` is never used
[INFO] [stdout]    --> src/board/square.rs:252:8
[INFO] [stdout]     |
[INFO] [stdout] 234 | pub trait RowExt {
[INFO] [stdout]     |           ------ method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 252 |     fn to_rank(&self) -> u8;
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_file` is never used
[INFO] [stdout]    --> src/board/square.rs:272:8
[INFO] [stdout]     |
[INFO] [stdout] 254 | pub trait ColExt {
[INFO] [stdout]     |           ------ method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 272 |     fn to_file(&self) -> char;
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RowIterator` is never constructed
[INFO] [stdout]    --> src/board/square.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct RowIterator{
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ColIterator` is never constructed
[INFO] [stdout]    --> src/board/square.rs:344:12
[INFO] [stdout]     |
[INFO] [stdout] 344 | pub struct ColIterator{
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessApiConfig` is never constructed
[INFO] [stdout]  --> src/chess_bot.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ChessApiConfig {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ChessApiError` is never used
[INFO] [stdout]   --> src/chess_bot.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ChessApiError {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessApiClient` is never constructed
[INFO] [stdout]   --> src/chess_bot.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct ChessApiClient {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `authenticate`, `make_move`, and `get_game_state` are never used
[INFO] [stdout]   --> src/chess_bot.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 29 | impl ChessApiClient {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 30 |     /// Creates a new API client with the given configuration
[INFO] [stdout] 31 |     pub fn new(config: ChessApiConfig) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub async fn authenticate(&self) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `CaptureCheck`, `CaptureCheckmate`, `CaptureStalemate`, and `GeneratedOnly` are never constructed
[INFO] [stdout]   --> src/chess_moves.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub enum MoveData {
[INFO] [stdout]    |          -------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 37 |     CaptureCheck = 21,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 38 |     CaptureCheckmate = 22,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 39 |     CaptureStalemate = 23,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     GeneratedOnly,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SpecialMoveType` is never used
[INFO] [stdout]   --> src/chess_moves.rs:55:6
[INFO] [stdout]    |
[INFO] [stdout] 55 | enum SpecialMoveType {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/chess_moves.rs:66:19
[INFO] [stdout]    |
[INFO] [stdout] 66 |     PieceNotFound(Square),
[INFO] [stdout]    |     ------------- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 66 -     PieceNotFound(Square),
[INFO] [stdout] 66 +     PieceNotFound(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/chess_moves.rs:67:20
[INFO] [stdout]    |
[INFO] [stdout] 67 |     OriginNotFound(Piece),
[INFO] [stdout]    |     -------------- ^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 67 -     OriginNotFound(Piece),
[INFO] [stdout] 67 +     OriginNotFound(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/chess_moves.rs:69:22
[INFO] [stdout]    |
[INFO] [stdout] 69 |     DisambiguousMove(Disambiguity), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stdout]    |     ---------------- ^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 69 -     DisambiguousMove(Disambiguity), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stdout] 69 +     DisambiguousMove(()), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `assemble_special_move` and `to_simplified` are never used
[INFO] [stdout]    --> src/chess_moves.rs:455:8
[INFO] [stdout]     |
[INFO] [stdout] 130 | impl ChessMove {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 455 |     fn assemble_special_move(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 517 |     pub fn to_simplified(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `special_move_builder` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1634:4
[INFO] [stdout]      |
[INFO] [stdout] 1634 | fn special_move_builder(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_none_or_promotion` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1655:4
[INFO] [stdout]      |
[INFO] [stdout] 1655 | fn build_none_or_promotion(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_move_type` is never used
[INFO] [stdout]     --> src/chess_moves.rs:1694:4
[INFO] [stdout]      |
[INFO] [stdout] 1694 | fn build_move_type(base: MoveData, result: MoveResult) -> MoveData {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `is_check`, `is_checkmate`, `is_stalemate`, and `is_en_passant` are never used
[INFO] [stdout]     --> src/chess_moves.rs:1760:12
[INFO] [stdout]      |
[INFO] [stdout] 1704 | impl MoveData {
[INFO] [stdout]      | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1760 |     pub fn is_check(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1771 |     pub fn is_checkmate(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1782 |     pub fn is_stalemate(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1810 |     pub fn is_en_passant(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChessClock` is never constructed
[INFO] [stdout]  --> src/clock.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct ChessClock{
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/clock.rs:16:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl ChessClock{
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 16 |     fn new() -> Self{
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Network`, `Game`, `Terminal`, `GUI`, and `Other` are never constructed
[INFO] [stdout]   --> src/common.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub enum ThreadIdentifier {
[INFO] [stdout]    |          ---------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 17 |     Network(ThreadIdHash),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 18 |     Game(ThreadIdHash),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 19 |     UI(ThreadIdHash),
[INFO] [stdout] 20 |     Terminal(ThreadIdHash),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 21 |     GUI(ThreadIdHash),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 22 |     Other(ThreadIdHash, &'static str),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ThreadIdentifier` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PlayerType` is never used
[INFO] [stdout]   --> src/game.rs:42:10
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub enum PlayerType{
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GameMetadata` is never constructed
[INFO] [stdout]   --> src/game.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub struct GameMetadata {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Game` is never constructed
[INFO] [stdout]   --> src/game.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct Game{
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `FullMoveNumber` is never used
[INFO] [stdout]   --> src/game.rs:70:10
[INFO] [stdout]    |
[INFO] [stdout] 70 | pub type FullMoveNumber = rules::FullMoveNumber;
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GameThread` is never constructed
[INFO] [stdout]   --> src/game.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub struct GameThread{
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameMessage` is never used
[INFO] [stdout]   --> src/game.rs:82:10
[INFO] [stdout]    |
[INFO] [stdout] 82 | pub enum GameMessage {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameResponse` is never used
[INFO] [stdout]   --> src/game.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum GameResponse {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameController` is never used
[INFO] [stdout]   --> src/game.rs:96:10
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub enum GameController {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `new_with_time_controls`, and `start_game` are never used
[INFO] [stdout]    --> src/game.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | impl Game{
[INFO] [stdout]     | --------- associated items in this implementation
[INFO] [stdout] 103 |     pub fn new(white: PlayerType, black: PlayerType) -> Game {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub fn new_with_time_controls(white: PlayerType, black: PlayerType, time_controls: TimeControls) -> Option<Game> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     fn start_game(&mut self) {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `start`, and `run` are never used
[INFO] [stdout]    --> src/game.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout] 135 | impl GameThread {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn new(game: Game) -> (GameThread, Sender<GameController>) {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 172 |     pub fn start(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     fn run(&mut self) {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlayerHandler` is never constructed
[INFO] [stdout]  --> src/handler.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct PlayerHandler{
[INFO] [stdout]   |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/handler.rs:13:13
[INFO] [stdout]    |
[INFO] [stdout] 12 |  impl PlayerHandler{
[INFO] [stdout]    |  ------------------ associated function in this implementation
[INFO] [stdout] 13 |      pub fn new(player_type: PlayerType, player_sender: mpsc::Sender<GameMessage>, player_receiver: mpsc::Receiver<GameResponse>) -> Self {
[INFO] [stdout]    |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `SetOutput`, `SetPrintTimestamp`, `SetTimestampDisplay`, `SetPrintThreadIdentifier`, `SetPrintLevel`, and `SetPrintMessage` are never constructed
[INFO] [stdout]   --> src/log.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub enum LogInstruction {
[INFO] [stdout]    |          -------------- variants in this enum
[INFO] [stdout] 38 |     SetLevel(LogLevel),
[INFO] [stdout] 39 |     SetOutput(LogOutput),
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 40 |     SetPrintTimestamp(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 41 |     SetTimestampDisplay(time_format::DisplayMode),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 42 |     SetPrintThreadIdentifier(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 43 |     SetPrintLevel(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 44 |     SetPrintMessage(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_id_channel_in_and_out` is never used
[INFO] [stdout]    --> src/log.rs:108:12
[INFO] [stdout]     |
[INFO] [stdout]  77 | impl LogThread {
[INFO] [stdout]     | -------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 108 |     pub fn from_id_channel_in_and_out( parent_thread: ThreadIdentifier, channel_in: Receiver<LogMessage>, out: LogOutput, ) -> (LogThread...
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PIECE_MAP` is never used
[INFO] [stdout]  --> src/move_parser.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub const PIECE_MAP: &[(&str, char)] = &[
[INFO] [stdout]   |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/move_parser.rs:45:19
[INFO] [stdout]    |
[INFO] [stdout] 45 |     InvalidSquare(Square),
[INFO] [stdout]    |     ------------- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 45 -     InvalidSquare(Square),
[INFO] [stdout] 45 +     InvalidSquare(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/move_parser.rs:49:29
[INFO] [stdout]    |
[INFO] [stdout] 49 |     AlgebraicParseModeError(AlgebraicParseStage),
[INFO] [stdout]    |     ----------------------- ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 49 -     AlgebraicParseModeError(AlgebraicParseStage),
[INFO] [stdout] 49 +     AlgebraicParseModeError(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/move_parser.rs:51:22
[INFO] [stdout]    |
[INFO] [stdout] 51 |     IllegalMoveError(MoveError),
[INFO] [stdout]    |     ---------------- ^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 51 -     IllegalMoveError(MoveError),
[INFO] [stdout] 51 +     IllegalMoveError(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/move_parser.rs:53:25
[INFO] [stdout]    |
[INFO] [stdout] 53 |     MalformedExpression(Token),
[INFO] [stdout]    |     ------------------- ^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 53 -     MalformedExpression(Token),
[INFO] [stdout] 53 +     MalformedExpression(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `DisambiguousMoveError` and `Todo` are never constructed
[INFO] [stdout]   --> src/move_parser.rs:50:5
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub enum ParseError{
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 50 |     DisambiguousMoveError(Disambiguity),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     Todo,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Piece` is never constructed
[INFO] [stdout]    --> src/move_parser.rs:141:5
[INFO] [stdout]     |
[INFO] [stdout] 140 | pub enum AlgebraicParseStage{
[INFO] [stdout]     |          ------------------- variant in this enum
[INFO] [stdout] 141 |     Piece,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AlgebraicParseStage` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PlayerClient` is never used
[INFO] [stdout]  --> src/player_agent.rs:3:10
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub enum PlayerClient {
[INFO] [stdout]   |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `PlayerController` is never used
[INFO] [stdout]  --> src/player_agent.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub trait PlayerController {
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Player` is never used
[INFO] [stdout]  --> src/player_agent/player_actor.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub trait Player {
[INFO] [stdout]   |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `FullMoveNumber` is never used
[INFO] [stdout]   --> src/rules.rs:19:10
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub type FullMoveNumber = u8;
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `GameState` is never used
[INFO] [stdout]   --> src/rules.rs:22:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub enum GameState {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TimeControls` is never constructed
[INFO] [stdout]    --> src/rules.rs:102:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | pub struct TimeControls {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Timer` is never used
[INFO] [stdout]    --> src/rules.rs:116:11
[INFO] [stdout]     |
[INFO] [stdout] 116 | pub trait Timer {
[INFO] [stdout]     |           ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Simple` and `Debug` are never constructed
[INFO] [stdout]   --> src/time.rs:64:9
[INFO] [stdout]    |
[INFO] [stdout] 62 |     pub enum DisplayMode {
[INFO] [stdout]    |              ----------- variants in this enum
[INFO] [stdout] 63 |         ISO8601,
[INFO] [stdout] 64 |         Simple,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 65 |         Debug,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DisplayMode` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `CurrentBackend` is never used
[INFO] [stdout]   --> src/ui.rs:16:6
[INFO] [stdout]    |
[INFO] [stdout] 16 | type CurrentBackend = backend_x11::X11Backend;
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Web` is never constructed
[INFO] [stdout]   --> src/ui.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub enum UIType {
[INFO] [stdout]    |          ------ variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 23 |     Web,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Game` is never constructed
[INFO] [stdout]   --> src/ui.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub enum UIState {
[INFO] [stdout]    |          ------- variant in this enum
[INFO] [stdout] 27 |     Menu,
[INFO] [stdout] 28 |     Game,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UserInput` is never used
[INFO] [stdout]   --> src/ui.rs:31:10
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub enum UserInput {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `ui_state` and `log_channel` are never read
[INFO] [stdout]   --> src/ui.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct UIManager {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     ui_state: UIState,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 40 |     log_channel: Option<mpsc::Sender<LogMessage>>,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `GraphicsBackend` is never used
[INFO] [stdout]   --> src/ui.rs:43:7
[INFO] [stdout]    |
[INFO] [stdout] 43 | trait GraphicsBackend {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UiUpdate` is never used
[INFO] [stdout]   --> src/ui.rs:50:10
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub enum UiUpdate {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `UiMessage` is never used
[INFO] [stdout]   --> src/ui.rs:55:10
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub enum UiMessage {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WIN32Backend` is never constructed
[INFO] [stdout]  --> src/ui/backend_win32.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct WIN32Backend {
[INFO] [stdout]   |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `X11Backend` is never constructed
[INFO] [stdout]  --> src/ui/backend_x11.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct X11Backend {
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]   --> src/clock.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]   --> src/clock.rs:34:40
[INFO] [stdout]    |
[INFO] [stdout] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.90s
[INFO] running `Command { std: "docker" "inspect" "cf49c8efead29ca67e81458e60c3d5aa08ce17b3e99c596bf28ca65ae2661a18", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cf49c8efead29ca67e81458e60c3d5aa08ce17b3e99c596bf28ca65ae2661a18", kill_on_drop: false }`
[INFO] [stdout] cf49c8efead29ca67e81458e60c3d5aa08ce17b3e99c596bf28ca65ae2661a18
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] cac07d55e96db70f8cdbf3c56c607352a0b6e4aa054480d551e6dfab6e3db42f
[INFO] running `Command { std: "docker" "start" "-a" "cac07d55e96db70f8cdbf3c56c607352a0b6e4aa054480d551e6dfab6e3db42f", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `std::error::Error`
[INFO] [stderr]  --> src/chess_bot.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use std::error::Error;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::player_agent`
[INFO] [stderr]  --> src/game.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use crate::player_agent;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::thread`
[INFO] [stderr]   --> src/game.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use std::thread;
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ProtoMove`
[INFO] [stderr]  --> src/player_agent/player_actor.rs:3:61
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::move_parser::{chess_notation_parser, ParseError, ProtoMove};
[INFO] [stderr]   |                                                             ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Instant`
[INFO] [stderr]  --> src/rules.rs:1:27
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::time::{Duration, Instant};
[INFO] [stderr]   |                           ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Config`
[INFO] [stderr]   --> src/main.rs:24:35
[INFO] [stderr]    |
[INFO] [stderr] 24 | use crate::config::{parse_config, Config, ConfigResult};
[INFO] [stderr]    |                                   ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `game_id`
[INFO] [stderr]   --> src/chess_bot.rs:42:35
[INFO] [stderr]    |
[INFO] [stderr] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stderr]    |                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `move_notation`
[INFO] [stderr]   --> src/chess_bot.rs:42:50
[INFO] [stderr]    |
[INFO] [stderr] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stderr]    |                                                  ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_move_notation`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `game_id`
[INFO] [stderr]   --> src/chess_bot.rs:48:40
[INFO] [stderr]    |
[INFO] [stderr] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stderr]    |                                        ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `file`
[INFO] [stderr]    --> src/log.rs:273:29
[INFO] [stderr]     |
[INFO] [stderr] 273 |             LogOutput::File(file) => {
[INFO] [stderr]     |                             ^^^^ help: if this is intentional, prefix it with an underscore: `_file`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/ui.rs:81:12
[INFO] [stderr]    |
[INFO] [stderr] 81 |     fn run(mut self) -> UIManager {
[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: unused variable: `log_handle`
[INFO] [stderr]   --> src/main.rs:67:10
[INFO] [stderr]    |
[INFO] [stderr] 67 |     let (log_handle, log_channel) = common_lib::init_logger(main_id, log_output);
[INFO] [stderr]    |          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_log_handle`
[INFO] [stderr] 
[INFO] [stderr] warning: methods `king_moved` and `rook_moved` are never used
[INFO] [stderr]   --> src/board.rs:37:8
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub trait CastlingRightsExt{
[INFO] [stderr]    |           ----------------- methods in this trait
[INFO] [stderr] ...
[INFO] [stderr] 37 |     fn king_moved(&mut self, king_color: Color);
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr] 38 |     fn rook_moved(&mut self, rook_color: Color, kingside: bool);
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `BOARD_TEMPLATE` is never used
[INFO] [stderr]    --> src/board.rs:135:7
[INFO] [stderr]     |
[INFO] [stderr] 135 | const BOARD_TEMPLATE: &'static str =
[INFO] [stderr]     |       ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/board.rs:199:12
[INFO] [stderr]     |
[INFO] [stderr] 149 | impl Board {
[INFO] [stderr]     | ---------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 199 |     pub fn clone(&self) -> Board {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 239 |     pub fn get_piece_count(&self) -> u8 {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 338 |     pub fn find_piece_positions(&self, piece: Piece) -> Vec<Square> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 439 |     pub fn get_char_at(&self, square: Square) -> char {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 683 |     pub fn sees_like_knight(&self, square:Square) -> Bitboard {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 791 |     pub fn get_pieces_at_bitboard(&self, bitboard: Bitboard) -> Vec<(Piece, Square)> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 815 |     pub fn get_active_pieces(&self) -> Vec<(Piece, Square)> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/board/pieces.rs:35:11
[INFO] [stderr]     |
[INFO] [stderr]  26 | impl Piece {
[INFO] [stderr]     | ---------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  35 |     const PIECES_WITH_COLOR: [(Piece,Color); 12] = [
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  62 |     pub fn iter_with_color() -> impl Iterator<Item=(Piece, Color)> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  99 |     pub fn is_rook(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 105 |     pub fn is_knight(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 111 |     pub fn is_bishop(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 117 |     pub fn is_queen(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 123 |     pub fn is_king(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 130 |     pub fn moves_diagonally(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 171 |     pub fn to_index(&self) -> usize {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 175 |     pub fn from_index(index: usize) -> Option<Piece> {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]   --> src/board/square.rs:17:11
[INFO] [stderr]    |
[INFO] [stderr]  9 | ...trait SquareExt {
[INFO] [stderr]    |          --------- associated items in this trait
[INFO] [stderr] ...
[INFO] [stderr] 17 | ...const A1: Square; const A2: Square; const A3: Square; const A4: Square; const A5: Square; const A6: Square; const A7: Square; const A8: S...
[INFO] [stderr]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stderr] 18 | ...const B1: Square; const B2: Square; const B3: Square; const B4: Square; const B5: Square; const B6: Square; const B7: Square; const B8: S...
[INFO] [stderr]    |                            ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stderr] 19 | ...const C1: Square; const C2: Square; const C3: Square; const C4: Square; const C5: Square; const C6: Square; const C7: Square; const C8: S...
[INFO] [stderr]    |                            ^^                                  ^^                ^^                ^^                ^^
[INFO] [stderr] 20 | ...const D1: Square; const D2: Square; const D3: Square; const D4: Square; const D5: Square; const D6: Square; const D7: Square; const D8: S...
[INFO] [stderr]    |          ^^                ^^                ^^                ^^                                  ^^                                  ^^
[INFO] [stderr] 21 | ...const E1: Square; const E2: Square; const E3: Square; const E4: Square; const E5: Square; const E6: Square; const E7: Square; const E8: S...
[INFO] [stderr]    |                                              ^^                                  ^^                ^^                ^^
[INFO] [stderr] 22 | ...const F1: Square; const F2: Square; const F3: Square; const F4: Square; const F5: Square; const F6: Square; const F7: Square; const F8: S...
[INFO] [stderr]    |          ^^                ^^                ^^                ^^                                  ^^                                  ^^
[INFO] [stderr] 23 | ...const G1: Square; const G2: Square; const G3: Square; const G4: Square; const G5: Square; const G6: Square; const G7: Square; const G8: S...
[INFO] [stderr]    |                            ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stderr] 24 | ...const H1: Square; const H2: Square; const H3: Square; const H4: Square; const H5: Square; const H6: Square; const H7: Square; const H8: S...
[INFO] [stderr]    |          ^^                ^^                ^^                ^^                ^^                ^^                ^^                ^^
[INFO] [stderr] 25 | .../// Array of square labels, from "a8","b8","c8" ... to ..., "f1", "g1", "h1".
[INFO] [stderr] 26 | ...const SQUARES: [&'static str; 64];
[INFO] [stderr]    |          ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 35 | ...fn get_rows(&self, ascending : bool) -> RowIterator;
[INFO] [stderr]    |       ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 41 | ...fn get_cols(&self, ascending : bool) -> ColIterator;
[INFO] [stderr]    |       ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 45 | ...fn get_pos_pair(&self) -> (Row, Col);
[INFO] [stderr]    |       ^^^^^^^^^^^^
[INFO] [stderr] 46 | .../// Returns the index of the square as a `usize`.
[INFO] [stderr] 47 | ...fn get_index(&self) -> usize;
[INFO] [stderr]    |       ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 61 | ...fn iter_files() -> impl Iterator<Item = char>;
[INFO] [stderr]    |       ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 65 | ...fn iter_squares() -> impl Iterator<Item = Square>;
[INFO] [stderr]    |       ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 70 | ...fn to_square_str(&self) -> &str;
[INFO] [stderr]    |       ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `to_rank` is never used
[INFO] [stderr]    --> src/board/square.rs:252:8
[INFO] [stderr]     |
[INFO] [stderr] 234 | pub trait RowExt {
[INFO] [stderr]     |           ------ method in this trait
[INFO] [stderr] ...
[INFO] [stderr] 252 |     fn to_rank(&self) -> u8;
[INFO] [stderr]     |        ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `to_file` is never used
[INFO] [stderr]    --> src/board/square.rs:272:8
[INFO] [stderr]     |
[INFO] [stderr] 254 | pub trait ColExt {
[INFO] [stderr]     |           ------ method in this trait
[INFO] [stderr] ...
[INFO] [stderr] 272 |     fn to_file(&self) -> char;
[INFO] [stderr]     |        ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `RowIterator` is never constructed
[INFO] [stderr]    --> src/board/square.rs:340:12
[INFO] [stderr]     |
[INFO] [stderr] 340 | pub struct RowIterator{
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ColIterator` is never constructed
[INFO] [stderr]    --> src/board/square.rs:344:12
[INFO] [stderr]     |
[INFO] [stderr] 344 | pub struct ColIterator{
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ChessApiConfig` is never constructed
[INFO] [stderr]  --> src/chess_bot.rs:9:12
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub struct ChessApiConfig {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stdout] 
[INFO] [stderr] warning: enum `ChessApiError` is never used
[INFO] [stdout] running 34 tests
[INFO] [stderr]   --> src/chess_bot.rs:17:10
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub enum ChessApiError {
[INFO] [stderr]    |          ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ChessApiClient` is never constructed
[INFO] [stderr]   --> src/chess_bot.rs:25:12
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub struct ChessApiClient {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `authenticate`, `make_move`, and `get_game_state` are never used
[INFO] [stderr]   --> src/chess_bot.rs:31:12
[INFO] [stderr]    |
[INFO] [stderr] 29 | impl ChessApiClient {
[INFO] [stderr]    | ------------------- associated items in this implementation
[INFO] [stderr] 30 |     /// Creates a new API client with the given configuration
[INFO] [stderr] 31 |     pub fn new(config: ChessApiConfig) -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 36 |     pub async fn authenticate(&self) -> Result<(), ChessApiError> {
[INFO] [stderr]    |                  ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 42 |     pub async fn make_move(&self, game_id: &str, move_notation: &str) -> Result<(), ChessApiError> {
[INFO] [stderr]    |                  ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 48 |     pub async fn get_game_state(&self, game_id: &str) -> Result<String, ChessApiError> {
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `CaptureCheck`, `CaptureCheckmate`, `CaptureStalemate`, and `GeneratedOnly` are never constructed
[INFO] [stderr]   --> src/chess_moves.rs:37:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub enum MoveData {
[INFO] [stderr]    |          -------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 37 |     CaptureCheck = 21,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 38 |     CaptureCheckmate = 22,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 39 |     CaptureStalemate = 23,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 45 |     GeneratedOnly,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MoveData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: enum `SpecialMoveType` is never used
[INFO] [stderr]   --> src/chess_moves.rs:55:6
[INFO] [stderr]    |
[INFO] [stderr] 55 | enum SpecialMoveType {
[INFO] [stderr]    |      ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/chess_moves.rs:66:19
[INFO] [stderr]    |
[INFO] [stderr] 66 |     PieceNotFound(Square),
[INFO] [stderr]    |     ------------- ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 66 -     PieceNotFound(Square),
[INFO] [stderr] 66 +     PieceNotFound(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/chess_moves.rs:67:20
[INFO] [stderr]    |
[INFO] [stderr] 67 |     OriginNotFound(Piece),
[INFO] [stderr]    |     -------------- ^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 67 -     OriginNotFound(Piece),
[INFO] [stderr] 67 +     OriginNotFound(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/chess_moves.rs:69:22
[INFO] [stderr]    |
[INFO] [stderr] 69 |     DisambiguousMove(Disambiguity), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stderr]    |     ---------------- ^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MoveError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 69 -     DisambiguousMove(Disambiguity), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stderr] 69 +     DisambiguousMove(()), // Disambiguity should match the type of disambiguation that would be needed
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `assemble_special_move` and `to_simplified` are never used
[INFO] [stderr]    --> src/chess_moves.rs:455:8
[INFO] [stderr]     |
[INFO] [stderr] 130 | impl ChessMove {
[INFO] [stderr]     | -------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 455 |     fn assemble_special_move(
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 517 |     pub fn to_simplified(&self) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `special_move_builder` is never used
[INFO] [stderr]     --> src/chess_moves.rs:1634:4
[INFO] [stderr]      |
[INFO] [stderr] 1634 | fn special_move_builder(
[INFO] [stderr]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_none_or_promotion` is never used
[INFO] [stderr]     --> src/chess_moves.rs:1655:4
[INFO] [stderr]      |
[INFO] [stderr] 1655 | fn build_none_or_promotion(
[INFO] [stderr]      |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_move_type` is never used
[INFO] [stderr]     --> src/chess_moves.rs:1694:4
[INFO] [stderr]      |
[INFO] [stderr] 1694 | fn build_move_type(base: MoveData, result: MoveResult) -> MoveData {
[INFO] [stderr]      |    ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `is_check`, `is_checkmate`, `is_stalemate`, and `is_en_passant` are never used
[INFO] [stderr]     --> src/chess_moves.rs:1760:12
[INFO] [stderr]      |
[INFO] [stderr] 1704 | impl MoveData {
[INFO] [stderr]      | ------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 1760 |     pub fn is_check(&self) -> bool {
[INFO] [stderr]      |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1771 |     pub fn is_checkmate(&self) -> bool {
[INFO] [stderr]      |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1782 |     pub fn is_stalemate(&self) -> bool {
[INFO] [stderr]      |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1810 |     pub fn is_en_passant(&self) -> bool {
[INFO] [stderr]      |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ChessClock` is never constructed
[INFO] [stderr]  --> src/clock.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct ChessClock{
[INFO] [stderr]   |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/clock.rs:16:8
[INFO] [stderr]    |
[INFO] [stderr] 15 | impl ChessClock{
[INFO] [stderr]    | --------------- associated function in this implementation
[INFO] [stderr] 16 |     fn new() -> Self{
[INFO] [stderr]    |        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Network`, `Game`, `Terminal`, `GUI`, and `Other` are never constructed
[INFO] [stderr]   --> src/common.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub enum ThreadIdentifier {
[INFO] [stderr]    |          ---------------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 17 |     Network(ThreadIdHash),
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] 18 |     Game(ThreadIdHash),
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 19 |     UI(ThreadIdHash),
[INFO] [stderr] 20 |     Terminal(ThreadIdHash),
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 21 |     GUI(ThreadIdHash),
[INFO] [stderr]    |     ^^^
[INFO] [stderr] 22 |     Other(ThreadIdHash, &'static str),
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ThreadIdentifier` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: enum `PlayerType` is never used
[INFO] [stderr]   --> src/game.rs:42:10
[INFO] [stderr]    |
[INFO] [stderr] 42 | pub enum PlayerType{
[INFO] [stderr]    |          ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `GameMetadata` is never constructed
[INFO] [stderr]   --> src/game.rs:55:12
[INFO] [stderr]    |
[INFO] [stderr] 55 | pub struct GameMetadata {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Game` is never constructed
[INFO] [stderr]   --> src/game.rs:62:12
[INFO] [stderr]    |
[INFO] [stderr] 62 | pub struct Game{
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `FullMoveNumber` is never used
[INFO] [stderr]   --> src/game.rs:70:10
[INFO] [stderr]    |
[INFO] [stderr] 70 | pub type FullMoveNumber = rules::FullMoveNumber;
[INFO] [stderr]    |          ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `GameThread` is never constructed
[INFO] [stderr]   --> src/game.rs:72:12
[INFO] [stderr]    |
[INFO] [stderr] 72 | pub struct GameThread{
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `GameMessage` is never used
[INFO] [stderr]   --> src/game.rs:82:10
[INFO] [stderr]    |
[INFO] [stderr] 82 | pub enum GameMessage {
[INFO] [stderr]    |          ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `GameResponse` is never used
[INFO] [stderr]   --> src/game.rs:89:10
[INFO] [stderr]    |
[INFO] [stderr] 89 | pub enum GameResponse {
[INFO] [stderr]    |          ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `GameController` is never used
[INFO] [stderr]   --> src/game.rs:96:10
[INFO] [stderr]    |
[INFO] [stderr] 96 | pub enum GameController {
[INFO] [stderr]    |          ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `new_with_time_controls`, and `start_game` are never used
[INFO] [stderr]    --> src/game.rs:103:12
[INFO] [stderr]     |
[INFO] [stderr] 102 | impl Game{
[INFO] [stderr]     | --------- associated items in this implementation
[INFO] [stderr] 103 |     pub fn new(white: PlayerType, black: PlayerType) -> Game {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 112 |     pub fn new_with_time_controls(white: PlayerType, black: PlayerType, time_controls: TimeControls) -> Option<Game> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 125 |     fn start_game(&mut self) {
[INFO] [stderr]     |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `start`, and `run` are never used
[INFO] [stderr]    --> src/game.rs:142:12
[INFO] [stderr]     |
[INFO] [stderr] 135 | impl GameThread {
[INFO] [stderr]     | --------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 142 |     pub fn new(game: Game) -> (GameThread, Sender<GameController>) {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 172 |     pub fn start(mut self) -> Self {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 179 |     fn run(&mut self) {
[INFO] [stderr]     |        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PlayerHandler` is never constructed
[INFO] [stderr]  --> src/handler.rs:7:12
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub struct PlayerHandler{
[INFO] [stderr]   |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/handler.rs:13:13
[INFO] [stderr]    |
[INFO] [stderr] 12 |  impl PlayerHandler{
[INFO] [stderr]    |  ------------------ associated function in this implementation
[INFO] [stderr] 13 |      pub fn new(player_type: PlayerType, player_sender: mpsc::Sender<GameMessage>, player_receiver: mpsc::Receiver<GameResponse>) -> Self {
[INFO] [stderr]    |             ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `SetOutput`, `SetPrintTimestamp`, `SetTimestampDisplay`, `SetPrintThreadIdentifier`, `SetPrintLevel`, and `SetPrintMessage` are never constructed
[INFO] [stderr]   --> src/log.rs:39:5
[INFO] [stderr]    |
[INFO] [stderr] 37 | pub enum LogInstruction {
[INFO] [stderr]    |          -------------- variants in this enum
[INFO] [stderr] 38 |     SetLevel(LogLevel),
[INFO] [stderr] 39 |     SetOutput(LogOutput),
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 40 |     SetPrintTimestamp(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 41 |     SetTimestampDisplay(time_format::DisplayMode),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 42 |     SetPrintThreadIdentifier(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 43 |     SetPrintLevel(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 44 |     SetPrintMessage(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_id_channel_in_and_out` is never used
[INFO] [stderr]    --> src/log.rs:108:12
[INFO] [stderr]     |
[INFO] [stderr]  77 | impl LogThread {
[INFO] [stderr]     | -------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 108 |     pub fn from_id_channel_in_and_out( parent_thread: ThreadIdentifier, channel_in: Receiver<LogMessage>, out: LogOutput, ) -> (LogThread...
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `PIECE_MAP` is never used
[INFO] [stderr]  --> src/move_parser.rs:7:11
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub const PIECE_MAP: &[(&str, char)] = &[
[INFO] [stderr]   |           ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/move_parser.rs:45:19
[INFO] [stderr]    |
[INFO] [stderr] 45 |     InvalidSquare(Square),
[INFO] [stderr]    |     ------------- ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 45 -     InvalidSquare(Square),
[INFO] [stderr] 45 +     InvalidSquare(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/move_parser.rs:49:29
[INFO] [stderr]    |
[INFO] [stderr] 49 |     AlgebraicParseModeError(AlgebraicParseStage),
[INFO] [stderr]    |     ----------------------- ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 49 -     AlgebraicParseModeError(AlgebraicParseStage),
[INFO] [stderr] 49 +     AlgebraicParseModeError(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/move_parser.rs:51:22
[INFO] [stderr]    |
[INFO] [stderr] 51 |     IllegalMoveError(MoveError),
[INFO] [stderr]    |     ---------------- ^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 51 -     IllegalMoveError(MoveError),
[INFO] [stderr] 51 +     IllegalMoveError(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/move_parser.rs:53:25
[INFO] [stderr]    |
[INFO] [stderr] 53 |     MalformedExpression(Token),
[INFO] [stderr]    |     ------------------- ^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 53 -     MalformedExpression(Token),
[INFO] [stderr] 53 +     MalformedExpression(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: variants `DisambiguousMoveError` and `Todo` are never constructed
[INFO] [stderr]   --> src/move_parser.rs:50:5
[INFO] [stderr]    |
[INFO] [stderr] 39 | pub enum ParseError{
[INFO] [stderr]    |          ---------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 50 |     DisambiguousMoveError(Disambiguity),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 54 |     Todo,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Piece` is never constructed
[INFO] [stderr]    --> src/move_parser.rs:141:5
[INFO] [stderr]     |
[INFO] [stderr] 140 | pub enum AlgebraicParseStage{
[INFO] [stderr]     |          ------------------- variant in this enum
[INFO] [stderr] 141 |     Piece,
[INFO] [stderr]     |     ^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `AlgebraicParseStage` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: enum `PlayerClient` is never used
[INFO] [stderr]  --> src/player_agent.rs:3:10
[INFO] [stderr]   |
[INFO] [stderr] 3 | pub enum PlayerClient {
[INFO] [stderr]   |          ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `PlayerController` is never used
[INFO] [stderr]  --> src/player_agent.rs:7:11
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub trait PlayerController {
[INFO] [stderr]   |           ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `Player` is never used
[INFO] [stderr]  --> src/player_agent/player_actor.rs:5:11
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub trait Player {
[INFO] [stderr]   |           ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `FullMoveNumber` is never used
[INFO] [stderr]   --> src/rules.rs:19:10
[INFO] [stderr]    |
[INFO] [stderr] 19 | pub type FullMoveNumber = u8;
[INFO] [stderr]    |          ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `GameState` is never used
[INFO] [stderr]   --> src/rules.rs:22:10
[INFO] [stderr]    |
[INFO] [stderr] 22 | pub enum GameState {
[INFO] [stderr]    |          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `TimeControls` is never constructed
[INFO] [stderr]    --> src/rules.rs:102:12
[INFO] [stderr]     |
[INFO] [stderr] 102 | pub struct TimeControls {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `Timer` is never used
[INFO] [stderr]    --> src/rules.rs:116:11
[INFO] [stderr]     |
[INFO] [stderr] 116 | pub trait Timer {
[INFO] [stderr]     |           ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Simple` and `Debug` are never constructed
[INFO] [stderr]   --> src/time.rs:64:9
[INFO] [stderr]    |
[INFO] [stderr] 62 |     pub enum DisplayMode {
[INFO] [stderr]    |              ----------- variants in this enum
[INFO] [stderr] 63 |         ISO8601,
[INFO] [stderr] 64 |         Simple,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 65 |         Debug,
[INFO] [stderr]    |         ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `DisplayMode` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `CurrentBackend` is never used
[INFO] [stderr]   --> src/ui.rs:16:6
[INFO] [stderr]    |
[INFO] [stderr] 16 | type CurrentBackend = backend_x11::X11Backend;
[INFO] [stderr]    |      ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Web` is never constructed
[INFO] [stderr]   --> src/ui.rs:23:5
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub enum UIType {
[INFO] [stderr]    |          ------ variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 23 |     Web,
[INFO] [stderr]    |     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Game` is never constructed
[INFO] [stderr]   --> src/ui.rs:28:5
[INFO] [stderr]    |
[INFO] [stderr] 26 | pub enum UIState {
[INFO] [stderr]    |          ------- variant in this enum
[INFO] [stderr] 27 |     Menu,
[INFO] [stderr] 28 |     Game,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `UserInput` is never used
[INFO] [stderr]   --> src/ui.rs:31:10
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub enum UserInput {
[INFO] [stderr]    |          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `ui_state` and `log_channel` are never read
[INFO] [stderr]   --> src/ui.rs:39:5
[INFO] [stderr]    |
[INFO] [stderr] 36 | pub struct UIManager {
[INFO] [stderr]    |            --------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 39 |     ui_state: UIState,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 40 |     log_channel: Option<mpsc::Sender<LogMessage>>,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `GraphicsBackend` is never used
[INFO] [stderr]   --> src/ui.rs:43:7
[INFO] [stderr]    |
[INFO] [stderr] 43 | trait GraphicsBackend {
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `UiUpdate` is never used
[INFO] [stderr]   --> src/ui.rs:50:10
[INFO] [stderr]    |
[INFO] [stderr] 50 | pub enum UiUpdate {
[INFO] [stderr]    |          ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `UiMessage` is never used
[INFO] [stderr]   --> src/ui.rs:55:10
[INFO] [stderr]    |
[INFO] [stderr] 55 | pub enum UiMessage {
[INFO] [stderr]    |          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `WIN32Backend` is never constructed
[INFO] [stderr]  --> src/ui/backend_win32.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct WIN32Backend {
[INFO] [stderr]   |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `X11Backend` is never constructed
[INFO] [stderr]  --> src/ui/backend_x11.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct X11Backend {
[INFO] [stderr]   |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: comparison is useless due to type limits
[INFO] [stderr]   --> src/clock.rs:34:12
[INFO] [stderr]    |
[INFO] [stderr] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: comparison is useless due to type limits
[INFO] [stderr]   --> src/clock.rs:34:40
[INFO] [stderr]    |
[INFO] [stderr] 34 |         if white_time.as_secs() < 0 || black_time.as_secs() < 0 {
[INFO] [stderr]    |                                        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `rusty_chess` (bin "rusty_chess" test) generated 79 warnings (run `cargo fix --bin "rusty_chess" --tests` to apply 7 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.03s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/rusty_chess-ba224892fa26a3fe)
[INFO] [stdout] test config::tests::parse_line_sets_log_mode_terminal ... ok
[INFO] [stdout] test config::tests::parse_line_test_false_returns_error ... ok
[INFO] [stdout] test config::tests::update_result_accumulates_errors ... ok
[INFO] [stdout] test config::tests::parse_line_sets_log_file_path ... ok
[INFO] [stdout] test move_parser::tests::test_chess_move_illegal_rook_jump ... ok
[INFO] [stdout] test move_parser::tests::test_chess_move_disambiguate ... ok
[INFO] [stdout] test config::tests::parse_line_sets_terminal_true ... ok
[INFO] [stdout] test move_parser::tests::test_chess_move_knight_opening ... ok
[INFO] [stdout] test move_parser::tests::test_chess_move_pawn_two_step ... ok
[INFO] [stdout] test move_parser::tests::test_lan_missing_origin ... ok
[INFO] [stdout] test move_parser::tests::test_lan_basic_move ... ok
[INFO] [stdout] test move_parser::tests::test_lan_promotion ... ok
[INFO] [stdout] test move_parser::tests::test_mixed_tokens ... ok
[INFO] [stdout] test move_parser::tests::test_promotion_pre_processing ... ok
[INFO] [stdout] test move_parser::tests::test_proto_missing_target_square ... ok
[INFO] [stdout] test move_parser::tests::test_san_capture_with_check ... ok
[INFO] [stdout] test move_parser::tests::test_san_disambiguation_by_file ... ok
[INFO] [stdout] test move_parser::tests::test_san_invalid_token ... ok
[INFO] [stdout] test move_parser::tests::test_san_kingside_castle ... ok
[INFO] [stdout] test move_parser::tests::test_square_pre_processing ... ok
[INFO] [stdout] test move_parser::tests::test_san_promotion ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_capture_and_check ... ok
[INFO] [stdout] test move_parser::tests::test_san_simple_knight_move ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_kingside_castling_zero ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_kingside_castling_o ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_piece ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_promotion ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_queenside_castling_zero ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_queenside_castling_o ... ok
[INFO] [stdout] test move_parser::tests::test_unrecognized_char ... ok
[INFO] [stdout] test move_parser::tests::test_tokenize_file_and_rank ... ok
[INFO] [stdout] test config::tests::parse_config_invalid_utf8 ... FAILED
[INFO] [stdout] test config::tests::parse_config_no_file ... FAILED
[INFO] [stdout] test config::tests::parse_config_valid_file ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- config::tests::parse_config_invalid_utf8 stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'config::tests::parse_config_invalid_utf8' panicked at src/config.rs:232:50:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x58d545f88d62 - std::backtrace_rs::backtrace::libunwind::trace::h2d45396358f41939
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x58d545f88d62 - std::backtrace_rs::backtrace::trace_unsynchronized::hffcefc0b67f1d6e2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x58d545f88d62 - std::sys::backtrace::_print_fmt::hd72f71d23b436b92
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x58d545f88d62 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::hdcfcb6d4c8489523
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x58d545faec13 - core::fmt::rt::Argument::fmt::h2c56b3114963061a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x58d545faec13 - core::fmt::write::h8a494366950f23bb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x58d545f85c33 - std::io::default_write_fmt::h7b8824096454f323
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x58d545f85c33 - std::io::Write::write_fmt::h4e71294925c334d0
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x58d545f88bb2 - std::sys::backtrace::BacktraceLock::print::hb2a626a81e06b2dc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x58d545f8a929 - std::panicking::default_hook::{{closure}}::h4f78485264f12d10
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x58d545f8a75e - std::panicking::default_hook::h2c66fc99e962531d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x58d545f525e4 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hb6bd65493727d71a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x58d545f525e4 - test::test_main_with_exit_callback::{{closure}}::h60217ec76a0ece4a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x58d545f8b2fe - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h318e4efb8c1a5689
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x58d545f8b2fe - std::panicking::rust_panic_with_hook::h33ac55f64bbd807d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x58d545f8b0ca - std::panicking::begin_panic_handler::{{closure}}::h30e7cb89678a57fe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:706:13
[INFO] [stdout]   16:     0x58d545f89259 - std::sys::backtrace::__rust_end_short_backtrace::hed60f27456c16ced
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x58d545f8ad5d - __rustc[de2ca18b4c54d5b8]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x58d545fad690 - core::panicking::panic_fmt::h62f63d096dd276af
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x58d545fadac6 - core::result::unwrap_failed::h95bc3f5a607b2c95
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/result.rs:1765:5
[INFO] [stdout]   20:     0x58d545ef6911 - core::result::Result<T,E>::unwrap::h0fb247491274b588
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/result.rs:1167:23
[INFO] [stdout]   21:     0x58d545ef6911 - rusty_chess::config::tests::parse_config_invalid_utf8::h7e8fe98bbb54af36
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:232:50
[INFO] [stdout]   22:     0x58d545ef6897 - rusty_chess::config::tests::parse_config_invalid_utf8::{{closure}}::hc0e50fb743316771
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:230:35
[INFO] [stdout]   23:     0x58d545f072e6 - core::ops::function::FnOnce::call_once::hfa8370919315b8a3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   24:     0x58d545f57e4b - core::ops::function::FnOnce::call_once::h1f9474f1347fff52
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   25:     0x58d545f57e4b - test::__rust_begin_short_backtrace::ha52ab26e77157f03
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:648:18
[INFO] [stdout]   26:     0x58d545f56f85 - test::run_test_in_process::{{closure}}::h229c1a11a50b261f
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:74
[INFO] [stdout]   27:     0x58d545f56f85 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h78821afbf97b39a9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   28:     0x58d545f56f85 - std::panicking::catch_unwind::do_call::h53abf3ed5bd32ba3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   29:     0x58d545f56f85 - std::panicking::catch_unwind::h6deb5fe1e91873c9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   30:     0x58d545f56f85 - std::panic::catch_unwind::hea0829b6b565654b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x58d545f56f85 - test::run_test_in_process::hdc44dfecea3db21b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:27
[INFO] [stdout]   32:     0x58d545f56f85 - test::run_test::{{closure}}::h0364ba59bf23f652
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:592:43
[INFO] [stdout]   33:     0x58d545f1ab84 - test::run_test::{{closure}}::h32730b304eec05da
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:622:41
[INFO] [stdout]   34:     0x58d545f1ab84 - std::sys::backtrace::__rust_begin_short_backtrace::h177cb952fc54ad2c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   35:     0x58d545f1e55a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h119d903520007597
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   36:     0x58d545f1e55a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hab88401d606702a6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   37:     0x58d545f1e55a - std::panicking::catch_unwind::do_call::h163fe12cca9901c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   38:     0x58d545f1e55a - std::panicking::catch_unwind::he81557d0e17cc1bc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   39:     0x58d545f1e55a - std::panic::catch_unwind::hc2b8e79c20593955
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x58d545f1e55a - std::thread::Builder::spawn_unchecked_::{{closure}}::hfa6b4978e07815cc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   41:     0x58d545f1e55a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hddcd7484a13fd793
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   42:     0x58d545f8e74f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h5924238c754de3b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   43:     0x58d545f8e74f - std::sys::pal::unix::thread::Thread::new::thread_start::hb6e99e73da4d28f8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/pal/unix/thread.rs:107:17
[INFO] [stdout]   44:     0x770af0226aa4 - <unknown>
[INFO] [stdout]   45:     0x770af02b3a34 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- config::tests::parse_config_no_file stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'config::tests::parse_config_no_file' panicked at src/config.rs:223:38:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x58d545f88d62 - std::backtrace_rs::backtrace::libunwind::trace::h2d45396358f41939
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x58d545f88d62 - std::backtrace_rs::backtrace::trace_unsynchronized::hffcefc0b67f1d6e2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x58d545f88d62 - std::sys::backtrace::_print_fmt::hd72f71d23b436b92
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x58d545f88d62 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::hdcfcb6d4c8489523
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x58d545faec13 - core::fmt::rt::Argument::fmt::h2c56b3114963061a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x58d545faec13 - core::fmt::write::h8a494366950f23bb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x58d545f85c33 - std::io::default_write_fmt::h7b8824096454f323
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x58d545f85c33 - std::io::Write::write_fmt::h4e71294925c334d0
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x58d545f88bb2 - std::sys::backtrace::BacktraceLock::print::hb2a626a81e06b2dc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x58d545f8a929 - std::panicking::default_hook::{{closure}}::h4f78485264f12d10
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x58d545f8a75e - std::panicking::default_hook::h2c66fc99e962531d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x58d545f525e4 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hb6bd65493727d71a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x58d545f525e4 - test::test_main_with_exit_callback::{{closure}}::h60217ec76a0ece4a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x58d545f8b2fe - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h318e4efb8c1a5689
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x58d545f8b2fe - std::panicking::rust_panic_with_hook::h33ac55f64bbd807d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x58d545f8b0ca - std::panicking::begin_panic_handler::{{closure}}::h30e7cb89678a57fe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:706:13
[INFO] [stdout]   16:     0x58d545f89259 - std::sys::backtrace::__rust_end_short_backtrace::hed60f27456c16ced
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x58d545f8ad5d - __rustc[de2ca18b4c54d5b8]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x58d545fad690 - core::panicking::panic_fmt::h62f63d096dd276af
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x58d545fadac6 - core::result::unwrap_failed::h95bc3f5a607b2c95
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/result.rs:1765:5
[INFO] [stdout]   20:     0x58d545ef67f3 - core::result::Result<T,E>::unwrap::hd3819143b98907b7
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/result.rs:1167:23
[INFO] [stdout]   21:     0x58d545ef67f3 - rusty_chess::config::tests::parse_config_no_file::h1298250a0fb83bfa
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:223:38
[INFO] [stdout]   22:     0x58d545ef6717 - rusty_chess::config::tests::parse_config_no_file::{{closure}}::h68d4d0ee1938e339
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:221:30
[INFO] [stdout]   23:     0x58d545f06f16 - core::ops::function::FnOnce::call_once::hb64ad804a6514521
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   24:     0x58d545f57e4b - core::ops::function::FnOnce::call_once::h1f9474f1347fff52
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   25:     0x58d545f57e4b - test::__rust_begin_short_backtrace::ha52ab26e77157f03
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:648:18
[INFO] [stdout]   26:     0x58d545f56f85 - test::run_test_in_process::{{closure}}::h229c1a11a50b261f
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:74
[INFO] [stdout]   27:     0x58d545f56f85 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h78821afbf97b39a9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   28:     0x58d545f56f85 - std::panicking::catch_unwind::do_call::h53abf3ed5bd32ba3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   29:     0x58d545f56f85 - std::panicking::catch_unwind::h6deb5fe1e91873c9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   30:     0x58d545f56f85 - std::panic::catch_unwind::hea0829b6b565654b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x58d545f56f85 - test::run_test_in_process::hdc44dfecea3db21b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:27
[INFO] [stdout]   32:     0x58d545f56f85 - test::run_test::{{closure}}::h0364ba59bf23f652
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:592:43
[INFO] [stdout]   33:     0x58d545f1ab84 - test::run_test::{{closure}}::h32730b304eec05da
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:622:41
[INFO] [stdout]   34:     0x58d545f1ab84 - std::sys::backtrace::__rust_begin_short_backtrace::h177cb952fc54ad2c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   35:     0x58d545f1e55a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h119d903520007597
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   36:     0x58d545f1e55a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hab88401d606702a6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   37:     0x58d545f1e55a - std::panicking::catch_unwind::do_call::h163fe12cca9901c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   38:     0x58d545f1e55a - std::panicking::catch_unwind::he81557d0e17cc1bc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   39:     0x58d545f1e55a - std::panic::catch_unwind::hc2b8e79c20593955
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x58d545f1e55a - std::thread::Builder::spawn_unchecked_::{{closure}}::hfa6b4978e07815cc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   41:     0x58d545f1e55a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hddcd7484a13fd793
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   42:     0x58d545f8e74f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h5924238c754de3b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   43:     0x58d545f8e74f - std::sys::pal::unix::thread::Thread::new::thread_start::hb6e99e73da4d28f8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/pal/unix/thread.rs:107:17
[INFO] [stdout]   44:     0x770af0226aa4 - <unknown>
[INFO] [stdout]   45:     0x770af02b3a34 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- config::tests::parse_config_valid_file stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'config::tests::parse_config_valid_file' panicked at src/config.rs:177:44:
[INFO] [stdout] Failed to create temp file: Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x58d545f88d62 - std::backtrace_rs::backtrace::libunwind::trace::h2d45396358f41939
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x58d545f88d62 - std::backtrace_rs::backtrace::trace_unsynchronized::hffcefc0b67f1d6e2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x58d545f88d62 - std::sys::backtrace::_print_fmt::hd72f71d23b436b92
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x58d545f88d62 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::hdcfcb6d4c8489523
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x58d545faec13 - core::fmt::rt::Argument::fmt::h2c56b3114963061a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x58d545faec13 - core::fmt::write::h8a494366950f23bb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x58d545f85c33 - std::io::default_write_fmt::h7b8824096454f323
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x58d545f85c33 - std::io::Write::write_fmt::h4e71294925c334d0
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x58d545f88bb2 - std::sys::backtrace::BacktraceLock::print::hb2a626a81e06b2dc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x58d545f8a929 - std::panicking::default_hook::{{closure}}::h4f78485264f12d10
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x58d545f8a75e - std::panicking::default_hook::h2c66fc99e962531d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x58d545f525e4 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hb6bd65493727d71a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x58d545f525e4 - test::test_main_with_exit_callback::{{closure}}::h60217ec76a0ece4a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x58d545f8b2fe - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h318e4efb8c1a5689
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x58d545f8b2fe - std::panicking::rust_panic_with_hook::h33ac55f64bbd807d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x58d545f8b0ca - std::panicking::begin_panic_handler::{{closure}}::h30e7cb89678a57fe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:706:13
[INFO] [stdout]   16:     0x58d545f89259 - std::sys::backtrace::__rust_end_short_backtrace::hed60f27456c16ced
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x58d545f8ad5d - __rustc[de2ca18b4c54d5b8]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x58d545fad690 - core::panicking::panic_fmt::h62f63d096dd276af
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x58d545fadac6 - core::result::unwrap_failed::h95bc3f5a607b2c95
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/result.rs:1765:5
[INFO] [stdout]   20:     0x58d545ef967e - core::result::Result<T,E>::expect::h2d262d1a35f2bafd
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/result.rs:1119:23
[INFO] [stdout]   21:     0x58d545ef5e2b - rusty_chess::config::tests::temp_file::haab96dab3237578c
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:177:44
[INFO] [stdout]   22:     0x58d545ef6c3f - rusty_chess::config::tests::parse_config_valid_file::h78eb017fab736200
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:243:20
[INFO] [stdout]   23:     0x58d545ef6bf7 - rusty_chess::config::tests::parse_config_valid_file::{{closure}}::hc68c015b1daa4c4c
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:242:33
[INFO] [stdout]   24:     0x58d545f07256 - core::ops::function::FnOnce::call_once::hefb96126beaab2b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   25:     0x58d545f57e4b - core::ops::function::FnOnce::call_once::h1f9474f1347fff52
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   26:     0x58d545f57e4b - test::__rust_begin_short_backtrace::ha52ab26e77157f03
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:648:18
[INFO] [stdout]   27:     0x58d545f56f85 - test::run_test_in_process::{{closure}}::h229c1a11a50b261f
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:74
[INFO] [stdout]   28:     0x58d545f56f85 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h78821afbf97b39a9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   29:     0x58d545f56f85 - std::panicking::catch_unwind::do_call::h53abf3ed5bd32ba3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   30:     0x58d545f56f85 - std::panicking::catch_unwind::h6deb5fe1e91873c9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   31:     0x58d545f56f85 - std::panic::catch_unwind::hea0829b6b565654b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   32:     0x58d545f56f85 - test::run_test_in_process::hdc44dfecea3db21b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:27
[INFO] [stdout]   33:     0x58d545f56f85 - test::run_test::{{closure}}::h0364ba59bf23f652
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:592:43
[INFO] [stdout]   34:     0x58d545f1ab84 - test::run_test::{{closure}}::h32730b304eec05da
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:622:41
[INFO] [stdout]   35:     0x58d545f1ab84 - std::sys::backtrace::__rust_begin_short_backtrace::h177cb952fc54ad2c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   36:     0x58d545f1e55a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h119d903520007597
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   37:     0x58d545f1e55a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hab88401d606702a6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   38:     0x58d545f1e55a - std::panicking::catch_unwind::do_call::h163fe12cca9901c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   39:     0x58d545f1e55a - std::panicking::catch_unwind::he81557d0e17cc1bc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   40:     0x58d545f1e55a - std::panic::catch_unwind::hc2b8e79c20593955
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   41:     0x58d545f1e55a - std::thread::Builder::spawn_unchecked_::{{closure}}::hfa6b4978e07815cc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   42:     0x58d545f1e55a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hddcd7484a13fd793
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   43:     0x58d545f8e74f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h5924238c754de3b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   44:     0x58d545f8e74f - std::sys::pal::unix::thread::Thread::new::thread_start::hb6e99e73da4d28f8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/pal/unix/thread.rs:107:17
[INFO] [stdout]   45:     0x770af0226aa4 - <unknown>
[INFO] [stdout]   46:     0x770af02b3a34 - clone
[INFO] [stdout]   47:                0x0 - <unknown>
[INFO] [stderr] error: test failed, to rerun pass `--bin rusty_chess`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     config::tests::parse_config_invalid_utf8
[INFO] [stdout]     config::tests::parse_config_no_file
[INFO] [stdout]     config::tests::parse_config_valid_file
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 31 passed; 3 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "cac07d55e96db70f8cdbf3c56c607352a0b6e4aa054480d551e6dfab6e3db42f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cac07d55e96db70f8cdbf3c56c607352a0b6e4aa054480d551e6dfab6e3db42f", kill_on_drop: false }`
[INFO] [stdout] cac07d55e96db70f8cdbf3c56c607352a0b6e4aa054480d551e6dfab6e3db42f
