[INFO] fetching crate alcibiades 0.3.0... [INFO] checking alcibiades-0.3.0 against try#81275a1445c7502a974118e0c69b795ab60be991 for pr-80243 [INFO] extracting crate alcibiades 0.3.0 into /workspace/builds/worker-7/source [INFO] validating manifest of crates.io crate alcibiades 0.3.0 on toolchain 81275a1445c7502a974118e0c69b795ab60be991 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+81275a1445c7502a974118e0c69b795ab60be991" "read-manifest" "--manifest-path" "Cargo.toml", 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-7/source/Cargo.toml [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+81275a1445c7502a974118e0c69b795ab60be991" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }` [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+81275a1445c7502a974118e0c69b795ab60be991" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7/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" "rustops/crates-build-env@sha256:c8ac004eab7d63a0ad09a2dde3d3353ba464f767bee4de425dc8f74c46a1905e" "/opt/rustwide/cargo-home/bin/cargo" "+81275a1445c7502a974118e0c69b795ab60be991" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] baed03042b0375a7703ebad7292704bdca8fe83337a5cfba27d163ed127ae975 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "baed03042b0375a7703ebad7292704bdca8fe83337a5cfba27d163ed127ae975", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "baed03042b0375a7703ebad7292704bdca8fe83337a5cfba27d163ed127ae975", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "baed03042b0375a7703ebad7292704bdca8fe83337a5cfba27d163ed127ae975", kill_on_drop: false }` [INFO] [stdout] baed03042b0375a7703ebad7292704bdca8fe83337a5cfba27d163ed127ae975 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "rustops/crates-build-env@sha256:c8ac004eab7d63a0ad09a2dde3d3353ba464f767bee4de425dc8f74c46a1905e" "/opt/rustwide/cargo-home/bin/cargo" "+81275a1445c7502a974118e0c69b795ab60be991" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 87b9446b80362cc782912572378f50f264b84d8a3207a953b14de8b112e00da7 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "87b9446b80362cc782912572378f50f264b84d8a3207a953b14de8b112e00da7", kill_on_drop: false }` [INFO] [stderr] Compiling memchr v2.3.4 [INFO] [stderr] Checking lazy_static v1.4.0 [INFO] [stderr] Checking thread_local v0.3.6 [INFO] [stderr] Checking aho-corasick v0.6.10 [INFO] [stderr] Checking regex v0.2.11 [INFO] [stderr] Checking 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::().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::().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] = 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] [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) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Iterator` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [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] [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] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(u64) -> bool` [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] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(u64) -> bool` [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 = try!(StdSearchNode::from_fen(fen)); [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) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Iterator` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [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: 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) -> Result; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Iterator` [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); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Iterator` [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::::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: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: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: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: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: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: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: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 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: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: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 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> = RwLock::new(HashMap::new()); [INFO] [stdout] 129 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (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] | ^^^^^^^^^ help: replace the use of the deprecated constant: `Once::new()` [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] | ^^^^^^^^^ help: replace the use of the deprecated constant: `Once::new()` [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 a macro (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> = Mutex::new(None); [INFO] [stdout] 613 | | static ref CHANGED_DEFAULTS: RwLock> = RwLock::new(vec![]); [INFO] [stdout] 614 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (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> = Mutex::new(None); [INFO] [stdout] 613 | | static ref CHANGED_DEFAULTS: RwLock> = RwLock::new(vec![]); [INFO] [stdout] 614 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (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:42 [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:5 [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 = RwLock::new(0.7); [INFO] [stdout] 177 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (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 a macro (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 = (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 a macro (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:5 [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 a macro (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 a macro (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 a macro (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{})|startpos)(?:\s+moves(?P{}))?\s*$", [INFO] [stdout] ... | [INFO] [stdout] 543 | | ).unwrap(); [INFO] [stdout] 544 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (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{})(?:\s+(?P\d+)|(?P{}))?(?:\s+|$)", [INFO] [stdout] ... | [INFO] [stdout] 572 | | ).unwrap(); [INFO] [stdout] 573 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [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::().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::().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] = 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] [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) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Iterator` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [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] [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] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(u64) -> bool` [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] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(u64) -> bool` [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 = try!(StdSearchNode::from_fen(fen)); [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) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Iterator` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [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: 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) -> Result; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Iterator` [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); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Iterator` [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::::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: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: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: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: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: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: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: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 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: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: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 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> = RwLock::new(HashMap::new()); [INFO] [stdout] 129 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (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] | ^^^^^^^^^ help: replace the use of the deprecated constant: `Once::new()` [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] | ^^^^^^^^^ help: replace the use of the deprecated constant: `Once::new()` [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 a macro (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> = Mutex::new(None); [INFO] [stdout] 613 | | static ref CHANGED_DEFAULTS: RwLock> = RwLock::new(vec![]); [INFO] [stdout] 614 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (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> = Mutex::new(None); [INFO] [stdout] 613 | | static ref CHANGED_DEFAULTS: RwLock> = RwLock::new(vec![]); [INFO] [stdout] 614 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (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:42 [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:5 [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 = RwLock::new(0.7); [INFO] [stdout] 177 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (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 a macro (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 = (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 a macro (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:5 [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 a macro (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 a macro (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 a macro (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{})|startpos)(?:\s+moves(?P{}))?\s*$", [INFO] [stdout] ... | [INFO] [stdout] 543 | | ).unwrap(); [INFO] [stdout] 544 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (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{})(?:\s+(?P\d+)|(?P{}))?(?:\s+|$)", [INFO] [stdout] ... | [INFO] [stdout] 572 | | ).unwrap(); [INFO] [stdout] 573 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [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` instead, and only call `assume_init` after initialization is done [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(invalid_value)]` on by default [INFO] [stdout] = note: booleans must be either `true` or `false` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 74 warnings emitted [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: 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` instead, and only call `assume_init` after initialization is done [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(invalid_value)]` on by default [INFO] [stdout] = note: booleans must be either `true` or `false` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 77 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 8.27s [INFO] running `Command { std: "docker" "inspect" "87b9446b80362cc782912572378f50f264b84d8a3207a953b14de8b112e00da7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "87b9446b80362cc782912572378f50f264b84d8a3207a953b14de8b112e00da7", kill_on_drop: false }` [INFO] [stdout] 87b9446b80362cc782912572378f50f264b84d8a3207a953b14de8b112e00da7