[INFO] fetching crate alcibiades 0.3.0...
[INFO] testing alcibiades-0.3.0 against master#1871252fc8bb672d40787e67404e6eaae7059369 for pr-125151
[INFO] extracting crate alcibiades 0.3.0 into /workspace/builds/worker-4-tc1/source
[INFO] validating manifest of crates.io crate alcibiades 0.3.0 on toolchain 1871252fc8bb672d40787e67404e6eaae7059369
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1871252fc8bb672d40787e67404e6eaae7059369" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate alcibiades 0.3.0
[INFO] finished tweaking crates.io crate alcibiades 0.3.0
[INFO] tweaked toml for crates.io crate alcibiades 0.3.0 written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1871252fc8bb672d40787e67404e6eaae7059369" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 20 packages to latest compatible versions
[INFO] [stderr]       Adding aho-corasick v0.6.10 (latest: v1.1.3)
[INFO] [stderr]       Adding lazy_static v0.2.11 (latest: v1.4.0)
[INFO] [stderr]       Adding rand v0.3.23 (latest: v0.8.5)
[INFO] [stderr]       Adding rand v0.4.6 (latest: v0.8.5)
[INFO] [stderr]       Adding rand_core v0.3.1 (latest: v0.6.4)
[INFO] [stderr]       Adding rand_core v0.4.2 (latest: v0.6.4)
[INFO] [stderr]       Adding rdrand v0.4.0 (latest: v0.8.3)
[INFO] [stderr]       Adding regex v0.2.11 (latest: v1.10.4)
[INFO] [stderr]       Adding regex-syntax v0.5.6 (latest: v0.8.3)
[INFO] [stderr]       Adding thread_local v0.3.6 (latest: v1.1.8)
[INFO] [stderr]       Adding ucd-util v0.1.10 (latest: v0.2.1)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1871252fc8bb672d40787e67404e6eaae7059369" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded utf8-ranges v1.0.5
[INFO] [stderr]   Downloaded ucd-util v0.1.10
[INFO] [stderr]   Downloaded regex-syntax v0.5.6
[INFO] [stderr]   Downloaded regex v0.2.11
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:59a85a07ab18ca8720692f8e61effa1c651d9e2ca591e072c2b212bb91a6b8b5" "/opt/rustwide/cargo-home/bin/cargo" "+1871252fc8bb672d40787e67404e6eaae7059369" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 3876d1c72b25346f26d787aa2a636a8b93366d38aa1b1dd23d4fc5d4e1f9810e
[INFO] running `Command { std: "docker" "start" "-a" "3876d1c72b25346f26d787aa2a636a8b93366d38aa1b1dd23d4fc5d4e1f9810e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "3876d1c72b25346f26d787aa2a636a8b93366d38aa1b1dd23d4fc5d4e1f9810e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3876d1c72b25346f26d787aa2a636a8b93366d38aa1b1dd23d4fc5d4e1f9810e", kill_on_drop: false }`
[INFO] [stdout] 3876d1c72b25346f26d787aa2a636a8b93366d38aa1b1dd23d4fc5d4e1f9810e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:59a85a07ab18ca8720692f8e61effa1c651d9e2ca591e072c2b212bb91a6b8b5" "/opt/rustwide/cargo-home/bin/cargo" "+1871252fc8bb672d40787e67404e6eaae7059369" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c97575f60538e54ca5d5a5fcefdb108431bc3199ce0467b59facc391001ee4d4
[INFO] running `Command { std: "docker" "start" "-a" "c97575f60538e54ca5d5a5fcefdb108431bc3199ce0467b59facc391001ee4d4", kill_on_drop: false }`
[INFO] [stderr]    Compiling ucd-util v0.1.10
[INFO] [stderr]    Compiling memchr v2.7.2
[INFO] [stderr]    Compiling regex v0.2.11
[INFO] [stderr]    Compiling utf8-ranges v1.0.5
[INFO] [stderr]    Compiling lazy_static v0.2.11
[INFO] [stderr]    Compiling thread_local v0.3.6
[INFO] [stderr]    Compiling rand v0.3.23
[INFO] [stderr]    Compiling regex-syntax v0.5.6
[INFO] [stderr]    Compiling aho-corasick v0.6.10
[INFO] [stderr]    Compiling alcibiades v0.3.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:55:22
[INFO] [stdout]    |
[INFO] [stdout] 55 |         let pieces = try!(parse_fen_piece_placement(fileds[0]));
[INFO] [stdout]    |                      ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:56:23
[INFO] [stdout]    |
[INFO] [stdout] 56 |         let to_move = try!(parse_fen_active_color(fileds[1]));
[INFO] [stdout]    |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:57:31
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let castling_rights = try!(parse_fen_castling_rights(fileds[2]));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:58:47
[INFO] [stdout]    |
[INFO] [stdout] 58 |         let enpassant_file = if let Some(x) = try!(parse_fen_enpassant_square(fileds[3])) {
[INFO] [stdout]    |                                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:67:30
[INFO] [stdout]    |
[INFO] [stdout] 67 |         let halfmove_clock = try!(fileds[4].parse::<u8>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:68:31
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let fullmove_number = try!(fileds[5].parse::<u16>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]   --> src/utils/notation.rs:69:17
[INFO] [stdout]    |
[INFO] [stdout] 69 |         if let 1...9000 = fullmove_number {
[INFO] [stdout]    |                 ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/utils/notation.rs:134:20
[INFO] [stdout]     |
[INFO] [stdout] 134 |             n @ '1'...'8' => Token::EmptySquares(n.to_digit(9).unwrap()),
[INFO] [stdout]     |                    ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/stock/std_ttable.rs:213:31
[INFO] [stdout]     |
[INFO] [stdout] 213 |                          n @ 1...30 => n + 1,
[INFO] [stdout]     |                               ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:226:26
[INFO] [stdout]     |
[INFO] [stdout] 226 |         if let Some(v) = try!(self.node_begin(alpha, beta, depth, last_move)) {
[INFO] [stdout]     |                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:238:17
[INFO] [stdout]     |
[INFO] [stdout] 238 |                 try!(self.report_progress(1));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:246:22
[INFO] [stdout]     |
[INFO] [stdout] 246 |                     -try!(self.run(-beta, -alpha, depth - 1, m))
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:255:28
[INFO] [stdout]     |
[INFO] [stdout] 255 |                     match -try!(self.run(-alpha - 1, -alpha, depth - 2, m)) {
[INFO] [stdout]     |                            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:257:31
[INFO] [stdout]     |
[INFO] [stdout] 257 |                         _ => -try!(self.run(-beta, -alpha, depth - 1, m)),
[INFO] [stdout]     |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:373:13
[INFO] [stdout]     |
[INFO] [stdout] 373 |             try!(self.report_progress(result.searched_nodes()));
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:425:30
[INFO] [stdout]     |
[INFO] [stdout] 425 |                 let value = -try!(self.run(-beta, -alpha, max(0, reduced_depth - 1), m));
[INFO] [stdout]     |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/stock/std_search_node.rs:70:39
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut p: StdSearchNode<T> = try!(StdSearchNode::from_fen(fen));
[INFO] [stdout]    |                                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:317:56
[INFO] [stdout]     |
[INFO] [stdout] 317 |         let (board, halfmove_clock, fullmove_number) = try!(parse_fen(fen));
[INFO] [stdout]     |                                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:318:19
[INFO] [stdout]     |
[INFO] [stdout] 318 |         let gen = try!(T::MoveGenerator::from_board(board));
[INFO] [stdout]     |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/aspiration.rs:107:13
[INFO] [stdout]     |
[INFO] [stdout] 107 |         } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/multipv.rs:118:17
[INFO] [stdout]     |
[INFO] [stdout] 118 |             } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/mod.rs:125:13
[INFO] [stdout]     |
[INFO] [stdout] 125 |         } = try!(self.multipv.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:150:27
[INFO] [stdout]     |
[INFO] [stdout] 150 |         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 150 -         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout] 150 +         const WQ: usize = 1 << (WHITE << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:151:27
[INFO] [stdout]     |
[INFO] [stdout] 151 |         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 151 -         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout] 151 +         const WK: usize = 1 << (WHITE << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:153:27
[INFO] [stdout]     |
[INFO] [stdout] 153 |         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 153 -         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout] 153 +         const BQ: usize = 1 << (BLACK << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:154:27
[INFO] [stdout]     |
[INFO] [stdout] 154 |         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout] 154 +         const BK: usize = 1 << (BLACK << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/board.rs:189:17
[INFO] [stdout]     |
[INFO] [stdout] 189 |                 try!(f.write_str(s));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:280:22
[INFO] [stdout]     |
[INFO] [stdout] 280 |     let mut server = try!(Server::<E>::wait_for_hanshake());
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:313:9
[INFO] [stdout]     |
[INFO] [stdout] 313 |         try!(write!(writer, "id name {}\n", E::name()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:314:9
[INFO] [stdout]     |
[INFO] [stdout] 314 |         try!(write!(writer, "id author {}\n", E::author()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:342:9
[INFO] [stdout]     |
[INFO] [stdout] 342 |         try!(write!(writer, "uciok\n"));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:343:9
[INFO] [stdout]     |
[INFO] [stdout] 343 |         try!(writer.flush());
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:307:12
[INFO] [stdout]     |
[INFO] [stdout] 307 |         if try!(reader.read_line(&mut line)) == 0 {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:316:13
[INFO] [stdout]     |
[INFO] [stdout] 316 |             try!(write!(writer,
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:361:40
[INFO] [stdout]     |
[INFO] [stdout] 361 |                 if let Ok(cmd) = match try!(reader.read_line(&mut line)) {
[INFO] [stdout]     |                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:405:25
[INFO] [stdout]     |
[INFO] [stdout] 405 |                         try!(write!(writer, "readyok\n"));
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:406:25
[INFO] [stdout]     |
[INFO] [stdout] 406 |                         try!(writer.flush());
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:469:17
[INFO] [stdout]     |
[INFO] [stdout] 469 |                 try!(writer.flush());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:444:29
[INFO] [stdout]     |
[INFO] [stdout] 444 | ...                   try!(write!(writer,
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:454:33
[INFO] [stdout]     |
[INFO] [stdout] 454 | ...                   try!(write!(writer, "info"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:458:33
[INFO] [stdout]     |
[INFO] [stdout] 458 | ...                   try!(write!(writer, "\n"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:456:37
[INFO] [stdout]     |
[INFO] [stdout] 456 | ...                   try!(write!(writer, " {} {}", info_type, data));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/lib.rs:127:1
[INFO] [stdout]     |
[INFO] [stdout] 127 | / lazy_static! {
[INFO] [stdout] 128 | |     static ref CONFIGURATION: RwLock<HashMap<&'static str, String>> = RwLock::new(HashMap::new());
[INFO] [stdout] 129 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:228:31
[INFO] [stdout]     |
[INFO] [stdout] 228 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]     |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:229:38
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = ONCE_INIT;
[INFO] [stdout]     |                                      ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = Once::new();
[INFO] [stdout]     |                                      ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]    |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:88:36
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = ONCE_INIT;
[INFO] [stdout]    |                                    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = Once::new();
[INFO] [stdout]    |                                    ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/notation.rs:87:5
[INFO] [stdout]    |
[INFO] [stdout] 87 | /     lazy_static! {
[INFO] [stdout] 88 | |         static ref RE: Regex = Regex::new(r"^[a-h][1-8]$").unwrap();
[INFO] [stdout] 89 | |     }
[INFO] [stdout]    | |_____^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/simple_search.rs:355:47
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/stock/std_move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/stock/std_move_generator.rs:37:33
[INFO] [stdout]    |
[INFO] [stdout] 37 |             evaluator: unsafe { uninitialized() },
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/std_time_manager.rs:175:1
[INFO] [stdout]     |
[INFO] [stdout] 175 | / lazy_static! {
[INFO] [stdout] 176 | |     static ref AVG_SLOPE: RwLock<f64> = RwLock::new(0.7);
[INFO] [stdout] 177 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/deepening/mod.rs:160:9
[INFO] [stdout]     |
[INFO] [stdout] 160 | /         lazy_static! {
[INFO] [stdout] 161 | |             static ref RE: Regex = Regex::new(r"^TARGET_DEPTH=([-+]?\d+)$").unwrap();
[INFO] [stdout] 162 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/moves.rs:387:5
[INFO] [stdout]     |
[INFO] [stdout] 387 | /     lazy_static! {
[INFO] [stdout] 388 | |         static ref NOTATION: Vec<String> = (0..64).map(|i| format!("{}{}",
[INFO] [stdout] 389 | |             ["a", "b", "c", "d", "e", "f", "g", "h"][Board::file(i)],
[INFO] [stdout] 390 | |             ["1", "2", "3", "4", "5", "6", "7", "8"][Board::rank(i)])
[INFO] [stdout] 391 | |         ).collect();
[INFO] [stdout] 392 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:300:9
[INFO] [stdout]     |
[INFO] [stdout] 300 | /         lazy_static! {
[INFO] [stdout] 301 | |             static ref RE: Regex = Regex::new(r"\buci(?:\s|$)").unwrap();
[INFO] [stdout] 302 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 490 | /     lazy_static! {
[INFO] [stdout] 491 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 492 | |             format!(r"\b({})\s*(?:\s(.*)|$)",
[INFO] [stdout] 493 | |                     "setoption|isready|ucinewgame|\
[INFO] [stdout] ...   |
[INFO] [stdout] 496 | |         ).unwrap();
[INFO] [stdout] 497 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:519:5
[INFO] [stdout]     |
[INFO] [stdout] 519 | /     lazy_static! {
[INFO] [stdout] 520 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 521 | |             r"^name\s+(\S.*?)(?:\s+value\s+(.*?))?\s*$").unwrap();
[INFO] [stdout] 522 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:536:5
[INFO] [stdout]     |
[INFO] [stdout] 536 | /     lazy_static! {
[INFO] [stdout] 537 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 538 | |             format!(
[INFO] [stdout] 539 | |                 r"^(?:fen\s+(?P<fen>{})|startpos)(?:\s+moves(?P<moves>{}))?\s*$",
[INFO] [stdout] ...   |
[INFO] [stdout] 543 | |         ).unwrap();
[INFO] [stdout] 544 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:564:5
[INFO] [stdout]     |
[INFO] [stdout] 564 | /     lazy_static! {
[INFO] [stdout] 565 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 566 | |             format!(
[INFO] [stdout] 567 | |                 r"\b(?P<keyword>{})(?:\s+(?P<number>\d+)|(?P<moves>{}))?(?:\s+|$)",
[INFO] [stdout] ...   |
[INFO] [stdout] 572 | |         ).unwrap();
[INFO] [stdout] 573 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:152:30
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut FnMut(u64) -> bool,
[INFO] [stdout]     |                              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut dyn FnMut(u64) -> bool,
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/search_node.rs:50:44
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/uci.rs:244:51
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>);
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>);
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/engine.rs:233:51
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:169:41
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut FnMut(u64) -> bool)
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut dyn FnMut(u64) -> bool)
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/stock/std_search_node.rs:69:44
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:214:63
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, &mut BISHOP_MAP, 0, false);
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` on by default
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, addr_of_mut!(BISHOP_MAP), 0, false);
[INFO] [stdout]     |                                                               ~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:215:52
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, &mut ROOK_MAP, bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, addr_of_mut!(ROOK_MAP), bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:172:17
[INFO] [stdout]     |
[INFO] [stdout] 172 | /                 format!("too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 | |                         mem::align_of::<T>()));
[INFO] [stdout]     | |_____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` on by default
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 172 ~                 "too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 ~                         mem::align_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:175:17
[INFO] [stdout]     |
[INFO] [stdout] 175 | /                 format!("too big transposition table entry: {} bytes",
[INFO] [stdout] 176 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 175 ~                 "too big transposition table entry: {} bytes",
[INFO] [stdout] 176 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:178:17
[INFO] [stdout]     |
[INFO] [stdout] 178 | /                 format!("too small transposition table entry: {} bytes",
[INFO] [stdout] 179 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 178 ~                 "too small transposition table entry: {} bytes",
[INFO] [stdout] 179 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `bool` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/simple_search.rs:355:42
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: booleans must be either `true` or `false`
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Option<moves::Move>` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                           |
[INFO] [stdout]     |                                           this code causes undefined behavior when executed
[INFO] [stdout]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]    --> /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/option.rs:571:1
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                    |
[INFO] [stdout]     |                                                    this code causes undefined behavior when executed
[INFO] [stdout]     |                                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         this code causes undefined behavior when executed
[INFO] [stdout]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[i16; 34]` does not permit being left uninitialized
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         this code causes undefined behavior when executed
[INFO] [stdout]     |                                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 84 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2.31s
[INFO] running `Command { std: "docker" "inspect" "c97575f60538e54ca5d5a5fcefdb108431bc3199ce0467b59facc391001ee4d4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c97575f60538e54ca5d5a5fcefdb108431bc3199ce0467b59facc391001ee4d4", kill_on_drop: false }`
[INFO] [stdout] c97575f60538e54ca5d5a5fcefdb108431bc3199ce0467b59facc391001ee4d4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:59a85a07ab18ca8720692f8e61effa1c651d9e2ca591e072c2b212bb91a6b8b5" "/opt/rustwide/cargo-home/bin/cargo" "+1871252fc8bb672d40787e67404e6eaae7059369" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 567cdc47e5d0ad469330a0576c1c28e7f87dc26f48cee7a8a9ad38af65366035
[INFO] running `Command { std: "docker" "start" "-a" "567cdc47e5d0ad469330a0576c1c28e7f87dc26f48cee7a8a9ad38af65366035", kill_on_drop: false }`
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:55:22
[INFO] [stdout]    |
[INFO] [stdout] 55 |         let pieces = try!(parse_fen_piece_placement(fileds[0]));
[INFO] [stdout]    |                      ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:56:23
[INFO] [stdout]    |
[INFO] [stdout] 56 |         let to_move = try!(parse_fen_active_color(fileds[1]));
[INFO] [stdout]    |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:57:31
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let castling_rights = try!(parse_fen_castling_rights(fileds[2]));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:58:47
[INFO] [stdout]    |
[INFO] [stdout] 58 |         let enpassant_file = if let Some(x) = try!(parse_fen_enpassant_square(fileds[3])) {
[INFO] [stdout]    |                                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:67:30
[INFO] [stdout]    |
[INFO] [stdout] 67 |         let halfmove_clock = try!(fileds[4].parse::<u8>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:68:31
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let fullmove_number = try!(fileds[5].parse::<u16>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]   --> src/utils/notation.rs:69:17
[INFO] [stdout]    |
[INFO] [stdout] 69 |         if let 1...9000 = fullmove_number {
[INFO] [stdout]    |                 ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/utils/notation.rs:134:20
[INFO] [stdout]     |
[INFO] [stdout] 134 |             n @ '1'...'8' => Token::EmptySquares(n.to_digit(9).unwrap()),
[INFO] [stdout]     |                    ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/stock/std_ttable.rs:213:31
[INFO] [stdout]     |
[INFO] [stdout] 213 |                          n @ 1...30 => n + 1,
[INFO] [stdout]     |                               ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:226:26
[INFO] [stdout]     |
[INFO] [stdout] 226 |         if let Some(v) = try!(self.node_begin(alpha, beta, depth, last_move)) {
[INFO] [stdout]     |                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:238:17
[INFO] [stdout]     |
[INFO] [stdout] 238 |                 try!(self.report_progress(1));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:246:22
[INFO] [stdout]     |
[INFO] [stdout] 246 |                     -try!(self.run(-beta, -alpha, depth - 1, m))
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:255:28
[INFO] [stdout]     |
[INFO] [stdout] 255 |                     match -try!(self.run(-alpha - 1, -alpha, depth - 2, m)) {
[INFO] [stdout]     |                            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:257:31
[INFO] [stdout]     |
[INFO] [stdout] 257 |                         _ => -try!(self.run(-beta, -alpha, depth - 1, m)),
[INFO] [stdout]     |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:373:13
[INFO] [stdout]     |
[INFO] [stdout] 373 |             try!(self.report_progress(result.searched_nodes()));
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:425:30
[INFO] [stdout]     |
[INFO] [stdout] 425 |                 let value = -try!(self.run(-beta, -alpha, max(0, reduced_depth - 1), m));
[INFO] [stdout]     |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/stock/std_search_node.rs:70:39
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut p: StdSearchNode<T> = try!(StdSearchNode::from_fen(fen));
[INFO] [stdout]    |                                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:317:56
[INFO] [stdout]     |
[INFO] [stdout] 317 |         let (board, halfmove_clock, fullmove_number) = try!(parse_fen(fen));
[INFO] [stdout]     |                                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:318:19
[INFO] [stdout]     |
[INFO] [stdout] 318 |         let gen = try!(T::MoveGenerator::from_board(board));
[INFO] [stdout]     |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/aspiration.rs:107:13
[INFO] [stdout]     |
[INFO] [stdout] 107 |         } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/multipv.rs:118:17
[INFO] [stdout]     |
[INFO] [stdout] 118 |             } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/mod.rs:125:13
[INFO] [stdout]     |
[INFO] [stdout] 125 |         } = try!(self.multipv.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:150:27
[INFO] [stdout]     |
[INFO] [stdout] 150 |         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 150 -         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout] 150 +         const WQ: usize = 1 << (WHITE << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:151:27
[INFO] [stdout]     |
[INFO] [stdout] 151 |         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 151 -         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout] 151 +         const WK: usize = 1 << (WHITE << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:153:27
[INFO] [stdout]     |
[INFO] [stdout] 153 |         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 153 -         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout] 153 +         const BQ: usize = 1 << (BLACK << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:154:27
[INFO] [stdout]     |
[INFO] [stdout] 154 |         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout] 154 +         const BK: usize = 1 << (BLACK << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/board.rs:189:17
[INFO] [stdout]     |
[INFO] [stdout] 189 |                 try!(f.write_str(s));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:280:22
[INFO] [stdout]     |
[INFO] [stdout] 280 |     let mut server = try!(Server::<E>::wait_for_hanshake());
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:313:9
[INFO] [stdout]     |
[INFO] [stdout] 313 |         try!(write!(writer, "id name {}\n", E::name()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:314:9
[INFO] [stdout]     |
[INFO] [stdout] 314 |         try!(write!(writer, "id author {}\n", E::author()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:342:9
[INFO] [stdout]     |
[INFO] [stdout] 342 |         try!(write!(writer, "uciok\n"));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:343:9
[INFO] [stdout]     |
[INFO] [stdout] 343 |         try!(writer.flush());
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:307:12
[INFO] [stdout]     |
[INFO] [stdout] 307 |         if try!(reader.read_line(&mut line)) == 0 {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:316:13
[INFO] [stdout]     |
[INFO] [stdout] 316 |             try!(write!(writer,
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:361:40
[INFO] [stdout]     |
[INFO] [stdout] 361 |                 if let Ok(cmd) = match try!(reader.read_line(&mut line)) {
[INFO] [stdout]     |                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:405:25
[INFO] [stdout]     |
[INFO] [stdout] 405 |                         try!(write!(writer, "readyok\n"));
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:406:25
[INFO] [stdout]     |
[INFO] [stdout] 406 |                         try!(writer.flush());
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:469:17
[INFO] [stdout]     |
[INFO] [stdout] 469 |                 try!(writer.flush());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:444:29
[INFO] [stdout]     |
[INFO] [stdout] 444 | ...                   try!(write!(writer,
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:454:33
[INFO] [stdout]     |
[INFO] [stdout] 454 | ...                   try!(write!(writer, "info"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:458:33
[INFO] [stdout]     |
[INFO] [stdout] 458 | ...                   try!(write!(writer, "\n"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:456:37
[INFO] [stdout]     |
[INFO] [stdout] 456 | ...                   try!(write!(writer, " {} {}", info_type, data));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/lib.rs:127:1
[INFO] [stdout]     |
[INFO] [stdout] 127 | / lazy_static! {
[INFO] [stdout] 128 | |     static ref CONFIGURATION: RwLock<HashMap<&'static str, String>> = RwLock::new(HashMap::new());
[INFO] [stdout] 129 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:228:31
[INFO] [stdout]     |
[INFO] [stdout] 228 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]     |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:229:38
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = ONCE_INIT;
[INFO] [stdout]     |                                      ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = Once::new();
[INFO] [stdout]     |                                      ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]    |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:88:36
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = ONCE_INIT;
[INFO] [stdout]    |                                    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = Once::new();
[INFO] [stdout]    |                                    ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/notation.rs:87:5
[INFO] [stdout]    |
[INFO] [stdout] 87 | /     lazy_static! {
[INFO] [stdout] 88 | |         static ref RE: Regex = Regex::new(r"^[a-h][1-8]$").unwrap();
[INFO] [stdout] 89 | |     }
[INFO] [stdout]    | |_____^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/simple_search.rs:355:47
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/stock/std_move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/stock/std_move_generator.rs:37:33
[INFO] [stdout]    |
[INFO] [stdout] 37 |             evaluator: unsafe { uninitialized() },
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/std_time_manager.rs:175:1
[INFO] [stdout]     |
[INFO] [stdout] 175 | / lazy_static! {
[INFO] [stdout] 176 | |     static ref AVG_SLOPE: RwLock<f64> = RwLock::new(0.7);
[INFO] [stdout] 177 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/deepening/mod.rs:160:9
[INFO] [stdout]     |
[INFO] [stdout] 160 | /         lazy_static! {
[INFO] [stdout] 161 | |             static ref RE: Regex = Regex::new(r"^TARGET_DEPTH=([-+]?\d+)$").unwrap();
[INFO] [stdout] 162 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/moves.rs:387:5
[INFO] [stdout]     |
[INFO] [stdout] 387 | /     lazy_static! {
[INFO] [stdout] 388 | |         static ref NOTATION: Vec<String> = (0..64).map(|i| format!("{}{}",
[INFO] [stdout] 389 | |             ["a", "b", "c", "d", "e", "f", "g", "h"][Board::file(i)],
[INFO] [stdout] 390 | |             ["1", "2", "3", "4", "5", "6", "7", "8"][Board::rank(i)])
[INFO] [stdout] 391 | |         ).collect();
[INFO] [stdout] 392 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:300:9
[INFO] [stdout]     |
[INFO] [stdout] 300 | /         lazy_static! {
[INFO] [stdout] 301 | |             static ref RE: Regex = Regex::new(r"\buci(?:\s|$)").unwrap();
[INFO] [stdout] 302 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 490 | /     lazy_static! {
[INFO] [stdout] 491 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 492 | |             format!(r"\b({})\s*(?:\s(.*)|$)",
[INFO] [stdout] 493 | |                     "setoption|isready|ucinewgame|\
[INFO] [stdout] ...   |
[INFO] [stdout] 496 | |         ).unwrap();
[INFO] [stdout] 497 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:519:5
[INFO] [stdout]     |
[INFO] [stdout] 519 | /     lazy_static! {
[INFO] [stdout] 520 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 521 | |             r"^name\s+(\S.*?)(?:\s+value\s+(.*?))?\s*$").unwrap();
[INFO] [stdout] 522 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:536:5
[INFO] [stdout]     |
[INFO] [stdout] 536 | /     lazy_static! {
[INFO] [stdout] 537 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 538 | |             format!(
[INFO] [stdout] 539 | |                 r"^(?:fen\s+(?P<fen>{})|startpos)(?:\s+moves(?P<moves>{}))?\s*$",
[INFO] [stdout] ...   |
[INFO] [stdout] 543 | |         ).unwrap();
[INFO] [stdout] 544 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:564:5
[INFO] [stdout]     |
[INFO] [stdout] 564 | /     lazy_static! {
[INFO] [stdout] 565 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 566 | |             format!(
[INFO] [stdout] 567 | |                 r"\b(?P<keyword>{})(?:\s+(?P<number>\d+)|(?P<moves>{}))?(?:\s+|$)",
[INFO] [stdout] ...   |
[INFO] [stdout] 572 | |         ).unwrap();
[INFO] [stdout] 573 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:152:30
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut FnMut(u64) -> bool,
[INFO] [stdout]     |                              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut dyn FnMut(u64) -> bool,
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/search_node.rs:50:44
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/uci.rs:244:51
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>);
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>);
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/engine.rs:233:51
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:169:41
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut FnMut(u64) -> bool)
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut dyn FnMut(u64) -> bool)
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/stock/std_search_node.rs:69:44
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:214:63
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, &mut BISHOP_MAP, 0, false);
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` on by default
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, addr_of_mut!(BISHOP_MAP), 0, false);
[INFO] [stdout]     |                                                               ~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:215:52
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, &mut ROOK_MAP, bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, addr_of_mut!(ROOK_MAP), bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:172:17
[INFO] [stdout]     |
[INFO] [stdout] 172 | /                 format!("too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 | |                         mem::align_of::<T>()));
[INFO] [stdout]     | |_____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` on by default
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 172 ~                 "too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 ~                         mem::align_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:175:17
[INFO] [stdout]     |
[INFO] [stdout] 175 | /                 format!("too big transposition table entry: {} bytes",
[INFO] [stdout] 176 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 175 ~                 "too big transposition table entry: {} bytes",
[INFO] [stdout] 176 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:178:17
[INFO] [stdout]     |
[INFO] [stdout] 178 | /                 format!("too small transposition table entry: {} bytes",
[INFO] [stdout] 179 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 178 ~                 "too small transposition table entry: {} bytes",
[INFO] [stdout] 179 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `bool` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/simple_search.rs:355:42
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: booleans must be either `true` or `false`
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Option<moves::Move>` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                           |
[INFO] [stdout]     |                                           this code causes undefined behavior when executed
[INFO] [stdout]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]    --> /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/option.rs:571:1
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                    |
[INFO] [stdout]     |                                                    this code causes undefined behavior when executed
[INFO] [stdout]     |                                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         this code causes undefined behavior when executed
[INFO] [stdout]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[i16; 34]` does not permit being left uninitialized
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         this code causes undefined behavior when executed
[INFO] [stdout]     |                                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling alcibiades v0.3.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: 84 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:55:22
[INFO] [stdout]    |
[INFO] [stdout] 55 |         let pieces = try!(parse_fen_piece_placement(fileds[0]));
[INFO] [stdout]    |                      ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:56:23
[INFO] [stdout]    |
[INFO] [stdout] 56 |         let to_move = try!(parse_fen_active_color(fileds[1]));
[INFO] [stdout]    |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:57:31
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let castling_rights = try!(parse_fen_castling_rights(fileds[2]));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:58:47
[INFO] [stdout]    |
[INFO] [stdout] 58 |         let enpassant_file = if let Some(x) = try!(parse_fen_enpassant_square(fileds[3])) {
[INFO] [stdout]    |                                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:67:30
[INFO] [stdout]    |
[INFO] [stdout] 67 |         let halfmove_clock = try!(fileds[4].parse::<u8>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:68:31
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let fullmove_number = try!(fileds[5].parse::<u16>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]   --> src/utils/notation.rs:69:17
[INFO] [stdout]    |
[INFO] [stdout] 69 |         if let 1...9000 = fullmove_number {
[INFO] [stdout]    |                 ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/utils/notation.rs:134:20
[INFO] [stdout]     |
[INFO] [stdout] 134 |             n @ '1'...'8' => Token::EmptySquares(n.to_digit(9).unwrap()),
[INFO] [stdout]     |                    ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/stock/std_ttable.rs:213:31
[INFO] [stdout]     |
[INFO] [stdout] 213 |                          n @ 1...30 => n + 1,
[INFO] [stdout]     |                               ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:226:26
[INFO] [stdout]     |
[INFO] [stdout] 226 |         if let Some(v) = try!(self.node_begin(alpha, beta, depth, last_move)) {
[INFO] [stdout]     |                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:238:17
[INFO] [stdout]     |
[INFO] [stdout] 238 |                 try!(self.report_progress(1));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:246:22
[INFO] [stdout]     |
[INFO] [stdout] 246 |                     -try!(self.run(-beta, -alpha, depth - 1, m))
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:255:28
[INFO] [stdout]     |
[INFO] [stdout] 255 |                     match -try!(self.run(-alpha - 1, -alpha, depth - 2, m)) {
[INFO] [stdout]     |                            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:257:31
[INFO] [stdout]     |
[INFO] [stdout] 257 |                         _ => -try!(self.run(-beta, -alpha, depth - 1, m)),
[INFO] [stdout]     |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:373:13
[INFO] [stdout]     |
[INFO] [stdout] 373 |             try!(self.report_progress(result.searched_nodes()));
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:425:30
[INFO] [stdout]     |
[INFO] [stdout] 425 |                 let value = -try!(self.run(-beta, -alpha, max(0, reduced_depth - 1), m));
[INFO] [stdout]     |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/stock/std_search_node.rs:70:39
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut p: StdSearchNode<T> = try!(StdSearchNode::from_fen(fen));
[INFO] [stdout]    |                                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:317:56
[INFO] [stdout]     |
[INFO] [stdout] 317 |         let (board, halfmove_clock, fullmove_number) = try!(parse_fen(fen));
[INFO] [stdout]     |                                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:318:19
[INFO] [stdout]     |
[INFO] [stdout] 318 |         let gen = try!(T::MoveGenerator::from_board(board));
[INFO] [stdout]     |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]     --> src/stock/std_move_generator.rs:1253:42
[INFO] [stdout]      |
[INFO] [stdout] 1253 |             StdMoveGenerator::from_board(try!(Board::from_fen(fen)))
[INFO] [stdout]      |                                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/aspiration.rs:107:13
[INFO] [stdout]     |
[INFO] [stdout] 107 |         } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/multipv.rs:118:17
[INFO] [stdout]     |
[INFO] [stdout] 118 |             } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/mod.rs:125:13
[INFO] [stdout]     |
[INFO] [stdout] 125 |         } = try!(self.multipv.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:150:27
[INFO] [stdout]     |
[INFO] [stdout] 150 |         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 150 -         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout] 150 +         const WQ: usize = 1 << (WHITE << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:151:27
[INFO] [stdout]     |
[INFO] [stdout] 151 |         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 151 -         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout] 151 +         const WK: usize = 1 << (WHITE << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:153:27
[INFO] [stdout]     |
[INFO] [stdout] 153 |         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 153 -         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout] 153 +         const BQ: usize = 1 << (BLACK << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:154:27
[INFO] [stdout]     |
[INFO] [stdout] 154 |         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout] 154 +         const BK: usize = 1 << (BLACK << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/board.rs:189:17
[INFO] [stdout]     |
[INFO] [stdout] 189 |                 try!(f.write_str(s));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:280:22
[INFO] [stdout]     |
[INFO] [stdout] 280 |     let mut server = try!(Server::<E>::wait_for_hanshake());
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:313:9
[INFO] [stdout]     |
[INFO] [stdout] 313 |         try!(write!(writer, "id name {}\n", E::name()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:314:9
[INFO] [stdout]     |
[INFO] [stdout] 314 |         try!(write!(writer, "id author {}\n", E::author()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:342:9
[INFO] [stdout]     |
[INFO] [stdout] 342 |         try!(write!(writer, "uciok\n"));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:343:9
[INFO] [stdout]     |
[INFO] [stdout] 343 |         try!(writer.flush());
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:307:12
[INFO] [stdout]     |
[INFO] [stdout] 307 |         if try!(reader.read_line(&mut line)) == 0 {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:316:13
[INFO] [stdout]     |
[INFO] [stdout] 316 |             try!(write!(writer,
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:361:40
[INFO] [stdout]     |
[INFO] [stdout] 361 |                 if let Ok(cmd) = match try!(reader.read_line(&mut line)) {
[INFO] [stdout]     |                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:405:25
[INFO] [stdout]     |
[INFO] [stdout] 405 |                         try!(write!(writer, "readyok\n"));
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:406:25
[INFO] [stdout]     |
[INFO] [stdout] 406 |                         try!(writer.flush());
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:469:17
[INFO] [stdout]     |
[INFO] [stdout] 469 |                 try!(writer.flush());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:444:29
[INFO] [stdout]     |
[INFO] [stdout] 444 | ...                   try!(write!(writer,
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:454:33
[INFO] [stdout]     |
[INFO] [stdout] 454 | ...                   try!(write!(writer, "info"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:458:33
[INFO] [stdout]     |
[INFO] [stdout] 458 | ...                   try!(write!(writer, "\n"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:456:37
[INFO] [stdout]     |
[INFO] [stdout] 456 | ...                   try!(write!(writer, " {} {}", info_type, data));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/lib.rs:127:1
[INFO] [stdout]     |
[INFO] [stdout] 127 | / lazy_static! {
[INFO] [stdout] 128 | |     static ref CONFIGURATION: RwLock<HashMap<&'static str, String>> = RwLock::new(HashMap::new());
[INFO] [stdout] 129 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:228:31
[INFO] [stdout]     |
[INFO] [stdout] 228 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]     |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:229:38
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = ONCE_INIT;
[INFO] [stdout]     |                                      ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = Once::new();
[INFO] [stdout]     |                                      ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]    |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:88:36
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = ONCE_INIT;
[INFO] [stdout]    |                                    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = Once::new();
[INFO] [stdout]    |                                    ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/notation.rs:87:5
[INFO] [stdout]    |
[INFO] [stdout] 87 | /     lazy_static! {
[INFO] [stdout] 88 | |         static ref RE: Regex = Regex::new(r"^[a-h][1-8]$").unwrap();
[INFO] [stdout] 89 | |     }
[INFO] [stdout]    | |_____^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/simple_search.rs:355:47
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/stock/std_move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/stock/std_move_generator.rs:37:33
[INFO] [stdout]    |
[INFO] [stdout] 37 |             evaluator: unsafe { uninitialized() },
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/std_time_manager.rs:175:1
[INFO] [stdout]     |
[INFO] [stdout] 175 | / lazy_static! {
[INFO] [stdout] 176 | |     static ref AVG_SLOPE: RwLock<f64> = RwLock::new(0.7);
[INFO] [stdout] 177 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/deepening/mod.rs:160:9
[INFO] [stdout]     |
[INFO] [stdout] 160 | /         lazy_static! {
[INFO] [stdout] 161 | |             static ref RE: Regex = Regex::new(r"^TARGET_DEPTH=([-+]?\d+)$").unwrap();
[INFO] [stdout] 162 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/moves.rs:387:5
[INFO] [stdout]     |
[INFO] [stdout] 387 | /     lazy_static! {
[INFO] [stdout] 388 | |         static ref NOTATION: Vec<String> = (0..64).map(|i| format!("{}{}",
[INFO] [stdout] 389 | |             ["a", "b", "c", "d", "e", "f", "g", "h"][Board::file(i)],
[INFO] [stdout] 390 | |             ["1", "2", "3", "4", "5", "6", "7", "8"][Board::rank(i)])
[INFO] [stdout] 391 | |         ).collect();
[INFO] [stdout] 392 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:300:9
[INFO] [stdout]     |
[INFO] [stdout] 300 | /         lazy_static! {
[INFO] [stdout] 301 | |             static ref RE: Regex = Regex::new(r"\buci(?:\s|$)").unwrap();
[INFO] [stdout] 302 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 490 | /     lazy_static! {
[INFO] [stdout] 491 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 492 | |             format!(r"\b({})\s*(?:\s(.*)|$)",
[INFO] [stdout] 493 | |                     "setoption|isready|ucinewgame|\
[INFO] [stdout] ...   |
[INFO] [stdout] 496 | |         ).unwrap();
[INFO] [stdout] 497 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:519:5
[INFO] [stdout]     |
[INFO] [stdout] 519 | /     lazy_static! {
[INFO] [stdout] 520 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 521 | |             r"^name\s+(\S.*?)(?:\s+value\s+(.*?))?\s*$").unwrap();
[INFO] [stdout] 522 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:536:5
[INFO] [stdout]     |
[INFO] [stdout] 536 | /     lazy_static! {
[INFO] [stdout] 537 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 538 | |             format!(
[INFO] [stdout] 539 | |                 r"^(?:fen\s+(?P<fen>{})|startpos)(?:\s+moves(?P<moves>{}))?\s*$",
[INFO] [stdout] ...   |
[INFO] [stdout] 543 | |         ).unwrap();
[INFO] [stdout] 544 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:564:5
[INFO] [stdout]     |
[INFO] [stdout] 564 | /     lazy_static! {
[INFO] [stdout] 565 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 566 | |             format!(
[INFO] [stdout] 567 | |                 r"\b(?P<keyword>{})(?:\s+(?P<number>\d+)|(?P<moves>{}))?(?:\s+|$)",
[INFO] [stdout] ...   |
[INFO] [stdout] 572 | |         ).unwrap();
[INFO] [stdout] 573 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:152:30
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut FnMut(u64) -> bool,
[INFO] [stdout]     |                              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut dyn FnMut(u64) -> bool,
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/search_node.rs:50:44
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/uci.rs:244:51
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>);
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>);
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/engine.rs:233:51
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:169:41
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut FnMut(u64) -> bool)
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut dyn FnMut(u64) -> bool)
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/stock/std_search_node.rs:69:44
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:214:63
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, &mut BISHOP_MAP, 0, false);
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` on by default
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, addr_of_mut!(BISHOP_MAP), 0, false);
[INFO] [stdout]     |                                                               ~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:215:52
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, &mut ROOK_MAP, bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, addr_of_mut!(ROOK_MAP), bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/stock/std_ttable.rs:443:17
[INFO] [stdout]     |
[INFO] [stdout] 443 |             let mut record = b.get(0).as_mut().unwrap();
[INFO] [stdout]     |                 ----^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/stock/std_ttable.rs:464:17
[INFO] [stdout]     |
[INFO] [stdout] 464 |             let mut record = b.get(4).as_mut().unwrap();
[INFO] [stdout]     |                 ----^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:172:17
[INFO] [stdout]     |
[INFO] [stdout] 172 | /                 format!("too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 | |                         mem::align_of::<T>()));
[INFO] [stdout]     | |_____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` on by default
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 172 ~                 "too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 ~                         mem::align_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:175:17
[INFO] [stdout]     |
[INFO] [stdout] 175 | /                 format!("too big transposition table entry: {} bytes",
[INFO] [stdout] 176 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 175 ~                 "too big transposition table entry: {} bytes",
[INFO] [stdout] 176 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:178:17
[INFO] [stdout]     |
[INFO] [stdout] 178 | /                 format!("too small transposition table entry: {} bytes",
[INFO] [stdout] 179 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 178 ~                 "too small transposition table entry: {} bytes",
[INFO] [stdout] 179 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `bool` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/simple_search.rs:355:42
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: booleans must be either `true` or `false`
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Option<moves::Move>` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                           |
[INFO] [stdout]     |                                           this code causes undefined behavior when executed
[INFO] [stdout]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]    --> /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/option.rs:571:1
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                    |
[INFO] [stdout]     |                                                    this code causes undefined behavior when executed
[INFO] [stdout]     |                                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         this code causes undefined behavior when executed
[INFO] [stdout]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[i16; 34]` does not permit being left uninitialized
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         this code causes undefined behavior when executed
[INFO] [stdout]     |                                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 87 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.26s
[INFO] running `Command { std: "docker" "inspect" "567cdc47e5d0ad469330a0576c1c28e7f87dc26f48cee7a8a9ad38af65366035", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "567cdc47e5d0ad469330a0576c1c28e7f87dc26f48cee7a8a9ad38af65366035", kill_on_drop: false }`
[INFO] [stdout] 567cdc47e5d0ad469330a0576c1c28e7f87dc26f48cee7a8a9ad38af65366035
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:59a85a07ab18ca8720692f8e61effa1c651d9e2ca591e072c2b212bb91a6b8b5" "/opt/rustwide/cargo-home/bin/cargo" "+1871252fc8bb672d40787e67404e6eaae7059369" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 7652f4ef79e1f7bc8d38ea69e5dc629ba9c5e3326704db0b181d169867adf554
[INFO] running `Command { std: "docker" "start" "-a" "7652f4ef79e1f7bc8d38ea69e5dc629ba9c5e3326704db0b181d169867adf554", kill_on_drop: false }`
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:55:22
[INFO] [stderr]    |
[INFO] [stderr] 55 |         let pieces = try!(parse_fen_piece_placement(fileds[0]));
[INFO] [stderr]    |                      ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:56:23
[INFO] [stderr]    |
[INFO] [stderr] 56 |         let to_move = try!(parse_fen_active_color(fileds[1]));
[INFO] [stderr]    |                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:57:31
[INFO] [stderr]    |
[INFO] [stderr] 57 |         let castling_rights = try!(parse_fen_castling_rights(fileds[2]));
[INFO] [stderr]    |                               ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:58:47
[INFO] [stderr]    |
[INFO] [stderr] 58 |         let enpassant_file = if let Some(x) = try!(parse_fen_enpassant_square(fileds[3])) {
[INFO] [stderr]    |                                               ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:67:30
[INFO] [stderr]    |
[INFO] [stderr] 67 |         let halfmove_clock = try!(fileds[4].parse::<u8>().map_err(|_| IllegalBoard));
[INFO] [stderr]    |                              ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:68:31
[INFO] [stderr]    |
[INFO] [stderr] 68 |         let fullmove_number = try!(fileds[5].parse::<u16>().map_err(|_| IllegalBoard));
[INFO] [stderr]    |                               ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/utils/notation.rs:69:17
[INFO] [stderr]    |
[INFO] [stderr] 69 |         if let 1...9000 = fullmove_number {
[INFO] [stderr]    |                 ^^^ help: use `..=` for an inclusive range
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]    --> src/utils/notation.rs:134:20
[INFO] [stderr]     |
[INFO] [stderr] 134 |             n @ '1'...'8' => Token::EmptySquares(n.to_digit(9).unwrap()),
[INFO] [stderr]     |                    ^^^ help: use `..=` for an inclusive range
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]    --> src/stock/std_ttable.rs:213:31
[INFO] [stderr]     |
[INFO] [stderr] 213 |                          n @ 1...30 => n + 1,
[INFO] [stderr]     |                               ^^^ help: use `..=` for an inclusive range
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:226:26
[INFO] [stderr]     |
[INFO] [stderr] 226 |         if let Some(v) = try!(self.node_begin(alpha, beta, depth, last_move)) {
[INFO] [stderr]     |                          ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:238:17
[INFO] [stderr]     |
[INFO] [stderr] 238 |                 try!(self.report_progress(1));
[INFO] [stderr]     |                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:246:22
[INFO] [stderr]     |
[INFO] [stderr] 246 |                     -try!(self.run(-beta, -alpha, depth - 1, m))
[INFO] [stderr]     |                      ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:255:28
[INFO] [stderr]     |
[INFO] [stderr] 255 |                     match -try!(self.run(-alpha - 1, -alpha, depth - 2, m)) {
[INFO] [stderr]     |                            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:257:31
[INFO] [stderr]     |
[INFO] [stderr] 257 |                         _ => -try!(self.run(-beta, -alpha, depth - 1, m)),
[INFO] [stderr]     |                               ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:373:13
[INFO] [stderr]     |
[INFO] [stderr] 373 |             try!(self.report_progress(result.searched_nodes()));
[INFO] [stderr]     |             ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:425:30
[INFO] [stderr]     |
[INFO] [stderr] 425 |                 let value = -try!(self.run(-beta, -alpha, max(0, reduced_depth - 1), m));
[INFO] [stderr]     |                              ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/stock/std_search_node.rs:70:39
[INFO] [stderr]    |
[INFO] [stderr] 70 |         let mut p: StdSearchNode<T> = try!(StdSearchNode::from_fen(fen));
[INFO] [stderr]    |                                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/std_search_node.rs:317:56
[INFO] [stderr]     |
[INFO] [stderr] 317 |         let (board, halfmove_clock, fullmove_number) = try!(parse_fen(fen));
[INFO] [stderr]     |                                                        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/std_search_node.rs:318:19
[INFO] [stderr]     |
[INFO] [stderr] 318 |         let gen = try!(T::MoveGenerator::from_board(board));
[INFO] [stderr]     |                   ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/deepening/aspiration.rs:107:13
[INFO] [stderr]     |
[INFO] [stderr] 107 |         } = try!(self.searcher.try_recv_report());
[INFO] [stderr]     |             ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/deepening/multipv.rs:118:17
[INFO] [stderr]     |
[INFO] [stderr] 118 |             } = try!(self.searcher.try_recv_report());
[INFO] [stderr]     |                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/deepening/mod.rs:125:13
[INFO] [stderr]     |
[INFO] [stderr] 125 |         } = try!(self.multipv.try_recv_report());
[INFO] [stderr]     |             ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/board.rs:150:27
[INFO] [stderr]     |
[INFO] [stderr] 150 |         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stderr]     |                           ^                              ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 150 -         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stderr] 150 +         const WQ: usize = 1 << (WHITE << 1) << QUEENSIDE;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/board.rs:151:27
[INFO] [stderr]     |
[INFO] [stderr] 151 |         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stderr]     |                           ^                             ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 151 -         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stderr] 151 +         const WK: usize = 1 << (WHITE << 1) << KINGSIDE;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/board.rs:153:27
[INFO] [stderr]     |
[INFO] [stderr] 153 |         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stderr]     |                           ^                              ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 153 -         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stderr] 153 +         const BQ: usize = 1 << (BLACK << 1) << QUEENSIDE;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/board.rs:154:27
[INFO] [stderr]     |
[INFO] [stderr] 154 |         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stderr]     |                           ^                             ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 154 -         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stderr] 154 +         const BK: usize = 1 << (BLACK << 1) << KINGSIDE;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/board.rs:189:17
[INFO] [stderr]     |
[INFO] [stderr] 189 |                 try!(f.write_str(s));
[INFO] [stderr]     |                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:280:22
[INFO] [stderr]     |
[INFO] [stderr] 280 |     let mut server = try!(Server::<E>::wait_for_hanshake());
[INFO] [stderr]     |                      ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:313:9
[INFO] [stderr]     |
[INFO] [stderr] 313 |         try!(write!(writer, "id name {}\n", E::name()));
[INFO] [stderr]     |         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:314:9
[INFO] [stderr]     |
[INFO] [stderr] 314 |         try!(write!(writer, "id author {}\n", E::author()));
[INFO] [stderr]     |         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:342:9
[INFO] [stderr]     |
[INFO] [stderr] 342 |         try!(write!(writer, "uciok\n"));
[INFO] [stderr]     |         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:343:9
[INFO] [stderr]     |
[INFO] [stderr] 343 |         try!(writer.flush());
[INFO] [stderr]     |         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:307:12
[INFO] [stderr]     |
[INFO] [stderr] 307 |         if try!(reader.read_line(&mut line)) == 0 {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:316:13
[INFO] [stderr]     |
[INFO] [stderr] 316 |             try!(write!(writer,
[INFO] [stderr]     |             ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:361:40
[INFO] [stderr]     |
[INFO] [stderr] 361 |                 if let Ok(cmd) = match try!(reader.read_line(&mut line)) {
[INFO] [stderr]     |                                        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:405:25
[INFO] [stderr]     |
[INFO] [stderr] 405 |                         try!(write!(writer, "readyok\n"));
[INFO] [stderr]     |                         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:406:25
[INFO] [stderr]     |
[INFO] [stderr] 406 |                         try!(writer.flush());
[INFO] [stderr]     |                         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:469:17
[INFO] [stderr]     |
[INFO] [stderr] 469 |                 try!(writer.flush());
[INFO] [stderr]     |                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:444:29
[INFO] [stderr]     |
[INFO] [stderr] 444 | ...                   try!(write!(writer,
[INFO] [stderr]     |                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:454:33
[INFO] [stderr]     |
[INFO] [stderr] 454 | ...                   try!(write!(writer, "info"));
[INFO] [stderr]     |                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:458:33
[INFO] [stderr]     |
[INFO] [stderr] 458 | ...                   try!(write!(writer, "\n"));
[INFO] [stderr]     |                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:456:37
[INFO] [stderr]     |
[INFO] [stderr] 456 | ...                   try!(write!(writer, " {} {}", info_type, data));
[INFO] [stderr]     |                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/lib.rs:127:1
[INFO] [stderr]     |
[INFO] [stderr] 127 | / lazy_static! {
[INFO] [stderr] 128 | |     static ref CONFIGURATION: RwLock<HashMap<&'static str, String>> = RwLock::new(HashMap::new());
[INFO] [stderr] 129 | | }
[INFO] [stderr]     | |_^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/utils/board_geometry.rs:228:31
[INFO] [stderr]     |
[INFO] [stderr] 228 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stderr]     |                               ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/utils/board_geometry.rs:229:38
[INFO] [stderr]     |
[INFO] [stderr] 229 |         static INIT_GEOMETRY: Once = ONCE_INIT;
[INFO] [stderr]     |                                      ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr] help: replace the use of the deprecated constant
[INFO] [stderr]     |
[INFO] [stderr] 229 |         static INIT_GEOMETRY: Once = Once::new();
[INFO] [stderr]     |                                      ~~~~~~~~~~~
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]   --> src/utils/zobrist_arrays.rs:87:31
[INFO] [stderr]    |
[INFO] [stderr] 87 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stderr]    |                               ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]   --> src/utils/zobrist_arrays.rs:88:36
[INFO] [stderr]    |
[INFO] [stderr] 88 |         static INIT_ARRAYS: Once = ONCE_INIT;
[INFO] [stderr]    |                                    ^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: replace the use of the deprecated constant
[INFO] [stderr]    |
[INFO] [stderr] 88 |         static INIT_ARRAYS: Once = Once::new();
[INFO] [stderr]    |                                    ~~~~~~~~~~~
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]   --> src/utils/notation.rs:87:5
[INFO] [stderr]    |
[INFO] [stderr] 87 | /     lazy_static! {
[INFO] [stderr] 88 | |         static ref RE: Regex = Regex::new(r"^[a-h][1-8]$").unwrap();
[INFO] [stderr] 89 | |     }
[INFO] [stderr]    | |_____^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/engine.rs:611:1
[INFO] [stderr]     |
[INFO] [stderr] 611 | / lazy_static! {
[INFO] [stderr] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stderr] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stderr] 614 | | }
[INFO] [stderr]     | |_^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/stock/simple_search.rs:355:47
[INFO] [stderr]     |
[INFO] [stderr] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stderr]     |                                               ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]  --> src/stock/std_move_generator.rs:3:15
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::mem::uninitialized;
[INFO] [stderr]   |               ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]   --> src/stock/std_move_generator.rs:37:33
[INFO] [stderr]    |
[INFO] [stderr] 37 |             evaluator: unsafe { uninitialized() },
[INFO] [stderr]    |                                 ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stderr]     |
[INFO] [stderr] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stderr]     |                                           ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stderr]     |
[INFO] [stderr] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stderr]     |                                                    ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stderr]     |
[INFO] [stderr] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stderr]     |                                          ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stderr]     |
[INFO] [stderr] 870 |             dest_sets = uninitialized();
[INFO] [stderr]     |                         ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/stock/std_time_manager.rs:175:1
[INFO] [stderr]     |
[INFO] [stderr] 175 | / lazy_static! {
[INFO] [stderr] 176 | |     static ref AVG_SLOPE: RwLock<f64> = RwLock::new(0.7);
[INFO] [stderr] 177 | | }
[INFO] [stderr]     | |_^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/stock/deepening/mod.rs:160:9
[INFO] [stderr]     |
[INFO] [stderr] 160 | /         lazy_static! {
[INFO] [stderr] 161 | |             static ref RE: Regex = Regex::new(r"^TARGET_DEPTH=([-+]?\d+)$").unwrap();
[INFO] [stderr] 162 | |         }
[INFO] [stderr]     | |_________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/moves.rs:387:5
[INFO] [stderr]     |
[INFO] [stderr] 387 | /     lazy_static! {
[INFO] [stderr] 388 | |         static ref NOTATION: Vec<String> = (0..64).map(|i| format!("{}{}",
[INFO] [stderr] 389 | |             ["a", "b", "c", "d", "e", "f", "g", "h"][Board::file(i)],
[INFO] [stderr] 390 | |             ["1", "2", "3", "4", "5", "6", "7", "8"][Board::rank(i)])
[INFO] [stderr] 391 | |         ).collect();
[INFO] [stderr] 392 | |     }
[INFO] [stderr]     | |_____^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]  --> src/move_generator.rs:3:15
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::mem::uninitialized;
[INFO] [stderr]   |               ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/move_generator.rs:206:41
[INFO] [stderr]     |
[INFO] [stderr] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stderr]     |                                         ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/uci.rs:300:9
[INFO] [stderr]     |
[INFO] [stderr] 300 | /         lazy_static! {
[INFO] [stderr] 301 | |             static ref RE: Regex = Regex::new(r"\buci(?:\s|$)").unwrap();
[INFO] [stderr] 302 | |         }
[INFO] [stderr]     | |_________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/uci.rs:490:5
[INFO] [stderr]     |
[INFO] [stderr] 490 | /     lazy_static! {
[INFO] [stderr] 491 | |         static ref RE: Regex = Regex::new(
[INFO] [stderr] 492 | |             format!(r"\b({})\s*(?:\s(.*)|$)",
[INFO] [stderr] 493 | |                     "setoption|isready|ucinewgame|\
[INFO] [stderr] ...   |
[INFO] [stderr] 496 | |         ).unwrap();
[INFO] [stderr] 497 | |     }
[INFO] [stderr]     | |_____^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/uci.rs:519:5
[INFO] [stderr]     |
[INFO] [stderr] 519 | /     lazy_static! {
[INFO] [stderr] 520 | |         static ref RE: Regex = Regex::new(
[INFO] [stderr] 521 | |             r"^name\s+(\S.*?)(?:\s+value\s+(.*?))?\s*$").unwrap();
[INFO] [stderr] 522 | |     }
[INFO] [stderr]     | |_____^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/uci.rs:536:5
[INFO] [stderr]     |
[INFO] [stderr] 536 | /     lazy_static! {
[INFO] [stderr] 537 | |         static ref RE: Regex = Regex::new(
[INFO] [stderr] 538 | |             format!(
[INFO] [stderr] 539 | |                 r"^(?:fen\s+(?P<fen>{})|startpos)(?:\s+moves(?P<moves>{}))?\s*$",
[INFO] [stderr] ...   |
[INFO] [stderr] 543 | |         ).unwrap();
[INFO] [stderr] 544 | |     }
[INFO] [stderr]     | |_____^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/uci.rs:564:5
[INFO] [stderr]     |
[INFO] [stderr] 564 | /     lazy_static! {
[INFO] [stderr] 565 | |         static ref RE: Regex = Regex::new(
[INFO] [stderr] 566 | |             format!(
[INFO] [stderr] 567 | |                 r"\b(?P<keyword>{})(?:\s+(?P<number>\d+)|(?P<moves>{}))?(?:\s+|$)",
[INFO] [stderr] ...   |
[INFO] [stderr] 572 | |         ).unwrap();
[INFO] [stderr] 573 | |     }
[INFO] [stderr]     | |_____^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/stock/simple_search.rs:152:30
[INFO] [stderr]     |
[INFO] [stderr] 152 |     report_function: &'a mut FnMut(u64) -> bool,
[INFO] [stderr]     |                              ^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 152 |     report_function: &'a mut dyn FnMut(u64) -> bool,
[INFO] [stderr]     |                              +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/search_node.rs:50:44
[INFO] [stderr]    |
[INFO] [stderr] 50 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stderr]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 50 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stderr]    |                                            +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/uci.rs:244:51
[INFO] [stderr]     |
[INFO] [stderr] 244 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>);
[INFO] [stderr]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 244 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>);
[INFO] [stderr]     |                                                   +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/engine.rs:233:51
[INFO] [stderr]     |
[INFO] [stderr] 233 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>) {
[INFO] [stderr]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 233 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>) {
[INFO] [stderr]     |                                                   +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/stock/simple_search.rs:169:41
[INFO] [stderr]     |
[INFO] [stderr] 169 |                report_function: &'a mut FnMut(u64) -> bool)
[INFO] [stderr]     |                                         ^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 169 |                report_function: &'a mut dyn FnMut(u64) -> bool)
[INFO] [stderr]     |                                         +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/stock/std_search_node.rs:69:44
[INFO] [stderr]    |
[INFO] [stderr] 69 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stderr]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 69 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stderr]    |                                            +++
[INFO] [stderr] 
[INFO] [stderr] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stderr]    --> src/utils/board_geometry.rs:214:63
[INFO] [stderr]     |
[INFO] [stderr] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, &mut BISHOP_MAP, 0, false);
[INFO] [stderr]     |                                                               ^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stderr]     |
[INFO] [stderr]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stderr]     = note: this will be a hard error in the 2024 edition
[INFO] [stderr]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stderr]     = note: `#[warn(static_mut_refs)]` on by default
[INFO] [stderr] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stderr]     |
[INFO] [stderr] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, addr_of_mut!(BISHOP_MAP), 0, false);
[INFO] [stderr]     |                                                               ~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stderr] 
[INFO] [stderr] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stderr]    --> src/utils/board_geometry.rs:215:52
[INFO] [stderr]     |
[INFO] [stderr] 215 |             let total_size = init_slider_map(ROOK, &mut ROOK_MAP, bishop_attacks_size, false);
[INFO] [stderr]     |                                                    ^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stderr]     |
[INFO] [stderr]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stderr]     = note: this will be a hard error in the 2024 edition
[INFO] [stderr]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stderr] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stderr]     |
[INFO] [stderr] 215 |             let total_size = init_slider_map(ROOK, addr_of_mut!(ROOK_MAP), bishop_attacks_size, false);
[INFO] [stderr]     |                                                    ~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stderr] 
[INFO] [stderr] warning: panic message is not a string literal
[INFO] [stderr]    --> src/stock/std_ttable.rs:172:17
[INFO] [stderr]     |
[INFO] [stderr] 172 | /                 format!("too restrictive transposition table entry alignment: {} bytes",
[INFO] [stderr] 173 | |                         mem::align_of::<T>()));
[INFO] [stderr]     | |_____________________________________________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stderr]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stderr]     = note: `#[warn(non_fmt_panics)]` on by default
[INFO] [stderr] help: remove the `format!(..)` macro call
[INFO] [stderr]     |
[INFO] [stderr] 172 ~                 "too restrictive transposition table entry alignment: {} bytes",
[INFO] [stderr] 173 ~                         mem::align_of::<T>());
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: panic message is not a string literal
[INFO] [stderr]    --> src/stock/std_ttable.rs:175:17
[INFO] [stderr]     |
[INFO] [stderr] 175 | /                 format!("too big transposition table entry: {} bytes",
[INFO] [stderr] 176 | |                         mem::size_of::<T>()));
[INFO] [stderr]     | |____________________________________________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stderr]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stderr] help: remove the `format!(..)` macro call
[INFO] [stderr]     |
[INFO] [stderr] 175 ~                 "too big transposition table entry: {} bytes",
[INFO] [stderr] 176 ~                         mem::size_of::<T>());
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: panic message is not a string literal
[INFO] [stderr]    --> src/stock/std_ttable.rs:178:17
[INFO] [stderr]     |
[INFO] [stderr] 178 | /                 format!("too small transposition table entry: {} bytes",
[INFO] [stderr] 179 | |                         mem::size_of::<T>()));
[INFO] [stderr]     | |____________________________________________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stderr]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stderr] help: remove the `format!(..)` macro call
[INFO] [stderr]     |
[INFO] [stderr] 178 ~                 "too small transposition table entry: {} bytes",
[INFO] [stderr] 179 ~                         mem::size_of::<T>());
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: the type `bool` does not permit being left uninitialized
[INFO] [stderr]    --> src/stock/simple_search.rs:355:42
[INFO] [stderr]     |
[INFO] [stderr] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stderr]     |                                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |                                          |
[INFO] [stderr]     |                                          this code causes undefined behavior when executed
[INFO] [stderr]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr]     = note: booleans must be either `true` or `false`
[INFO] [stderr]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: the type `Option<moves::Move>` does not permit being left uninitialized
[INFO] [stderr]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stderr]     |
[INFO] [stderr] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stderr]     |                                           ^^^^^^^^^^^^^^^
[INFO] [stderr]     |                                           |
[INFO] [stderr]     |                                           this code causes undefined behavior when executed
[INFO] [stderr]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stderr]    --> /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/option.rs:571:1
[INFO] [stderr] 
[INFO] [stderr] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stderr]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stderr]     |
[INFO] [stderr] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stderr]     |                                                    ^^^^^^^^^^^^^^^
[INFO] [stderr]     |                                                    |
[INFO] [stderr]     |                                                    this code causes undefined behavior when executed
[INFO] [stderr]     |                                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr]     = note: integers must be initialized
[INFO] [stderr] 
[INFO] [stderr] warning: the type `u64` does not permit being left uninitialized
[INFO] [stderr]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stderr]     |
[INFO] [stderr] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stderr]     |                                          ^^^^^^^^^^^^^^^
[INFO] [stderr]     |                                          |
[INFO] [stderr]     |                                          this code causes undefined behavior when executed
[INFO] [stderr]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr]     = note: integers must be initialized
[INFO] [stderr] 
[INFO] [stderr] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stderr]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stderr]     |
[INFO] [stderr] 870 |             dest_sets = uninitialized();
[INFO] [stderr]     |                         ^^^^^^^^^^^^^^^
[INFO] [stderr]     |                         |
[INFO] [stderr]     |                         this code causes undefined behavior when executed
[INFO] [stderr]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr]     = note: integers must be initialized
[INFO] [stderr] 
[INFO] [stderr] warning: the type `[i16; 34]` does not permit being left uninitialized
[INFO] [stderr]    --> src/move_generator.rs:206:41
[INFO] [stderr]     |
[INFO] [stderr] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stderr]     |                                         ^^^^^^^^^^^^^^^
[INFO] [stderr]     |                                         |
[INFO] [stderr]     |                                         this code causes undefined behavior when executed
[INFO] [stderr]     |                                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr]     = note: integers must be initialized
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]     --> src/stock/std_move_generator.rs:1253:42
[INFO] [stderr]      |
[INFO] [stderr] 1253 |             StdMoveGenerator::from_board(try!(Board::from_fen(fen)))
[INFO] [stderr]      |                                          ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/stock/std_ttable.rs:443:17
[INFO] [stderr]     |
[INFO] [stderr] 443 |             let mut record = b.get(0).as_mut().unwrap();
[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: variable does not need to be mutable
[INFO] [stderr]    --> src/stock/std_ttable.rs:464:17
[INFO] [stderr]     |
[INFO] [stderr] 464 |             let mut record = b.get(4).as_mut().unwrap();
[INFO] [stderr]     |                 ----^^^^^^
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: `alcibiades` (lib) generated 84 warnings (1 duplicate) (run `cargo fix --lib -p alcibiades` to apply 18 suggestions)
[INFO] [stderr] warning: `alcibiades` (lib test) generated 87 warnings (84 duplicates) (run `cargo fix --lib -p alcibiades --tests` to apply 2 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.02s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/alcibiades-13063b2b96d9d730)
[INFO] [stdout] 
[INFO] [stdout] running 41 tests
[INFO] [stdout] test bitsets::tests::bitsets ... ok
[INFO] [stdout] test board::tests::castling_rights ... ok
[INFO] [stdout] test moves::tests::moves ... ok
[INFO] [stdout] test stock::std_move_generator::tests::piece_type_constants ... ok
[INFO] [stderr] thread 'stock::std_move_generator::tests::move_into_check_bug' panicked at library/core/src/panicking.rs:219:5:
[INFO] [stderr] attempted to leave type `core::option::Option<moves::Move>` uninitialized, which is invalid
[INFO] [stderr] stack backtrace:
[INFO] [stderr]    0:     0x558b1cf15065 - std::backtrace_rs::backtrace::libunwind::trace::h59d96bdb08384354
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/../../backtrace/src/backtrace/libunwind.rs:105:5
[INFO] [stderr]    1:     0x558b1cf15065 - std::backtrace_rs::backtrace::trace_unsynchronized::h9cf5becacfc93fba
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/../../backtrace/src/backtrace/mod.rs:66:5
[INFO] [stderr]    2:     0x558b1cf15065 - std::sys_common::backtrace::_print_fmt::h10b76d10405dbd48
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/sys_common/backtrace.rs:68:5
[INFO] [stderr]    3:     0x558b1cf15065 - <std::sys_common::backtrace::_print::DisplayBacktrace as core::fmt::Display>::fmt::h6ed9e62a156d84e4
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/sys_common/backtrace.rs:44:22
[INFO] [stderr]    4:     0x558b1cf3ba3b - core::fmt::rt::Argument::fmt::h645c680983f03c9f
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/fmt/rt.rs:165:63
[INFO] [stderr]    5:     0x558b1cf3ba3b - core::fmt::write::h8bcd80919a02be29
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/fmt/mod.rs:1169:21
[INFO] [stderr]    6:     0x558b1cf1294f - std::io::Write::write_fmt::hed769ca6c29434ec
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/io/mod.rs:1835:15
[INFO] [stderr]    7:     0x558b1cf14e3e - std::sys_common::backtrace::_print::h6306f131a28d62b0
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/sys_common/backtrace.rs:47:5
[INFO] [stderr]    8:     0x558b1cf14e3e - std::sys_common::backtrace::print::h7079288e0a26dfcc
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/sys_common/backtrace.rs:34:9
[INFO] [stderr]    9:     0x558b1cf16869 - std::panicking::default_hook::{{closure}}::hb063ecec81a736ba
[INFO] [stderr]   10:     0x558b1cf165ad - std::panicking::default_hook::hd56ee406bf547b5c
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/panicking.rs:298:9
[INFO] [stderr]   11:     0x558b1cdbf61a - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::he5eacdef44c8728f
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/alloc/src/boxed.rs:2036:9
[INFO] [stderr]   12:     0x558b1cdbf61a - test::test_main::{{closure}}::h0ec9aed229e79095
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/test/src/lib.rs:137:21
[INFO] [stderr]   13:     0x558b1cf16e6b - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hcbd0d80e1ad4e4f9
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/alloc/src/boxed.rs:2036:9
[INFO] [stderr]   14:     0x558b1cf16e6b - std::panicking::rust_panic_with_hook::h624aa3ca42ebb8f2
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/panicking.rs:799:13
[INFO] [stderr]   15:     0x558b1cf16bab - std::panicking::begin_panic_handler::{{closure}}::hbc4e76194a5e287c
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/panicking.rs:656:13
[INFO] [stderr]   16:     0x558b1cf15529 - std::sys_common::backtrace::__rust_end_short_backtrace::h847fedc9d1ff7b6d
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/sys_common/backtrace.rs:171:18
[INFO] [stderr]   17:     0x558b1cf16917 - rust_begin_unwind
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/panicking.rs:652:5
[INFO] [stderr]   18:     0x558b1cd3ce40 - core::panicking::panic_nounwind_fmt::runtime::h4b9f1774825d29a1
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/panicking.rs:110:18
[INFO] [stderr]   19:     0x558b1cd3ce40 - core::panicking::panic_nounwind_fmt::h7f70629ab29f76f1
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/panicking.rs:120:5
[INFO] [stderr]   20:     0x558b1cd3ced2 - core::panicking::panic_nounwind::hde0018e2d22904b7
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/panicking.rs:219:5
[INFO] [stderr]   21:     0x558b1cd47b2f - core::mem::uninitialized::hcbea9f577626677b
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/mem/mod.rs:693:9
[INFO] [stderr]   22:     0x558b1cd47b2f - <alcibiades::stock::std_move_generator::StdMoveGenerator<T> as alcibiades::move_generator::MoveGenerator>::try_move_digest::h311e2214f60e40f6
[INFO] [stderr]                                at /opt/rustwide/workdir/src/stock/std_move_generator.rs:299:43
[INFO] [stderr]   23:     0x558b1cd497c7 - <alcibiades::stock::std_move_generator::StdMoveGenerator<T> as alcibiades::move_generator::MoveGenerator>::do_move::ha229e484e2bb41d9
[INFO] [stderr]                                at /opt/rustwide/workdir/src/stock/std_move_generator.rs:517:38
[INFO] [stderr]   24:     0x558b1cd8a8ac - alcibiades::stock::std_move_generator::tests::move_into_check_bug::ha43ef456d029a7d9
[INFO] [stderr]                                at /opt/rustwide/workdir/src/stock/std_move_generator.rs:1592:9
[INFO] [stderr]   25:     0x558b1cd8a747 - alcibiades::stock::std_move_generator::tests::move_into_check_bug::{{closure}}::hf1d3299abac02160
[INFO] [stderr]                                at /opt/rustwide/workdir/src/stock/std_move_generator.rs:1586:29
[INFO] [stderr]   26:     0x558b1cd7d2a6 - core::ops::function::FnOnce::call_once::h8b1b9bea3cf48d62
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/ops/function.rs:250:5
[INFO] [stderr]   27:     0x558b1cdc3ffb - core::ops::function::FnOnce::call_once::h2e43a8f6f3d94b99
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/ops/function.rs:250:5
[INFO] [stderr]   28:     0x558b1cdc3ffb - test::__rust_begin_short_backtrace::h214c9f2d2d3fee90
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/test/src/lib.rs:625:18
[INFO] [stderr]   29:     0x558b1cdc3701 - test::run_test_in_process::{{closure}}::h510b7ba7990692a5
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/test/src/lib.rs:648:60
[INFO] [stderr]   30:     0x558b1cdc3701 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h4157186197a93871
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stderr]   31:     0x558b1cdc3701 - std::panicking::try::do_call::h1bf2463bccd4b28c
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/panicking.rs:559:40
[INFO] [stderr]   32:     0x558b1cdc3701 - std::panicking::try::hd6d4808c9fab4fa5
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/panicking.rs:523:19
[INFO] [stderr]   33:     0x558b1cdc3701 - std::panic::catch_unwind::hd5641d97d123f9f2
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/panic.rs:149:14
[INFO] [stderr]   34:     0x558b1cdc3701 - test::run_test_in_process::hc273b71c8b878a4c
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/test/src/lib.rs:648:27
[INFO] [stderr]   35:     0x558b1cdc3701 - test::run_test::{{closure}}::h6838df834eb8467e
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/test/src/lib.rs:569:43
[INFO] [stderr]   36:     0x558b1cd8c0c4 - test::run_test::{{closure}}::h608b98ecff5665fb
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/test/src/lib.rs:599:41
[INFO] [stderr]   37:     0x558b1cd8c0c4 - std::sys_common::backtrace::__rust_begin_short_backtrace::hdc4182b97d1042e9
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/sys_common/backtrace.rs:155:18
[INFO] [stderr]   38:     0x558b1cd90af2 - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h571773fd21d674c8
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/thread/mod.rs:542:17
[INFO] [stderr]   39:     0x558b1cd90af2 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hdcd384cf2fa70ba3
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stderr]   40:     0x558b1cd90af2 - std::panicking::try::do_call::h4f1a44bd81423be1
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/panicking.rs:559:40
[INFO] [stderr]   41:     0x558b1cd90af2 - std::panicking::try::h5e02afcb81dcd361
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/panicking.rs:523:19
[INFO] [stderr]   42:     0x558b1cd90af2 - std::panic::catch_unwind::h022f75775bfd8c45
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/panic.rs:149:14
[INFO] [stderr]   43:     0x558b1cd90af2 - std::thread::Builder::spawn_unchecked_::{{closure}}::hf5a62e9e4e6df1f8
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/thread/mod.rs:541:30
[INFO] [stderr]   44:     0x558b1cd90af2 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h6d56360aeb9509a7
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/core/src/ops/function.rs:250:5
[INFO] [stderr]   45:     0x558b1cf1b16b - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h7a343dc551c06baa
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/alloc/src/boxed.rs:2022:9
[INFO] [stderr]   46:     0x558b1cf1b16b - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h30b8111cbaa644f3
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/alloc/src/boxed.rs:2022:9
[INFO] [stderr]   47:     0x558b1cf1b16b - std::sys::pal::unix::thread::Thread::new::thread_start::h7404e134e61e7a11
[INFO] [stderr]                                at /rustc/1871252fc8bb672d40787e67404e6eaae7059369/library/std/src/sys/pal/unix/thread.rs:108:17
[INFO] [stderr]   48:     0x7f16d41d5ac3 - <unknown>
[INFO] [stderr]   49:     0x7f16d4266a04 - __clone
[INFO] [stderr]   50:                0x0 - <unknown>
[INFO] [stderr] thread caused non-unwinding panic. aborting.
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] [stderr] 
[INFO] [stderr] Caused by:
[INFO] [stderr]   process didn't exit successfully: `/opt/rustwide/target/debug/deps/alcibiades-13063b2b96d9d730` (signal: 6, SIGABRT: process abort signal)
[INFO] running `Command { std: "docker" "inspect" "7652f4ef79e1f7bc8d38ea69e5dc629ba9c5e3326704db0b181d169867adf554", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7652f4ef79e1f7bc8d38ea69e5dc629ba9c5e3326704db0b181d169867adf554", kill_on_drop: false }`
[INFO] [stdout] 7652f4ef79e1f7bc8d38ea69e5dc629ba9c5e3326704db0b181d169867adf554
[INFO] testing alcibiades-0.3.0 against try#b642703cf9526da1e72c0b6755753b939a9c6b6d for pr-125151
[INFO] extracting crate alcibiades 0.3.0 into /workspace/builds/worker-4-tc2/source
[INFO] validating manifest of crates.io crate alcibiades 0.3.0 on toolchain b642703cf9526da1e72c0b6755753b939a9c6b6d
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b642703cf9526da1e72c0b6755753b939a9c6b6d" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate alcibiades 0.3.0
[INFO] finished tweaking crates.io crate alcibiades 0.3.0
[INFO] tweaked toml for crates.io crate alcibiades 0.3.0 written to /workspace/builds/worker-4-tc2/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b642703cf9526da1e72c0b6755753b939a9c6b6d" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 20 packages to latest compatible versions
[INFO] [stderr]       Adding aho-corasick v0.6.10 (latest: v1.1.3)
[INFO] [stderr]       Adding lazy_static v0.2.11 (latest: v1.4.0)
[INFO] [stderr]       Adding rand v0.3.23 (latest: v0.8.5)
[INFO] [stderr]       Adding rand v0.4.6 (latest: v0.8.5)
[INFO] [stderr]       Adding rand_core v0.3.1 (latest: v0.6.4)
[INFO] [stderr]       Adding rand_core v0.4.2 (latest: v0.6.4)
[INFO] [stderr]       Adding rdrand v0.4.0 (latest: v0.8.3)
[INFO] [stderr]       Adding regex v0.2.11 (latest: v1.10.4)
[INFO] [stderr]       Adding regex-syntax v0.5.6 (latest: v0.8.3)
[INFO] [stderr]       Adding thread_local v0.3.6 (latest: v1.1.8)
[INFO] [stderr]       Adding ucd-util v0.1.10 (latest: v0.2.1)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b642703cf9526da1e72c0b6755753b939a9c6b6d" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:59a85a07ab18ca8720692f8e61effa1c651d9e2ca591e072c2b212bb91a6b8b5" "/opt/rustwide/cargo-home/bin/cargo" "+b642703cf9526da1e72c0b6755753b939a9c6b6d" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 45b0a80eae6a913c41b81586ebda5d87b500788cf090a95042b5cd2bda1d0a8f
[INFO] running `Command { std: "docker" "start" "-a" "45b0a80eae6a913c41b81586ebda5d87b500788cf090a95042b5cd2bda1d0a8f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "45b0a80eae6a913c41b81586ebda5d87b500788cf090a95042b5cd2bda1d0a8f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "45b0a80eae6a913c41b81586ebda5d87b500788cf090a95042b5cd2bda1d0a8f", kill_on_drop: false }`
[INFO] [stdout] 45b0a80eae6a913c41b81586ebda5d87b500788cf090a95042b5cd2bda1d0a8f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:59a85a07ab18ca8720692f8e61effa1c651d9e2ca591e072c2b212bb91a6b8b5" "/opt/rustwide/cargo-home/bin/cargo" "+b642703cf9526da1e72c0b6755753b939a9c6b6d" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f99db2ee1fc9651f962263e7355cf94c828303b88351a4f0143939eb02ad23df
[INFO] running `Command { std: "docker" "start" "-a" "f99db2ee1fc9651f962263e7355cf94c828303b88351a4f0143939eb02ad23df", kill_on_drop: false }`
[INFO] [stderr]    Compiling regex v0.2.11
[INFO] [stderr]    Compiling memchr v2.7.2
[INFO] [stderr]    Compiling ucd-util v0.1.10
[INFO] [stderr]    Compiling utf8-ranges v1.0.5
[INFO] [stderr]    Compiling thread_local v0.3.6
[INFO] [stderr]    Compiling rand v0.3.23
[INFO] [stderr]    Compiling lazy_static v0.2.11
[INFO] [stderr]    Compiling regex-syntax v0.5.6
[INFO] [stderr]    Compiling aho-corasick v0.6.10
[INFO] [stderr]    Compiling alcibiades v0.3.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:55:22
[INFO] [stdout]    |
[INFO] [stdout] 55 |         let pieces = try!(parse_fen_piece_placement(fileds[0]));
[INFO] [stdout]    |                      ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:56:23
[INFO] [stdout]    |
[INFO] [stdout] 56 |         let to_move = try!(parse_fen_active_color(fileds[1]));
[INFO] [stdout]    |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:57:31
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let castling_rights = try!(parse_fen_castling_rights(fileds[2]));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:58:47
[INFO] [stdout]    |
[INFO] [stdout] 58 |         let enpassant_file = if let Some(x) = try!(parse_fen_enpassant_square(fileds[3])) {
[INFO] [stdout]    |                                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:67:30
[INFO] [stdout]    |
[INFO] [stdout] 67 |         let halfmove_clock = try!(fileds[4].parse::<u8>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:68:31
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let fullmove_number = try!(fileds[5].parse::<u16>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]   --> src/utils/notation.rs:69:17
[INFO] [stdout]    |
[INFO] [stdout] 69 |         if let 1...9000 = fullmove_number {
[INFO] [stdout]    |                 ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/utils/notation.rs:134:20
[INFO] [stdout]     |
[INFO] [stdout] 134 |             n @ '1'...'8' => Token::EmptySquares(n.to_digit(9).unwrap()),
[INFO] [stdout]     |                    ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/stock/std_ttable.rs:213:31
[INFO] [stdout]     |
[INFO] [stdout] 213 |                          n @ 1...30 => n + 1,
[INFO] [stdout]     |                               ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:226:26
[INFO] [stdout]     |
[INFO] [stdout] 226 |         if let Some(v) = try!(self.node_begin(alpha, beta, depth, last_move)) {
[INFO] [stdout]     |                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:238:17
[INFO] [stdout]     |
[INFO] [stdout] 238 |                 try!(self.report_progress(1));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:246:22
[INFO] [stdout]     |
[INFO] [stdout] 246 |                     -try!(self.run(-beta, -alpha, depth - 1, m))
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:255:28
[INFO] [stdout]     |
[INFO] [stdout] 255 |                     match -try!(self.run(-alpha - 1, -alpha, depth - 2, m)) {
[INFO] [stdout]     |                            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:257:31
[INFO] [stdout]     |
[INFO] [stdout] 257 |                         _ => -try!(self.run(-beta, -alpha, depth - 1, m)),
[INFO] [stdout]     |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:373:13
[INFO] [stdout]     |
[INFO] [stdout] 373 |             try!(self.report_progress(result.searched_nodes()));
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:425:30
[INFO] [stdout]     |
[INFO] [stdout] 425 |                 let value = -try!(self.run(-beta, -alpha, max(0, reduced_depth - 1), m));
[INFO] [stdout]     |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/stock/std_search_node.rs:70:39
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut p: StdSearchNode<T> = try!(StdSearchNode::from_fen(fen));
[INFO] [stdout]    |                                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:317:56
[INFO] [stdout]     |
[INFO] [stdout] 317 |         let (board, halfmove_clock, fullmove_number) = try!(parse_fen(fen));
[INFO] [stdout]     |                                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:318:19
[INFO] [stdout]     |
[INFO] [stdout] 318 |         let gen = try!(T::MoveGenerator::from_board(board));
[INFO] [stdout]     |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/aspiration.rs:107:13
[INFO] [stdout]     |
[INFO] [stdout] 107 |         } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/multipv.rs:118:17
[INFO] [stdout]     |
[INFO] [stdout] 118 |             } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/mod.rs:125:13
[INFO] [stdout]     |
[INFO] [stdout] 125 |         } = try!(self.multipv.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:150:27
[INFO] [stdout]     |
[INFO] [stdout] 150 |         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 150 -         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout] 150 +         const WQ: usize = 1 << (WHITE << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:151:27
[INFO] [stdout]     |
[INFO] [stdout] 151 |         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 151 -         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout] 151 +         const WK: usize = 1 << (WHITE << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:153:27
[INFO] [stdout]     |
[INFO] [stdout] 153 |         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 153 -         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout] 153 +         const BQ: usize = 1 << (BLACK << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:154:27
[INFO] [stdout]     |
[INFO] [stdout] 154 |         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout] 154 +         const BK: usize = 1 << (BLACK << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/board.rs:189:17
[INFO] [stdout]     |
[INFO] [stdout] 189 |                 try!(f.write_str(s));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:280:22
[INFO] [stdout]     |
[INFO] [stdout] 280 |     let mut server = try!(Server::<E>::wait_for_hanshake());
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:313:9
[INFO] [stdout]     |
[INFO] [stdout] 313 |         try!(write!(writer, "id name {}\n", E::name()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:314:9
[INFO] [stdout]     |
[INFO] [stdout] 314 |         try!(write!(writer, "id author {}\n", E::author()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:342:9
[INFO] [stdout]     |
[INFO] [stdout] 342 |         try!(write!(writer, "uciok\n"));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:343:9
[INFO] [stdout]     |
[INFO] [stdout] 343 |         try!(writer.flush());
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:307:12
[INFO] [stdout]     |
[INFO] [stdout] 307 |         if try!(reader.read_line(&mut line)) == 0 {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:316:13
[INFO] [stdout]     |
[INFO] [stdout] 316 |             try!(write!(writer,
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:361:40
[INFO] [stdout]     |
[INFO] [stdout] 361 |                 if let Ok(cmd) = match try!(reader.read_line(&mut line)) {
[INFO] [stdout]     |                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:405:25
[INFO] [stdout]     |
[INFO] [stdout] 405 |                         try!(write!(writer, "readyok\n"));
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:406:25
[INFO] [stdout]     |
[INFO] [stdout] 406 |                         try!(writer.flush());
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:469:17
[INFO] [stdout]     |
[INFO] [stdout] 469 |                 try!(writer.flush());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:444:29
[INFO] [stdout]     |
[INFO] [stdout] 444 | ...                   try!(write!(writer,
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:454:33
[INFO] [stdout]     |
[INFO] [stdout] 454 | ...                   try!(write!(writer, "info"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:458:33
[INFO] [stdout]     |
[INFO] [stdout] 458 | ...                   try!(write!(writer, "\n"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:456:37
[INFO] [stdout]     |
[INFO] [stdout] 456 | ...                   try!(write!(writer, " {} {}", info_type, data));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/lib.rs:127:1
[INFO] [stdout]     |
[INFO] [stdout] 127 | / lazy_static! {
[INFO] [stdout] 128 | |     static ref CONFIGURATION: RwLock<HashMap<&'static str, String>> = RwLock::new(HashMap::new());
[INFO] [stdout] 129 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:228:31
[INFO] [stdout]     |
[INFO] [stdout] 228 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]     |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:229:38
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = ONCE_INIT;
[INFO] [stdout]     |                                      ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = Once::new();
[INFO] [stdout]     |                                      ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]    |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:88:36
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = ONCE_INIT;
[INFO] [stdout]    |                                    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = Once::new();
[INFO] [stdout]    |                                    ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/notation.rs:87:5
[INFO] [stdout]    |
[INFO] [stdout] 87 | /     lazy_static! {
[INFO] [stdout] 88 | |         static ref RE: Regex = Regex::new(r"^[a-h][1-8]$").unwrap();
[INFO] [stdout] 89 | |     }
[INFO] [stdout]    | |_____^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/simple_search.rs:355:47
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/stock/std_move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/stock/std_move_generator.rs:37:33
[INFO] [stdout]    |
[INFO] [stdout] 37 |             evaluator: unsafe { uninitialized() },
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/std_time_manager.rs:175:1
[INFO] [stdout]     |
[INFO] [stdout] 175 | / lazy_static! {
[INFO] [stdout] 176 | |     static ref AVG_SLOPE: RwLock<f64> = RwLock::new(0.7);
[INFO] [stdout] 177 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/deepening/mod.rs:160:9
[INFO] [stdout]     |
[INFO] [stdout] 160 | /         lazy_static! {
[INFO] [stdout] 161 | |             static ref RE: Regex = Regex::new(r"^TARGET_DEPTH=([-+]?\d+)$").unwrap();
[INFO] [stdout] 162 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/moves.rs:387:5
[INFO] [stdout]     |
[INFO] [stdout] 387 | /     lazy_static! {
[INFO] [stdout] 388 | |         static ref NOTATION: Vec<String> = (0..64).map(|i| format!("{}{}",
[INFO] [stdout] 389 | |             ["a", "b", "c", "d", "e", "f", "g", "h"][Board::file(i)],
[INFO] [stdout] 390 | |             ["1", "2", "3", "4", "5", "6", "7", "8"][Board::rank(i)])
[INFO] [stdout] 391 | |         ).collect();
[INFO] [stdout] 392 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:300:9
[INFO] [stdout]     |
[INFO] [stdout] 300 | /         lazy_static! {
[INFO] [stdout] 301 | |             static ref RE: Regex = Regex::new(r"\buci(?:\s|$)").unwrap();
[INFO] [stdout] 302 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 490 | /     lazy_static! {
[INFO] [stdout] 491 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 492 | |             format!(r"\b({})\s*(?:\s(.*)|$)",
[INFO] [stdout] 493 | |                     "setoption|isready|ucinewgame|\
[INFO] [stdout] ...   |
[INFO] [stdout] 496 | |         ).unwrap();
[INFO] [stdout] 497 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:519:5
[INFO] [stdout]     |
[INFO] [stdout] 519 | /     lazy_static! {
[INFO] [stdout] 520 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 521 | |             r"^name\s+(\S.*?)(?:\s+value\s+(.*?))?\s*$").unwrap();
[INFO] [stdout] 522 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:536:5
[INFO] [stdout]     |
[INFO] [stdout] 536 | /     lazy_static! {
[INFO] [stdout] 537 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 538 | |             format!(
[INFO] [stdout] 539 | |                 r"^(?:fen\s+(?P<fen>{})|startpos)(?:\s+moves(?P<moves>{}))?\s*$",
[INFO] [stdout] ...   |
[INFO] [stdout] 543 | |         ).unwrap();
[INFO] [stdout] 544 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:564:5
[INFO] [stdout]     |
[INFO] [stdout] 564 | /     lazy_static! {
[INFO] [stdout] 565 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 566 | |             format!(
[INFO] [stdout] 567 | |                 r"\b(?P<keyword>{})(?:\s+(?P<number>\d+)|(?P<moves>{}))?(?:\s+|$)",
[INFO] [stdout] ...   |
[INFO] [stdout] 572 | |         ).unwrap();
[INFO] [stdout] 573 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:152:30
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut FnMut(u64) -> bool,
[INFO] [stdout]     |                              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut dyn FnMut(u64) -> bool,
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/search_node.rs:50:44
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/uci.rs:244:51
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>);
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>);
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/engine.rs:233:51
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:169:41
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut FnMut(u64) -> bool)
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut dyn FnMut(u64) -> bool)
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/stock/std_search_node.rs:69:44
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:214:63
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, &mut BISHOP_MAP, 0, false);
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` on by default
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, addr_of_mut!(BISHOP_MAP), 0, false);
[INFO] [stdout]     |                                                               ~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:215:52
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, &mut ROOK_MAP, bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, addr_of_mut!(ROOK_MAP), bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:172:17
[INFO] [stdout]     |
[INFO] [stdout] 172 | /                 format!("too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 | |                         mem::align_of::<T>()));
[INFO] [stdout]     | |_____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` on by default
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 172 ~                 "too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 ~                         mem::align_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:175:17
[INFO] [stdout]     |
[INFO] [stdout] 175 | /                 format!("too big transposition table entry: {} bytes",
[INFO] [stdout] 176 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 175 ~                 "too big transposition table entry: {} bytes",
[INFO] [stdout] 176 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:178:17
[INFO] [stdout]     |
[INFO] [stdout] 178 | /                 format!("too small transposition table entry: {} bytes",
[INFO] [stdout] 179 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 178 ~                 "too small transposition table entry: {} bytes",
[INFO] [stdout] 179 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `bool` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/simple_search.rs:355:42
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: booleans must be either `true` or `false`
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Option<moves::Move>` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                           |
[INFO] [stdout]     |                                           this code causes undefined behavior when executed
[INFO] [stdout]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]    --> /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/option.rs:571:1
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                    |
[INFO] [stdout]     |                                                    this code causes undefined behavior when executed
[INFO] [stdout]     |                                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         this code causes undefined behavior when executed
[INFO] [stdout]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[i16; 34]` does not permit being left uninitialized
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         this code causes undefined behavior when executed
[INFO] [stdout]     |                                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 84 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2.28s
[INFO] running `Command { std: "docker" "inspect" "f99db2ee1fc9651f962263e7355cf94c828303b88351a4f0143939eb02ad23df", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f99db2ee1fc9651f962263e7355cf94c828303b88351a4f0143939eb02ad23df", kill_on_drop: false }`
[INFO] [stdout] f99db2ee1fc9651f962263e7355cf94c828303b88351a4f0143939eb02ad23df
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:59a85a07ab18ca8720692f8e61effa1c651d9e2ca591e072c2b212bb91a6b8b5" "/opt/rustwide/cargo-home/bin/cargo" "+b642703cf9526da1e72c0b6755753b939a9c6b6d" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 8383fdcbac84298e94a0bb18ee6796339d405c0067d0be746f94a513c124eba4
[INFO] running `Command { std: "docker" "start" "-a" "8383fdcbac84298e94a0bb18ee6796339d405c0067d0be746f94a513c124eba4", kill_on_drop: false }`
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:55:22
[INFO] [stdout]    |
[INFO] [stdout] 55 |         let pieces = try!(parse_fen_piece_placement(fileds[0]));
[INFO] [stdout]    |                      ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:56:23
[INFO] [stdout]    |
[INFO] [stdout] 56 |         let to_move = try!(parse_fen_active_color(fileds[1]));
[INFO] [stdout]    |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:57:31
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let castling_rights = try!(parse_fen_castling_rights(fileds[2]));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:58:47
[INFO] [stdout]    |
[INFO] [stdout] 58 |         let enpassant_file = if let Some(x) = try!(parse_fen_enpassant_square(fileds[3])) {
[INFO] [stdout]    |                                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:67:30
[INFO] [stdout]    |
[INFO] [stdout] 67 |         let halfmove_clock = try!(fileds[4].parse::<u8>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:68:31
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let fullmove_number = try!(fileds[5].parse::<u16>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]   --> src/utils/notation.rs:69:17
[INFO] [stdout]    |
[INFO] [stdout] 69 |         if let 1...9000 = fullmove_number {
[INFO] [stdout]    |                 ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/utils/notation.rs:134:20
[INFO] [stdout]     |
[INFO] [stdout] 134 |             n @ '1'...'8' => Token::EmptySquares(n.to_digit(9).unwrap()),
[INFO] [stdout]     |                    ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/stock/std_ttable.rs:213:31
[INFO] [stdout]     |
[INFO] [stdout] 213 |                          n @ 1...30 => n + 1,
[INFO] [stdout]     |                               ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:226:26
[INFO] [stdout]     |
[INFO] [stdout] 226 |         if let Some(v) = try!(self.node_begin(alpha, beta, depth, last_move)) {
[INFO] [stdout]     |                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:238:17
[INFO] [stdout]     |
[INFO] [stdout] 238 |                 try!(self.report_progress(1));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:246:22
[INFO] [stdout]     |
[INFO] [stdout] 246 |                     -try!(self.run(-beta, -alpha, depth - 1, m))
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:255:28
[INFO] [stdout]     |
[INFO] [stdout] 255 |                     match -try!(self.run(-alpha - 1, -alpha, depth - 2, m)) {
[INFO] [stdout]     |                            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:257:31
[INFO] [stdout]     |
[INFO] [stdout] 257 |                         _ => -try!(self.run(-beta, -alpha, depth - 1, m)),
[INFO] [stdout]     |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:373:13
[INFO] [stdout]     |
[INFO] [stdout] 373 |             try!(self.report_progress(result.searched_nodes()));
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:425:30
[INFO] [stdout]     |
[INFO] [stdout] 425 |                 let value = -try!(self.run(-beta, -alpha, max(0, reduced_depth - 1), m));
[INFO] [stdout]     |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/stock/std_search_node.rs:70:39
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut p: StdSearchNode<T> = try!(StdSearchNode::from_fen(fen));
[INFO] [stdout]    |                                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:317:56
[INFO] [stdout]     |
[INFO] [stdout] 317 |         let (board, halfmove_clock, fullmove_number) = try!(parse_fen(fen));
[INFO] [stdout]     |                                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:318:19
[INFO] [stdout]     |
[INFO] [stdout] 318 |         let gen = try!(T::MoveGenerator::from_board(board));
[INFO] [stdout]     |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/aspiration.rs:107:13
[INFO] [stdout]     |
[INFO] [stdout] 107 |         } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/multipv.rs:118:17
[INFO] [stdout]     |
[INFO] [stdout] 118 |             } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/mod.rs:125:13
[INFO] [stdout]     |
[INFO] [stdout] 125 |         } = try!(self.multipv.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:150:27
[INFO] [stdout]     |
[INFO] [stdout] 150 |         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 150 -         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout] 150 +         const WQ: usize = 1 << (WHITE << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:151:27
[INFO] [stdout]     |
[INFO] [stdout] 151 |         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 151 -         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout] 151 +         const WK: usize = 1 << (WHITE << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:153:27
[INFO] [stdout]     |
[INFO] [stdout] 153 |         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 153 -         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout] 153 +         const BQ: usize = 1 << (BLACK << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:154:27
[INFO] [stdout]     |
[INFO] [stdout] 154 |         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout] 154 +         const BK: usize = 1 << (BLACK << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/board.rs:189:17
[INFO] [stdout]     |
[INFO] [stdout] 189 |                 try!(f.write_str(s));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:280:22
[INFO] [stdout]     |
[INFO] [stdout] 280 |     let mut server = try!(Server::<E>::wait_for_hanshake());
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:313:9
[INFO] [stdout]     |
[INFO] [stdout] 313 |         try!(write!(writer, "id name {}\n", E::name()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:314:9
[INFO] [stdout]     |
[INFO] [stdout] 314 |         try!(write!(writer, "id author {}\n", E::author()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:342:9
[INFO] [stdout]     |
[INFO] [stdout] 342 |         try!(write!(writer, "uciok\n"));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:343:9
[INFO] [stdout]     |
[INFO] [stdout] 343 |         try!(writer.flush());
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:307:12
[INFO] [stdout]     |
[INFO] [stdout] 307 |         if try!(reader.read_line(&mut line)) == 0 {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:316:13
[INFO] [stdout]     |
[INFO] [stdout] 316 |             try!(write!(writer,
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:361:40
[INFO] [stdout]     |
[INFO] [stdout] 361 |                 if let Ok(cmd) = match try!(reader.read_line(&mut line)) {
[INFO] [stdout]     |                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:405:25
[INFO] [stdout]     |
[INFO] [stdout] 405 |                         try!(write!(writer, "readyok\n"));
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:406:25
[INFO] [stdout]     |
[INFO] [stdout] 406 |                         try!(writer.flush());
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:469:17
[INFO] [stdout]     |
[INFO] [stdout] 469 |                 try!(writer.flush());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:444:29
[INFO] [stdout]     |
[INFO] [stdout] 444 | ...                   try!(write!(writer,
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:454:33
[INFO] [stdout]     |
[INFO] [stdout] 454 | ...                   try!(write!(writer, "info"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:458:33
[INFO] [stdout]     |
[INFO] [stdout] 458 | ...                   try!(write!(writer, "\n"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:456:37
[INFO] [stdout]     |
[INFO] [stdout] 456 | ...                   try!(write!(writer, " {} {}", info_type, data));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/lib.rs:127:1
[INFO] [stdout]     |
[INFO] [stdout] 127 | / lazy_static! {
[INFO] [stdout] 128 | |     static ref CONFIGURATION: RwLock<HashMap<&'static str, String>> = RwLock::new(HashMap::new());
[INFO] [stdout] 129 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:228:31
[INFO] [stdout]     |
[INFO] [stdout] 228 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]     |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:229:38
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = ONCE_INIT;
[INFO] [stdout]     |                                      ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = Once::new();
[INFO] [stdout]     |                                      ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]    |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:88:36
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = ONCE_INIT;
[INFO] [stdout]    |                                    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = Once::new();
[INFO] [stdout]    |                                    ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/notation.rs:87:5
[INFO] [stdout]    |
[INFO] [stdout] 87 | /     lazy_static! {
[INFO] [stdout] 88 | |         static ref RE: Regex = Regex::new(r"^[a-h][1-8]$").unwrap();
[INFO] [stdout] 89 | |     }
[INFO] [stdout]    | |_____^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/simple_search.rs:355:47
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/stock/std_move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/stock/std_move_generator.rs:37:33
[INFO] [stdout]    |
[INFO] [stdout] 37 |             evaluator: unsafe { uninitialized() },
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/std_time_manager.rs:175:1
[INFO] [stdout]     |
[INFO] [stdout] 175 | / lazy_static! {
[INFO] [stdout] 176 | |     static ref AVG_SLOPE: RwLock<f64> = RwLock::new(0.7);
[INFO] [stdout] 177 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/deepening/mod.rs:160:9
[INFO] [stdout]     |
[INFO] [stdout] 160 | /         lazy_static! {
[INFO] [stdout] 161 | |             static ref RE: Regex = Regex::new(r"^TARGET_DEPTH=([-+]?\d+)$").unwrap();
[INFO] [stdout] 162 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/moves.rs:387:5
[INFO] [stdout]     |
[INFO] [stdout] 387 | /     lazy_static! {
[INFO] [stdout] 388 | |         static ref NOTATION: Vec<String> = (0..64).map(|i| format!("{}{}",
[INFO] [stdout] 389 | |             ["a", "b", "c", "d", "e", "f", "g", "h"][Board::file(i)],
[INFO] [stdout] 390 | |             ["1", "2", "3", "4", "5", "6", "7", "8"][Board::rank(i)])
[INFO] [stdout] 391 | |         ).collect();
[INFO] [stdout] 392 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:300:9
[INFO] [stdout]     |
[INFO] [stdout] 300 | /         lazy_static! {
[INFO] [stdout] 301 | |             static ref RE: Regex = Regex::new(r"\buci(?:\s|$)").unwrap();
[INFO] [stdout] 302 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 490 | /     lazy_static! {
[INFO] [stdout] 491 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 492 | |             format!(r"\b({})\s*(?:\s(.*)|$)",
[INFO] [stdout] 493 | |                     "setoption|isready|ucinewgame|\
[INFO] [stdout] ...   |
[INFO] [stdout] 496 | |         ).unwrap();
[INFO] [stdout] 497 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:519:5
[INFO] [stdout]     |
[INFO] [stdout] 519 | /     lazy_static! {
[INFO] [stdout] 520 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 521 | |             r"^name\s+(\S.*?)(?:\s+value\s+(.*?))?\s*$").unwrap();
[INFO] [stdout] 522 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:536:5
[INFO] [stdout]     |
[INFO] [stdout] 536 | /     lazy_static! {
[INFO] [stdout] 537 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 538 | |             format!(
[INFO] [stdout] 539 | |                 r"^(?:fen\s+(?P<fen>{})|startpos)(?:\s+moves(?P<moves>{}))?\s*$",
[INFO] [stdout] ...   |
[INFO] [stdout] 543 | |         ).unwrap();
[INFO] [stdout] 544 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:564:5
[INFO] [stdout]     |
[INFO] [stdout] 564 | /     lazy_static! {
[INFO] [stdout] 565 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 566 | |             format!(
[INFO] [stdout] 567 | |                 r"\b(?P<keyword>{})(?:\s+(?P<number>\d+)|(?P<moves>{}))?(?:\s+|$)",
[INFO] [stdout] ...   |
[INFO] [stdout] 572 | |         ).unwrap();
[INFO] [stdout] 573 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:152:30
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut FnMut(u64) -> bool,
[INFO] [stdout]     |                              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut dyn FnMut(u64) -> bool,
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/search_node.rs:50:44
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/uci.rs:244:51
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>);
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>);
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/engine.rs:233:51
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:169:41
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut FnMut(u64) -> bool)
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut dyn FnMut(u64) -> bool)
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/stock/std_search_node.rs:69:44
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:214:63
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, &mut BISHOP_MAP, 0, false);
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` on by default
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, addr_of_mut!(BISHOP_MAP), 0, false);
[INFO] [stdout]     |                                                               ~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:215:52
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, &mut ROOK_MAP, bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, addr_of_mut!(ROOK_MAP), bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:172:17
[INFO] [stdout]     |
[INFO] [stdout] 172 | /                 format!("too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 | |                         mem::align_of::<T>()));
[INFO] [stdout]     | |_____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` on by default
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 172 ~                 "too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 ~                         mem::align_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:175:17
[INFO] [stdout]     |
[INFO] [stdout] 175 | /                 format!("too big transposition table entry: {} bytes",
[INFO] [stdout] 176 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 175 ~                 "too big transposition table entry: {} bytes",
[INFO] [stdout] 176 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:178:17
[INFO] [stdout]     |
[INFO] [stdout] 178 | /                 format!("too small transposition table entry: {} bytes",
[INFO] [stdout] 179 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 178 ~                 "too small transposition table entry: {} bytes",
[INFO] [stdout] 179 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `bool` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/simple_search.rs:355:42
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: booleans must be either `true` or `false`
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Option<moves::Move>` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                           |
[INFO] [stdout]     |                                           this code causes undefined behavior when executed
[INFO] [stdout]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]    --> /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/option.rs:571:1
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                    |
[INFO] [stdout]     |                                                    this code causes undefined behavior when executed
[INFO] [stdout]     |                                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         this code causes undefined behavior when executed
[INFO] [stdout]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[i16; 34]` does not permit being left uninitialized
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         this code causes undefined behavior when executed
[INFO] [stdout]     |                                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling alcibiades v0.3.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: 84 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:55:22
[INFO] [stdout]    |
[INFO] [stdout] 55 |         let pieces = try!(parse_fen_piece_placement(fileds[0]));
[INFO] [stdout]    |                      ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:56:23
[INFO] [stdout]    |
[INFO] [stdout] 56 |         let to_move = try!(parse_fen_active_color(fileds[1]));
[INFO] [stdout]    |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:57:31
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let castling_rights = try!(parse_fen_castling_rights(fileds[2]));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:58:47
[INFO] [stdout]    |
[INFO] [stdout] 58 |         let enpassant_file = if let Some(x) = try!(parse_fen_enpassant_square(fileds[3])) {
[INFO] [stdout]    |                                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:67:30
[INFO] [stdout]    |
[INFO] [stdout] 67 |         let halfmove_clock = try!(fileds[4].parse::<u8>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/utils/notation.rs:68:31
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let fullmove_number = try!(fileds[5].parse::<u16>().map_err(|_| IllegalBoard));
[INFO] [stdout]    |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]   --> src/utils/notation.rs:69:17
[INFO] [stdout]    |
[INFO] [stdout] 69 |         if let 1...9000 = fullmove_number {
[INFO] [stdout]    |                 ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/utils/notation.rs:134:20
[INFO] [stdout]     |
[INFO] [stdout] 134 |             n @ '1'...'8' => Token::EmptySquares(n.to_digit(9).unwrap()),
[INFO] [stdout]     |                    ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/stock/std_ttable.rs:213:31
[INFO] [stdout]     |
[INFO] [stdout] 213 |                          n @ 1...30 => n + 1,
[INFO] [stdout]     |                               ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:226:26
[INFO] [stdout]     |
[INFO] [stdout] 226 |         if let Some(v) = try!(self.node_begin(alpha, beta, depth, last_move)) {
[INFO] [stdout]     |                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:238:17
[INFO] [stdout]     |
[INFO] [stdout] 238 |                 try!(self.report_progress(1));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:246:22
[INFO] [stdout]     |
[INFO] [stdout] 246 |                     -try!(self.run(-beta, -alpha, depth - 1, m))
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:255:28
[INFO] [stdout]     |
[INFO] [stdout] 255 |                     match -try!(self.run(-alpha - 1, -alpha, depth - 2, m)) {
[INFO] [stdout]     |                            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:257:31
[INFO] [stdout]     |
[INFO] [stdout] 257 |                         _ => -try!(self.run(-beta, -alpha, depth - 1, m)),
[INFO] [stdout]     |                               ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:373:13
[INFO] [stdout]     |
[INFO] [stdout] 373 |             try!(self.report_progress(result.searched_nodes()));
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/simple_search.rs:425:30
[INFO] [stdout]     |
[INFO] [stdout] 425 |                 let value = -try!(self.run(-beta, -alpha, max(0, reduced_depth - 1), m));
[INFO] [stdout]     |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]   --> src/stock/std_search_node.rs:70:39
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut p: StdSearchNode<T> = try!(StdSearchNode::from_fen(fen));
[INFO] [stdout]    |                                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:317:56
[INFO] [stdout]     |
[INFO] [stdout] 317 |         let (board, halfmove_clock, fullmove_number) = try!(parse_fen(fen));
[INFO] [stdout]     |                                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/std_search_node.rs:318:19
[INFO] [stdout]     |
[INFO] [stdout] 318 |         let gen = try!(T::MoveGenerator::from_board(board));
[INFO] [stdout]     |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]     --> src/stock/std_move_generator.rs:1253:42
[INFO] [stdout]      |
[INFO] [stdout] 1253 |             StdMoveGenerator::from_board(try!(Board::from_fen(fen)))
[INFO] [stdout]      |                                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/aspiration.rs:107:13
[INFO] [stdout]     |
[INFO] [stdout] 107 |         } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/multipv.rs:118:17
[INFO] [stdout]     |
[INFO] [stdout] 118 |             } = try!(self.searcher.try_recv_report());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/stock/deepening/mod.rs:125:13
[INFO] [stdout]     |
[INFO] [stdout] 125 |         } = try!(self.multipv.try_recv_report());
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:150:27
[INFO] [stdout]     |
[INFO] [stdout] 150 |         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 150 -         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stdout] 150 +         const WQ: usize = 1 << (WHITE << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:151:27
[INFO] [stdout]     |
[INFO] [stdout] 151 |         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 151 -         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stdout] 151 +         const WK: usize = 1 << (WHITE << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:153:27
[INFO] [stdout]     |
[INFO] [stdout] 153 |         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout]     |                           ^                              ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 153 -         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stdout] 153 +         const BQ: usize = 1 << (BLACK << 1) << QUEENSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/board.rs:154:27
[INFO] [stdout]     |
[INFO] [stdout] 154 |         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout]     |                           ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stdout] 154 +         const BK: usize = 1 << (BLACK << 1) << KINGSIDE;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/board.rs:189:17
[INFO] [stdout]     |
[INFO] [stdout] 189 |                 try!(f.write_str(s));
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:280:22
[INFO] [stdout]     |
[INFO] [stdout] 280 |     let mut server = try!(Server::<E>::wait_for_hanshake());
[INFO] [stdout]     |                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:313:9
[INFO] [stdout]     |
[INFO] [stdout] 313 |         try!(write!(writer, "id name {}\n", E::name()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:314:9
[INFO] [stdout]     |
[INFO] [stdout] 314 |         try!(write!(writer, "id author {}\n", E::author()));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:342:9
[INFO] [stdout]     |
[INFO] [stdout] 342 |         try!(write!(writer, "uciok\n"));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:343:9
[INFO] [stdout]     |
[INFO] [stdout] 343 |         try!(writer.flush());
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:307:12
[INFO] [stdout]     |
[INFO] [stdout] 307 |         if try!(reader.read_line(&mut line)) == 0 {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:316:13
[INFO] [stdout]     |
[INFO] [stdout] 316 |             try!(write!(writer,
[INFO] [stdout]     |             ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:361:40
[INFO] [stdout]     |
[INFO] [stdout] 361 |                 if let Ok(cmd) = match try!(reader.read_line(&mut line)) {
[INFO] [stdout]     |                                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:405:25
[INFO] [stdout]     |
[INFO] [stdout] 405 |                         try!(write!(writer, "readyok\n"));
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:406:25
[INFO] [stdout]     |
[INFO] [stdout] 406 |                         try!(writer.flush());
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:469:17
[INFO] [stdout]     |
[INFO] [stdout] 469 |                 try!(writer.flush());
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:444:29
[INFO] [stdout]     |
[INFO] [stdout] 444 | ...                   try!(write!(writer,
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:454:33
[INFO] [stdout]     |
[INFO] [stdout] 454 | ...                   try!(write!(writer, "info"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:458:33
[INFO] [stdout]     |
[INFO] [stdout] 458 | ...                   try!(write!(writer, "\n"));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/uci.rs:456:37
[INFO] [stdout]     |
[INFO] [stdout] 456 | ...                   try!(write!(writer, " {} {}", info_type, data));
[INFO] [stdout]     |                       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/lib.rs:127:1
[INFO] [stdout]     |
[INFO] [stdout] 127 | / lazy_static! {
[INFO] [stdout] 128 | |     static ref CONFIGURATION: RwLock<HashMap<&'static str, String>> = RwLock::new(HashMap::new());
[INFO] [stdout] 129 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:228:31
[INFO] [stdout]     |
[INFO] [stdout] 228 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]     |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/utils/board_geometry.rs:229:38
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = ONCE_INIT;
[INFO] [stdout]     |                                      ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]     |
[INFO] [stdout] 229 |         static INIT_GEOMETRY: Once = Once::new();
[INFO] [stdout]     |                                      ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stdout]    |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/zobrist_arrays.rs:88:36
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = ONCE_INIT;
[INFO] [stdout]    |                                    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]    |
[INFO] [stdout] 88 |         static INIT_ARRAYS: Once = Once::new();
[INFO] [stdout]    |                                    ~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]   --> src/utils/notation.rs:87:5
[INFO] [stdout]    |
[INFO] [stdout] 87 | /     lazy_static! {
[INFO] [stdout] 88 | |         static ref RE: Regex = Regex::new(r"^[a-h][1-8]$").unwrap();
[INFO] [stdout] 89 | |     }
[INFO] [stdout]    | |_____^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/engine.rs:611:1
[INFO] [stdout]     |
[INFO] [stdout] 611 | / lazy_static! {
[INFO] [stdout] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stdout] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stdout] 614 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/simple_search.rs:355:47
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/stock/std_move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/stock/std_move_generator.rs:37:33
[INFO] [stdout]    |
[INFO] [stdout] 37 |             evaluator: unsafe { uninitialized() },
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/std_time_manager.rs:175:1
[INFO] [stdout]     |
[INFO] [stdout] 175 | / lazy_static! {
[INFO] [stdout] 176 | |     static ref AVG_SLOPE: RwLock<f64> = RwLock::new(0.7);
[INFO] [stdout] 177 | | }
[INFO] [stdout]     | |_^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/stock/deepening/mod.rs:160:9
[INFO] [stdout]     |
[INFO] [stdout] 160 | /         lazy_static! {
[INFO] [stdout] 161 | |             static ref RE: Regex = Regex::new(r"^TARGET_DEPTH=([-+]?\d+)$").unwrap();
[INFO] [stdout] 162 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/moves.rs:387:5
[INFO] [stdout]     |
[INFO] [stdout] 387 | /     lazy_static! {
[INFO] [stdout] 388 | |         static ref NOTATION: Vec<String> = (0..64).map(|i| format!("{}{}",
[INFO] [stdout] 389 | |             ["a", "b", "c", "d", "e", "f", "g", "h"][Board::file(i)],
[INFO] [stdout] 390 | |             ["1", "2", "3", "4", "5", "6", "7", "8"][Board::rank(i)])
[INFO] [stdout] 391 | |         ).collect();
[INFO] [stdout] 392 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]  --> src/move_generator.rs:3:15
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::mem::uninitialized;
[INFO] [stdout]   |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:300:9
[INFO] [stdout]     |
[INFO] [stdout] 300 | /         lazy_static! {
[INFO] [stdout] 301 | |             static ref RE: Regex = Regex::new(r"\buci(?:\s|$)").unwrap();
[INFO] [stdout] 302 | |         }
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:490:5
[INFO] [stdout]     |
[INFO] [stdout] 490 | /     lazy_static! {
[INFO] [stdout] 491 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 492 | |             format!(r"\b({})\s*(?:\s(.*)|$)",
[INFO] [stdout] 493 | |                     "setoption|isready|ucinewgame|\
[INFO] [stdout] ...   |
[INFO] [stdout] 496 | |         ).unwrap();
[INFO] [stdout] 497 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:519:5
[INFO] [stdout]     |
[INFO] [stdout] 519 | /     lazy_static! {
[INFO] [stdout] 520 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 521 | |             r"^name\s+(\S.*?)(?:\s+value\s+(.*?))?\s*$").unwrap();
[INFO] [stdout] 522 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:536:5
[INFO] [stdout]     |
[INFO] [stdout] 536 | /     lazy_static! {
[INFO] [stdout] 537 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 538 | |             format!(
[INFO] [stdout] 539 | |                 r"^(?:fen\s+(?P<fen>{})|startpos)(?:\s+moves(?P<moves>{}))?\s*$",
[INFO] [stdout] ...   |
[INFO] [stdout] 543 | |         ).unwrap();
[INFO] [stdout] 544 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stdout]    --> src/uci.rs:564:5
[INFO] [stdout]     |
[INFO] [stdout] 564 | /     lazy_static! {
[INFO] [stdout] 565 | |         static ref RE: Regex = Regex::new(
[INFO] [stdout] 566 | |             format!(
[INFO] [stdout] 567 | |                 r"\b(?P<keyword>{})(?:\s+(?P<number>\d+)|(?P<moves>{}))?(?:\s+|$)",
[INFO] [stdout] ...   |
[INFO] [stdout] 572 | |         ).unwrap();
[INFO] [stdout] 573 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:152:30
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut FnMut(u64) -> bool,
[INFO] [stdout]     |                              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 152 |     report_function: &'a mut dyn FnMut(u64) -> bool,
[INFO] [stdout]     |                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/search_node.rs:50:44
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/uci.rs:244:51
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>);
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 244 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>);
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/engine.rs:233:51
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 233 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>) {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/stock/simple_search.rs:169:41
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut FnMut(u64) -> bool)
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 169 |                report_function: &'a mut dyn FnMut(u64) -> bool)
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/stock/std_search_node.rs:69:44
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 69 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:214:63
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, &mut BISHOP_MAP, 0, false);
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` on by default
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, addr_of_mut!(BISHOP_MAP), 0, false);
[INFO] [stdout]     |                                                               ~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stdout]    --> src/utils/board_geometry.rs:215:52
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, &mut ROOK_MAP, bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stdout]     = note: this will be a hard error in the 2024 edition
[INFO] [stdout]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stdout] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 215 |             let total_size = init_slider_map(ROOK, addr_of_mut!(ROOK_MAP), bishop_attacks_size, false);
[INFO] [stdout]     |                                                    ~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/stock/std_ttable.rs:443:17
[INFO] [stdout]     |
[INFO] [stdout] 443 |             let mut record = b.get(0).as_mut().unwrap();
[INFO] [stdout]     |                 ----^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/stock/std_ttable.rs:464:17
[INFO] [stdout]     |
[INFO] [stdout] 464 |             let mut record = b.get(4).as_mut().unwrap();
[INFO] [stdout]     |                 ----^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:172:17
[INFO] [stdout]     |
[INFO] [stdout] 172 | /                 format!("too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 | |                         mem::align_of::<T>()));
[INFO] [stdout]     | |_____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` on by default
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 172 ~                 "too restrictive transposition table entry alignment: {} bytes",
[INFO] [stdout] 173 ~                         mem::align_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:175:17
[INFO] [stdout]     |
[INFO] [stdout] 175 | /                 format!("too big transposition table entry: {} bytes",
[INFO] [stdout] 176 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 175 ~                 "too big transposition table entry: {} bytes",
[INFO] [stdout] 176 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/stock/std_ttable.rs:178:17
[INFO] [stdout]     |
[INFO] [stdout] 178 | /                 format!("too small transposition table entry: {} bytes",
[INFO] [stdout] 179 | |                         mem::size_of::<T>()));
[INFO] [stdout]     | |____________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 178 ~                 "too small transposition table entry: {} bytes",
[INFO] [stdout] 179 ~                         mem::size_of::<T>());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `bool` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/simple_search.rs:355:42
[INFO] [stdout]     |
[INFO] [stdout] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: booleans must be either `true` or `false`
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Option<moves::Move>` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stdout]     |
[INFO] [stdout] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                           |
[INFO] [stdout]     |                                           this code causes undefined behavior when executed
[INFO] [stdout]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]    --> /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/option.rs:571:1
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stdout]     |
[INFO] [stdout] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                    |
[INFO] [stdout]     |                                                    this code causes undefined behavior when executed
[INFO] [stdout]     |                                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stdout]     |
[INFO] [stdout] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                          |
[INFO] [stdout]     |                                          this code causes undefined behavior when executed
[INFO] [stdout]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stdout]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stdout]     |
[INFO] [stdout] 870 |             dest_sets = uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         this code causes undefined behavior when executed
[INFO] [stdout]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[i16; 34]` does not permit being left uninitialized
[INFO] [stdout]    --> src/move_generator.rs:206:41
[INFO] [stdout]     |
[INFO] [stdout] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         this code causes undefined behavior when executed
[INFO] [stdout]     |                                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 87 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.22s
[INFO] running `Command { std: "docker" "inspect" "8383fdcbac84298e94a0bb18ee6796339d405c0067d0be746f94a513c124eba4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8383fdcbac84298e94a0bb18ee6796339d405c0067d0be746f94a513c124eba4", kill_on_drop: false }`
[INFO] [stdout] 8383fdcbac84298e94a0bb18ee6796339d405c0067d0be746f94a513c124eba4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:59a85a07ab18ca8720692f8e61effa1c651d9e2ca591e072c2b212bb91a6b8b5" "/opt/rustwide/cargo-home/bin/cargo" "+b642703cf9526da1e72c0b6755753b939a9c6b6d" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] ab58eb41a684e7315a358ce62439b4637c4f6b44490bb9353a75387ea16ae789
[INFO] running `Command { std: "docker" "start" "-a" "ab58eb41a684e7315a358ce62439b4637c4f6b44490bb9353a75387ea16ae789", kill_on_drop: false }`
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:55:22
[INFO] [stderr]    |
[INFO] [stderr] 55 |         let pieces = try!(parse_fen_piece_placement(fileds[0]));
[INFO] [stderr]    |                      ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:56:23
[INFO] [stderr]    |
[INFO] [stderr] 56 |         let to_move = try!(parse_fen_active_color(fileds[1]));
[INFO] [stderr]    |                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:57:31
[INFO] [stderr]    |
[INFO] [stderr] 57 |         let castling_rights = try!(parse_fen_castling_rights(fileds[2]));
[INFO] [stderr]    |                               ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:58:47
[INFO] [stderr]    |
[INFO] [stderr] 58 |         let enpassant_file = if let Some(x) = try!(parse_fen_enpassant_square(fileds[3])) {
[INFO] [stderr]    |                                               ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:67:30
[INFO] [stderr]    |
[INFO] [stderr] 67 |         let halfmove_clock = try!(fileds[4].parse::<u8>().map_err(|_| IllegalBoard));
[INFO] [stderr]    |                              ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/utils/notation.rs:68:31
[INFO] [stderr]    |
[INFO] [stderr] 68 |         let fullmove_number = try!(fileds[5].parse::<u16>().map_err(|_| IllegalBoard));
[INFO] [stderr]    |                               ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/utils/notation.rs:69:17
[INFO] [stderr]    |
[INFO] [stderr] 69 |         if let 1...9000 = fullmove_number {
[INFO] [stderr]    |                 ^^^ help: use `..=` for an inclusive range
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]    --> src/utils/notation.rs:134:20
[INFO] [stderr]     |
[INFO] [stderr] 134 |             n @ '1'...'8' => Token::EmptySquares(n.to_digit(9).unwrap()),
[INFO] [stderr]     |                    ^^^ help: use `..=` for an inclusive range
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]    --> src/stock/std_ttable.rs:213:31
[INFO] [stderr]     |
[INFO] [stderr] 213 |                          n @ 1...30 => n + 1,
[INFO] [stderr]     |                               ^^^ help: use `..=` for an inclusive range
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:226:26
[INFO] [stderr]     |
[INFO] [stderr] 226 |         if let Some(v) = try!(self.node_begin(alpha, beta, depth, last_move)) {
[INFO] [stderr]     |                          ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:238:17
[INFO] [stderr]     |
[INFO] [stderr] 238 |                 try!(self.report_progress(1));
[INFO] [stderr]     |                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:246:22
[INFO] [stderr]     |
[INFO] [stderr] 246 |                     -try!(self.run(-beta, -alpha, depth - 1, m))
[INFO] [stderr]     |                      ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:255:28
[INFO] [stderr]     |
[INFO] [stderr] 255 |                     match -try!(self.run(-alpha - 1, -alpha, depth - 2, m)) {
[INFO] [stderr]     |                            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:257:31
[INFO] [stderr]     |
[INFO] [stderr] 257 |                         _ => -try!(self.run(-beta, -alpha, depth - 1, m)),
[INFO] [stderr]     |                               ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:373:13
[INFO] [stderr]     |
[INFO] [stderr] 373 |             try!(self.report_progress(result.searched_nodes()));
[INFO] [stderr]     |             ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/simple_search.rs:425:30
[INFO] [stderr]     |
[INFO] [stderr] 425 |                 let value = -try!(self.run(-beta, -alpha, max(0, reduced_depth - 1), m));
[INFO] [stderr]     |                              ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]   --> src/stock/std_search_node.rs:70:39
[INFO] [stderr]    |
[INFO] [stderr] 70 |         let mut p: StdSearchNode<T> = try!(StdSearchNode::from_fen(fen));
[INFO] [stderr]    |                                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/std_search_node.rs:317:56
[INFO] [stderr]     |
[INFO] [stderr] 317 |         let (board, halfmove_clock, fullmove_number) = try!(parse_fen(fen));
[INFO] [stderr]     |                                                        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/std_search_node.rs:318:19
[INFO] [stderr]     |
[INFO] [stderr] 318 |         let gen = try!(T::MoveGenerator::from_board(board));
[INFO] [stderr]     |                   ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/deepening/aspiration.rs:107:13
[INFO] [stderr]     |
[INFO] [stderr] 107 |         } = try!(self.searcher.try_recv_report());
[INFO] [stderr]     |             ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/deepening/multipv.rs:118:17
[INFO] [stderr]     |
[INFO] [stderr] 118 |             } = try!(self.searcher.try_recv_report());
[INFO] [stderr]     |                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/stock/deepening/mod.rs:125:13
[INFO] [stderr]     |
[INFO] [stderr] 125 |         } = try!(self.multipv.try_recv_report());
[INFO] [stderr]     |             ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/board.rs:150:27
[INFO] [stderr]     |
[INFO] [stderr] 150 |         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stderr]     |                           ^                              ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 150 -         const WQ: usize = (1 << (WHITE << 1) << QUEENSIDE);
[INFO] [stderr] 150 +         const WQ: usize = 1 << (WHITE << 1) << QUEENSIDE;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/board.rs:151:27
[INFO] [stderr]     |
[INFO] [stderr] 151 |         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stderr]     |                           ^                             ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 151 -         const WK: usize = (1 << (WHITE << 1) << KINGSIDE);
[INFO] [stderr] 151 +         const WK: usize = 1 << (WHITE << 1) << KINGSIDE;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/board.rs:153:27
[INFO] [stderr]     |
[INFO] [stderr] 153 |         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stderr]     |                           ^                              ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 153 -         const BQ: usize = (1 << (BLACK << 1) << QUEENSIDE);
[INFO] [stderr] 153 +         const BQ: usize = 1 << (BLACK << 1) << QUEENSIDE;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/board.rs:154:27
[INFO] [stderr]     |
[INFO] [stderr] 154 |         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stderr]     |                           ^                             ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 154 -         const BK: usize = (1 << (BLACK << 1) << KINGSIDE);
[INFO] [stderr] 154 +         const BK: usize = 1 << (BLACK << 1) << KINGSIDE;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/board.rs:189:17
[INFO] [stderr]     |
[INFO] [stderr] 189 |                 try!(f.write_str(s));
[INFO] [stderr]     |                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:280:22
[INFO] [stderr]     |
[INFO] [stderr] 280 |     let mut server = try!(Server::<E>::wait_for_hanshake());
[INFO] [stderr]     |                      ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:313:9
[INFO] [stderr]     |
[INFO] [stderr] 313 |         try!(write!(writer, "id name {}\n", E::name()));
[INFO] [stderr]     |         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:314:9
[INFO] [stderr]     |
[INFO] [stderr] 314 |         try!(write!(writer, "id author {}\n", E::author()));
[INFO] [stderr]     |         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:342:9
[INFO] [stderr]     |
[INFO] [stderr] 342 |         try!(write!(writer, "uciok\n"));
[INFO] [stderr]     |         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:343:9
[INFO] [stderr]     |
[INFO] [stderr] 343 |         try!(writer.flush());
[INFO] [stderr]     |         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:307:12
[INFO] [stderr]     |
[INFO] [stderr] 307 |         if try!(reader.read_line(&mut line)) == 0 {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:316:13
[INFO] [stderr]     |
[INFO] [stderr] 316 |             try!(write!(writer,
[INFO] [stderr]     |             ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:361:40
[INFO] [stderr]     |
[INFO] [stderr] 361 |                 if let Ok(cmd) = match try!(reader.read_line(&mut line)) {
[INFO] [stderr]     |                                        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:405:25
[INFO] [stderr]     |
[INFO] [stderr] 405 |                         try!(write!(writer, "readyok\n"));
[INFO] [stderr]     |                         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:406:25
[INFO] [stderr]     |
[INFO] [stderr] 406 |                         try!(writer.flush());
[INFO] [stderr]     |                         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:469:17
[INFO] [stderr]     |
[INFO] [stderr] 469 |                 try!(writer.flush());
[INFO] [stderr]     |                 ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:444:29
[INFO] [stderr]     |
[INFO] [stderr] 444 | ...                   try!(write!(writer,
[INFO] [stderr]     |                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:454:33
[INFO] [stderr]     |
[INFO] [stderr] 454 | ...                   try!(write!(writer, "info"));
[INFO] [stderr]     |                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:458:33
[INFO] [stderr]     |
[INFO] [stderr] 458 | ...                   try!(write!(writer, "\n"));
[INFO] [stderr]     |                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]    --> src/uci.rs:456:37
[INFO] [stderr]     |
[INFO] [stderr] 456 | ...                   try!(write!(writer, " {} {}", info_type, data));
[INFO] [stderr]     |                       ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/lib.rs:127:1
[INFO] [stderr]     |
[INFO] [stderr] 127 | / lazy_static! {
[INFO] [stderr] 128 | |     static ref CONFIGURATION: RwLock<HashMap<&'static str, String>> = RwLock::new(HashMap::new());
[INFO] [stderr] 129 | | }
[INFO] [stderr]     | |_^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/utils/board_geometry.rs:228:31
[INFO] [stderr]     |
[INFO] [stderr] 228 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stderr]     |                               ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/utils/board_geometry.rs:229:38
[INFO] [stderr]     |
[INFO] [stderr] 229 |         static INIT_GEOMETRY: Once = ONCE_INIT;
[INFO] [stderr]     |                                      ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr] help: replace the use of the deprecated constant
[INFO] [stderr]     |
[INFO] [stderr] 229 |         static INIT_GEOMETRY: Once = Once::new();
[INFO] [stderr]     |                                      ~~~~~~~~~~~
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]   --> src/utils/zobrist_arrays.rs:87:31
[INFO] [stderr]    |
[INFO] [stderr] 87 |         use std::sync::{Once, ONCE_INIT};
[INFO] [stderr]    |                               ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]   --> src/utils/zobrist_arrays.rs:88:36
[INFO] [stderr]    |
[INFO] [stderr] 88 |         static INIT_ARRAYS: Once = ONCE_INIT;
[INFO] [stderr]    |                                    ^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: replace the use of the deprecated constant
[INFO] [stderr]    |
[INFO] [stderr] 88 |         static INIT_ARRAYS: Once = Once::new();
[INFO] [stderr]    |                                    ~~~~~~~~~~~
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]   --> src/utils/notation.rs:87:5
[INFO] [stderr]    |
[INFO] [stderr] 87 | /     lazy_static! {
[INFO] [stderr] 88 | |         static ref RE: Regex = Regex::new(r"^[a-h][1-8]$").unwrap();
[INFO] [stderr] 89 | |     }
[INFO] [stderr]    | |_____^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/engine.rs:611:1
[INFO] [stderr]     |
[INFO] [stderr] 611 | / lazy_static! {
[INFO] [stderr] 612 | |     static ref ENGINE: Mutex<Option<EngineInfo>> = Mutex::new(None);
[INFO] [stderr] 613 | |     static ref CHANGED_DEFAULTS: RwLock<Vec<(&'static str, &'static str)>> = RwLock::new(vec![]);
[INFO] [stderr] 614 | | }
[INFO] [stderr]     | |_^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/stock/simple_search.rs:355:47
[INFO] [stderr]     |
[INFO] [stderr] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stderr]     |                                               ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]  --> src/stock/std_move_generator.rs:3:15
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::mem::uninitialized;
[INFO] [stderr]   |               ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]   --> src/stock/std_move_generator.rs:37:33
[INFO] [stderr]    |
[INFO] [stderr] 37 |             evaluator: unsafe { uninitialized() },
[INFO] [stderr]    |                                 ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stderr]     |
[INFO] [stderr] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stderr]     |                                           ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stderr]     |
[INFO] [stderr] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stderr]     |                                                    ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stderr]     |
[INFO] [stderr] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stderr]     |                                          ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stderr]     |
[INFO] [stderr] 870 |             dest_sets = uninitialized();
[INFO] [stderr]     |                         ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/stock/std_time_manager.rs:175:1
[INFO] [stderr]     |
[INFO] [stderr] 175 | / lazy_static! {
[INFO] [stderr] 176 | |     static ref AVG_SLOPE: RwLock<f64> = RwLock::new(0.7);
[INFO] [stderr] 177 | | }
[INFO] [stderr]     | |_^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/stock/deepening/mod.rs:160:9
[INFO] [stderr]     |
[INFO] [stderr] 160 | /         lazy_static! {
[INFO] [stderr] 161 | |             static ref RE: Regex = Regex::new(r"^TARGET_DEPTH=([-+]?\d+)$").unwrap();
[INFO] [stderr] 162 | |         }
[INFO] [stderr]     | |_________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/moves.rs:387:5
[INFO] [stderr]     |
[INFO] [stderr] 387 | /     lazy_static! {
[INFO] [stderr] 388 | |         static ref NOTATION: Vec<String> = (0..64).map(|i| format!("{}{}",
[INFO] [stderr] 389 | |             ["a", "b", "c", "d", "e", "f", "g", "h"][Board::file(i)],
[INFO] [stderr] 390 | |             ["1", "2", "3", "4", "5", "6", "7", "8"][Board::rank(i)])
[INFO] [stderr] 391 | |         ).collect();
[INFO] [stderr] 392 | |     }
[INFO] [stderr]     | |_____^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]  --> src/move_generator.rs:3:15
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::mem::uninitialized;
[INFO] [stderr]   |               ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]    --> src/move_generator.rs:206:41
[INFO] [stderr]     |
[INFO] [stderr] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stderr]     |                                         ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/uci.rs:300:9
[INFO] [stderr]     |
[INFO] [stderr] 300 | /         lazy_static! {
[INFO] [stderr] 301 | |             static ref RE: Regex = Regex::new(r"\buci(?:\s|$)").unwrap();
[INFO] [stderr] 302 | |         }
[INFO] [stderr]     | |_________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/uci.rs:490:5
[INFO] [stderr]     |
[INFO] [stderr] 490 | /     lazy_static! {
[INFO] [stderr] 491 | |         static ref RE: Regex = Regex::new(
[INFO] [stderr] 492 | |             format!(r"\b({})\s*(?:\s(.*)|$)",
[INFO] [stderr] 493 | |                     "setoption|isready|ucinewgame|\
[INFO] [stderr] ...   |
[INFO] [stderr] 496 | |         ).unwrap();
[INFO] [stderr] 497 | |     }
[INFO] [stderr]     | |_____^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/uci.rs:519:5
[INFO] [stderr]     |
[INFO] [stderr] 519 | /     lazy_static! {
[INFO] [stderr] 520 | |         static ref RE: Regex = Regex::new(
[INFO] [stderr] 521 | |             r"^name\s+(\S.*?)(?:\s+value\s+(.*?))?\s*$").unwrap();
[INFO] [stderr] 522 | |     }
[INFO] [stderr]     | |_____^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/uci.rs:536:5
[INFO] [stderr]     |
[INFO] [stderr] 536 | /     lazy_static! {
[INFO] [stderr] 537 | |         static ref RE: Regex = Regex::new(
[INFO] [stderr] 538 | |             format!(
[INFO] [stderr] 539 | |                 r"^(?:fen\s+(?P<fen>{})|startpos)(?:\s+moves(?P<moves>{}))?\s*$",
[INFO] [stderr] ...   |
[INFO] [stderr] 543 | |         ).unwrap();
[INFO] [stderr] 544 | |     }
[INFO] [stderr]     | |_____^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `new` function is now preferred
[INFO] [stderr]    --> src/uci.rs:564:5
[INFO] [stderr]     |
[INFO] [stderr] 564 | /     lazy_static! {
[INFO] [stderr] 565 | |         static ref RE: Regex = Regex::new(
[INFO] [stderr] 566 | |             format!(
[INFO] [stderr] 567 | |                 r"\b(?P<keyword>{})(?:\s+(?P<number>\d+)|(?P<moves>{}))?(?:\s+|$)",
[INFO] [stderr] ...   |
[INFO] [stderr] 572 | |         ).unwrap();
[INFO] [stderr] 573 | |     }
[INFO] [stderr]     | |_____^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `__lazy_static_create` which comes from the expansion of the macro `lazy_static` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/stock/simple_search.rs:152:30
[INFO] [stderr]     |
[INFO] [stderr] 152 |     report_function: &'a mut FnMut(u64) -> bool,
[INFO] [stderr]     |                              ^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 152 |     report_function: &'a mut dyn FnMut(u64) -> bool,
[INFO] [stderr]     |                              +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/search_node.rs:50:44
[INFO] [stderr]    |
[INFO] [stderr] 50 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stderr]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 50 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard>;
[INFO] [stderr]    |                                            +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/uci.rs:244:51
[INFO] [stderr]     |
[INFO] [stderr] 244 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>);
[INFO] [stderr]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 244 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>);
[INFO] [stderr]     |                                                   +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/engine.rs:233:51
[INFO] [stderr]     |
[INFO] [stderr] 233 |     fn position(&mut self, fen: &str, moves: &mut Iterator<Item = &str>) {
[INFO] [stderr]     |                                                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 233 |     fn position(&mut self, fen: &str, moves: &mut dyn Iterator<Item = &str>) {
[INFO] [stderr]     |                                                   +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/stock/simple_search.rs:169:41
[INFO] [stderr]     |
[INFO] [stderr] 169 |                report_function: &'a mut FnMut(u64) -> bool)
[INFO] [stderr]     |                                         ^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 169 |                report_function: &'a mut dyn FnMut(u64) -> bool)
[INFO] [stderr]     |                                         +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/stock/std_search_node.rs:69:44
[INFO] [stderr]    |
[INFO] [stderr] 69 |     fn from_history(fen: &str, moves: &mut Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stderr]    |                                            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is an object-safe trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 69 |     fn from_history(fen: &str, moves: &mut dyn Iterator<Item = &str>) -> Result<Self, IllegalBoard> {
[INFO] [stderr]    |                                            +++
[INFO] [stderr] 
[INFO] [stderr] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stderr]    --> src/utils/board_geometry.rs:214:63
[INFO] [stderr]     |
[INFO] [stderr] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, &mut BISHOP_MAP, 0, false);
[INFO] [stderr]     |                                                               ^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stderr]     |
[INFO] [stderr]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stderr]     = note: this will be a hard error in the 2024 edition
[INFO] [stderr]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stderr]     = note: `#[warn(static_mut_refs)]` on by default
[INFO] [stderr] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stderr]     |
[INFO] [stderr] 214 |             let bishop_attacks_size = init_slider_map(BISHOP, addr_of_mut!(BISHOP_MAP), 0, false);
[INFO] [stderr]     |                                                               ~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stderr] 
[INFO] [stderr] warning: creating a mutable reference to mutable static is discouraged
[INFO] [stderr]    --> src/utils/board_geometry.rs:215:52
[INFO] [stderr]     |
[INFO] [stderr] 215 |             let total_size = init_slider_map(ROOK, &mut ROOK_MAP, bishop_attacks_size, false);
[INFO] [stderr]     |                                                    ^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stderr]     |
[INFO] [stderr]     = note: for more information, see issue #114447 <https://github.com/rust-lang/rust/issues/114447>
[INFO] [stderr]     = note: this will be a hard error in the 2024 edition
[INFO] [stderr]     = note: this mutable reference has lifetime `'static`, but if the static gets accessed (read or written) by any other means, or any other reference is created, then any further use of this mutable reference is Undefined Behavior
[INFO] [stderr] help: use `addr_of_mut!` instead to create a raw pointer
[INFO] [stderr]     |
[INFO] [stderr] 215 |             let total_size = init_slider_map(ROOK, addr_of_mut!(ROOK_MAP), bishop_attacks_size, false);
[INFO] [stderr]     |                                                    ~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stderr] 
[INFO] [stderr] warning: panic message is not a string literal
[INFO] [stderr]    --> src/stock/std_ttable.rs:172:17
[INFO] [stderr]     |
[INFO] [stderr] 172 | /                 format!("too restrictive transposition table entry alignment: {} bytes",
[INFO] [stderr] 173 | |                         mem::align_of::<T>()));
[INFO] [stderr]     | |_____________________________________________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stderr]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stderr]     = note: `#[warn(non_fmt_panics)]` on by default
[INFO] [stderr] help: remove the `format!(..)` macro call
[INFO] [stderr]     |
[INFO] [stderr] 172 ~                 "too restrictive transposition table entry alignment: {} bytes",
[INFO] [stderr] 173 ~                         mem::align_of::<T>());
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: panic message is not a string literal
[INFO] [stderr]    --> src/stock/std_ttable.rs:175:17
[INFO] [stderr]     |
[INFO] [stderr] 175 | /                 format!("too big transposition table entry: {} bytes",
[INFO] [stderr] 176 | |                         mem::size_of::<T>()));
[INFO] [stderr]     | |____________________________________________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stderr]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stderr] help: remove the `format!(..)` macro call
[INFO] [stderr]     |
[INFO] [stderr] 175 ~                 "too big transposition table entry: {} bytes",
[INFO] [stderr] 176 ~                         mem::size_of::<T>());
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: panic message is not a string literal
[INFO] [stderr]    --> src/stock/std_ttable.rs:178:17
[INFO] [stderr]     |
[INFO] [stderr] 178 | /                 format!("too small transposition table entry: {} bytes",
[INFO] [stderr] 179 | |                         mem::size_of::<T>()));
[INFO] [stderr]     | |____________________________________________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stderr]     = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stderr] help: remove the `format!(..)` macro call
[INFO] [stderr]     |
[INFO] [stderr] 178 ~                 "too small transposition table entry: {} bytes",
[INFO] [stderr] 179 ~                         mem::size_of::<T>());
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: the type `bool` does not permit being left uninitialized
[INFO] [stderr]    --> src/stock/simple_search.rs:355:42
[INFO] [stderr]     |
[INFO] [stderr] 355 |                       is_check: unsafe { mem::uninitialized() }, // We will initialize this soon!
[INFO] [stderr]     |                                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |                                          |
[INFO] [stderr]     |                                          this code causes undefined behavior when executed
[INFO] [stderr]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr]     = note: booleans must be either `true` or `false`
[INFO] [stderr]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: the type `Option<moves::Move>` does not permit being left uninitialized
[INFO] [stderr]    --> src/stock/std_move_generator.rs:299:43
[INFO] [stderr]     |
[INFO] [stderr] 299 |         let mut generated_move = unsafe { uninitialized() };
[INFO] [stderr]     |                                           ^^^^^^^^^^^^^^^
[INFO] [stderr]     |                                           |
[INFO] [stderr]     |                                           this code causes undefined behavior when executed
[INFO] [stderr]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stderr]    --> /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/option.rs:571:1
[INFO] [stderr] 
[INFO] [stderr] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stderr]    --> src/stock/std_move_generator.rs:416:52
[INFO] [stderr]     |
[INFO] [stderr] 416 |                 let mut dest_sets: [Bitboard; 4] = uninitialized();
[INFO] [stderr]     |                                                    ^^^^^^^^^^^^^^^
[INFO] [stderr]     |                                                    |
[INFO] [stderr]     |                                                    this code causes undefined behavior when executed
[INFO] [stderr]     |                                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr]     = note: integers must be initialized
[INFO] [stderr] 
[INFO] [stderr] warning: the type `u64` does not permit being left uninitialized
[INFO] [stderr]    --> src/stock/std_move_generator.rs:498:42
[INFO] [stderr]     |
[INFO] [stderr] 498 |         let mut old_hash: u64 = unsafe { uninitialized() };
[INFO] [stderr]     |                                          ^^^^^^^^^^^^^^^
[INFO] [stderr]     |                                          |
[INFO] [stderr]     |                                          this code causes undefined behavior when executed
[INFO] [stderr]     |                                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr]     = note: integers must be initialized
[INFO] [stderr] 
[INFO] [stderr] warning: the type `[u64; 4]` does not permit being left uninitialized
[INFO] [stderr]    --> src/stock/std_move_generator.rs:870:25
[INFO] [stderr]     |
[INFO] [stderr] 870 |             dest_sets = uninitialized();
[INFO] [stderr]     |                         ^^^^^^^^^^^^^^^
[INFO] [stderr]     |                         |
[INFO] [stderr]     |                         this code causes undefined behavior when executed
[INFO] [stderr]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr]     = note: integers must be initialized
[INFO] [stderr] 
[INFO] [stderr] warning: the type `[i16; 34]` does not permit being left uninitialized
[INFO] [stderr]    --> src/move_generator.rs:206:41
[INFO] [stderr]     |
[INFO] [stderr] 206 |             let mut gain: [Value; 34] = uninitialized();
[INFO] [stderr]     |                                         ^^^^^^^^^^^^^^^
[INFO] [stderr]     |                                         |
[INFO] [stderr]     |                                         this code causes undefined behavior when executed
[INFO] [stderr]     |                                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]     |
[INFO] [stderr]     = note: integers must be initialized
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stderr]     --> src/stock/std_move_generator.rs:1253:42
[INFO] [stderr]      |
[INFO] [stderr] 1253 |             StdMoveGenerator::from_board(try!(Board::from_fen(fen)))
[INFO] [stderr]      |                                          ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/stock/std_ttable.rs:443:17
[INFO] [stderr]     |
[INFO] [stderr] 443 |             let mut record = b.get(0).as_mut().unwrap();
[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: variable does not need to be mutable
[INFO] [stderr]    --> src/stock/std_ttable.rs:464:17
[INFO] [stderr]     |
[INFO] [stderr] 464 |             let mut record = b.get(4).as_mut().unwrap();
[INFO] [stderr]     |                 ----^^^^^^
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: `alcibiades` (lib) generated 84 warnings (1 duplicate) (run `cargo fix --lib -p alcibiades` to apply 18 suggestions)
[INFO] [stderr] warning: `alcibiades` (lib test) generated 87 warnings (84 duplicates) (run `cargo fix --lib -p alcibiades --tests` to apply 2 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.02s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/alcibiades-13063b2b96d9d730)
[INFO] [stdout] 
[INFO] [stdout] running 41 tests
[INFO] [stdout] test bitsets::tests::bitsets ... ok
[INFO] [stdout] test board::tests::castling_rights ... ok
[INFO] [stdout] test moves::tests::moves ... ok
[INFO] [stdout] test stock::std_move_generator::tests::piece_type_constants ... ok
[INFO] [stderr] thread 'stock::std_qsearch::tests::qsearch' panicked at library/core/src/panicking.rs:219:5:
[INFO] [stderr] attempted to leave type `core::option::Option<moves::Move>` uninitialized, which is invalid
[INFO] [stderr] stack backtrace:
[INFO] [stderr]    0:     0x557d71511b35 - std::backtrace_rs::backtrace::libunwind::trace::he49dc9a9e3164223
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/../../backtrace/src/backtrace/libunwind.rs:105:5
[INFO] [stderr]    1:     0x557d71511b35 - std::backtrace_rs::backtrace::trace_unsynchronized::h3a3e77c68030aa6b
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/../../backtrace/src/backtrace/mod.rs:66:5
[INFO] [stderr]    2:     0x557d71511b35 - std::sys_common::backtrace::_print_fmt::h9479ad2f99afd5d4
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/sys_common/backtrace.rs:68:5
[INFO] [stderr]    3:     0x557d71511b35 - <std::sys_common::backtrace::_print::DisplayBacktrace as core::fmt::Display>::fmt::hfb01aa1fa3fb1821
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/sys_common/backtrace.rs:44:22
[INFO] [stderr]    4:     0x557d715384ab - core::fmt::rt::Argument::fmt::h125e56152abbc1c3
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/fmt/rt.rs:165:63
[INFO] [stderr]    5:     0x557d715384ab - core::fmt::write::hb0ab4ff05ccfe741
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/fmt/mod.rs:1169:21
[INFO] [stderr]    6:     0x557d7150f36f - std::io::Write::write_fmt::h456b7988df61daf3
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/io/mod.rs:1835:15
[INFO] [stderr]    7:     0x557d7151190e - std::sys_common::backtrace::_print::h79ca548f3a2adf4b
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/sys_common/backtrace.rs:47:5
[INFO] [stderr]    8:     0x557d7151190e - std::sys_common::backtrace::print::h9aebf997b2fea2d3
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/sys_common/backtrace.rs:34:9
[INFO] [stderr]    9:     0x557d71513279 - std::panicking::default_hook::{{closure}}::h68a0954af2694526
[INFO] [stderr]   10:     0x557d71513048 - std::panicking::default_hook::h5be50cc6849ffb00
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/panicking.rs:298:9
[INFO] [stderr]   11:     0x557d713bc53f - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hd874405dcbd1d3ed
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/alloc/src/boxed.rs:2036:9
[INFO] [stderr]   12:     0x557d713bc53f - test::test_main::{{closure}}::h4f26a9df34a84b94
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/test/src/lib.rs:137:21
[INFO] [stderr]   13:     0x557d7151387b - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h00e96d9c62aa9a12
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/alloc/src/boxed.rs:2036:9
[INFO] [stderr]   14:     0x557d7151387b - std::panicking::rust_panic_with_hook::h3c0df6036729334c
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/panicking.rs:799:13
[INFO] [stderr]   15:     0x557d715135bb - std::panicking::begin_panic_handler::{{closure}}::ha3a21e93c4cfd807
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/panicking.rs:656:13
[INFO] [stderr]   16:     0x557d71511ff9 - std::sys_common::backtrace::__rust_end_short_backtrace::h19508a8f8ae71dc9
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/sys_common/backtrace.rs:171:18
[INFO] [stderr]   17:     0x557d71513327 - rust_begin_unwind
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/panicking.rs:652:5
[INFO] [stderr]   18:     0x557d71339e20 - core::panicking::panic_nounwind_fmt::runtime::h5a694fc2dbb2d2f2
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/panicking.rs:110:18
[INFO] [stderr]   19:     0x557d71339e20 - core::panicking::panic_nounwind_fmt::hdd1d11fcfd7ed294
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/panicking.rs:120:5
[INFO] [stderr]   20:     0x557d71339eb2 - core::panicking::panic_nounwind::h8259b34807f64d0c
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/panicking.rs:219:5
[INFO] [stderr]   21:     0x557d71344b0f - core::mem::uninitialized::h541efd21a192e1d8
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/mem/mod.rs:693:9
[INFO] [stderr]   22:     0x557d71344b0f - <alcibiades::stock::std_move_generator::StdMoveGenerator<T> as alcibiades::move_generator::MoveGenerator>::try_move_digest::h5be39b6dd359511c
[INFO] [stderr]                                at /opt/rustwide/workdir/src/stock/std_move_generator.rs:299:43
[INFO] [stderr]   23:     0x557d713467a7 - <alcibiades::stock::std_move_generator::StdMoveGenerator<T> as alcibiades::move_generator::MoveGenerator>::do_move::hbac41053b5e0660f
[INFO] [stderr]                                at /opt/rustwide/workdir/src/stock/std_move_generator.rs:517:38
[INFO] [stderr]   24:     0x557d71353bcf - alcibiades::stock::std_qsearch::qsearch::hb8cb1bfd4324d77b
[INFO] [stderr]                                at /opt/rustwide/workdir/src/stock/std_qsearch.rs:167:12
[INFO] [stderr]   25:     0x557d7137c07d - alcibiades::stock::std_qsearch::tests::qsearch::h59801afab22bad3b
[INFO] [stderr]                                at /opt/rustwide/workdir/src/stock/std_qsearch.rs:245:17
[INFO] [stderr]   26:     0x557d7137be27 - alcibiades::stock::std_qsearch::tests::qsearch::{{closure}}::haf049273ed620a4e
[INFO] [stderr]                                at /opt/rustwide/workdir/src/stock/std_qsearch.rs:237:17
[INFO] [stderr]   27:     0x557d713830a6 - core::ops::function::FnOnce::call_once::hd4a5272f185fa833
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/ops/function.rs:250:5
[INFO] [stderr]   28:     0x557d713c0e5b - core::ops::function::FnOnce::call_once::h18c6bf92212b87a4
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/ops/function.rs:250:5
[INFO] [stderr]   29:     0x557d713c0e5b - test::__rust_begin_short_backtrace::hdcf0edcfa9080086
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/test/src/lib.rs:625:18
[INFO] [stderr]   30:     0x557d713c0521 - test::run_test_in_process::{{closure}}::heac2c4eb375d2d10
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/test/src/lib.rs:648:60
[INFO] [stderr]   31:     0x557d713c0521 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h0289bafc8a1cc004
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stderr]   32:     0x557d713c0521 - std::panicking::try::do_call::h5e158f1ad8a5f983
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/panicking.rs:559:40
[INFO] [stderr]   33:     0x557d713c0521 - std::panicking::try::hea3411d60321c4de
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/panicking.rs:523:19
[INFO] [stderr]   34:     0x557d713c0521 - std::panic::catch_unwind::hafb7bb18bc47bbc7
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/panic.rs:149:14
[INFO] [stderr]   35:     0x557d713c0521 - test::run_test_in_process::h74dd138dc7762d99
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/test/src/lib.rs:648:27
[INFO] [stderr]   36:     0x557d713c0521 - test::run_test::{{closure}}::h6b390822e63606cf
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/test/src/lib.rs:569:43
[INFO] [stderr]   37:     0x557d71388ef4 - test::run_test::{{closure}}::h6e11dba8131d354b
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/test/src/lib.rs:599:41
[INFO] [stderr]   38:     0x557d71388ef4 - std::sys_common::backtrace::__rust_begin_short_backtrace::ha71b3541b59bdbbb
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/sys_common/backtrace.rs:155:18
[INFO] [stderr]   39:     0x557d7138d9c2 - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hef92127c5ef9e53c
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/thread/mod.rs:542:17
[INFO] [stderr]   40:     0x557d7138d9c2 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h859c109f9d11c92b
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stderr]   41:     0x557d7138d9c2 - std::panicking::try::do_call::hbf534c458cd858f0
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/panicking.rs:559:40
[INFO] [stderr]   42:     0x557d7138d9c2 - std::panicking::try::h65c18365a7b9ad90
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/panicking.rs:523:19
[INFO] [stderr]   43:     0x557d7138d9c2 - std::panic::catch_unwind::h21b25d4c69478c39
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/panic.rs:149:14
[INFO] [stderr]   44:     0x557d7138d9c2 - std::thread::Builder::spawn_unchecked_::{{closure}}::h23335f620275a9bf
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/thread/mod.rs:541:30
[INFO] [stderr]   45:     0x557d7138d9c2 - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb491dc55513e9b7c
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/core/src/ops/function.rs:250:5
[INFO] [stderr]   46:     0x557d71517b6b - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h41b39260afcffdc9
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/alloc/src/boxed.rs:2022:9
[INFO] [stderr]   47:     0x557d71517b6b - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h6694c8dc6dd010c4
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/alloc/src/boxed.rs:2022:9
[INFO] [stderr]   48:     0x557d71517b6b - std::sys::pal::unix::thread::Thread::new::thread_start::hf16038e1c8e19c99
[INFO] [stderr]                                at /rustc/b642703cf9526da1e72c0b6755753b939a9c6b6d/library/std/src/sys/pal/unix/thread.rs:108:17
[INFO] [stderr]   49:     0x7f989dbe3ac3 - <unknown>
[INFO] [stderr]   50:     0x7f989dc74a04 - __clone
[INFO] [stderr]   51:                0x0 - <unknown>
[INFO] [stderr] thread caused non-unwinding panic. aborting.
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] [stderr] 
[INFO] [stderr] Caused by:
[INFO] [stderr]   process didn't exit successfully: `/opt/rustwide/target/debug/deps/alcibiades-13063b2b96d9d730` (signal: 6, SIGABRT: process abort signal)
[INFO] running `Command { std: "docker" "inspect" "ab58eb41a684e7315a358ce62439b4637c4f6b44490bb9353a75387ea16ae789", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ab58eb41a684e7315a358ce62439b4637c4f6b44490bb9353a75387ea16ae789", kill_on_drop: false }`
[INFO] [stdout] ab58eb41a684e7315a358ce62439b4637c4f6b44490bb9353a75387ea16ae789
