[INFO] updating cached repository nikofil/advent-rust [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/nikofil/advent-rust [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/nikofil/advent-rust" "work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/nikofil/advent-rust"` [INFO] [stderr] Cloning into 'work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/nikofil/advent-rust'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/nikofil/advent-rust" "work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/gh/nikofil/advent-rust"` [INFO] [stderr] Cloning into 'work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/gh/nikofil/advent-rust'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 36c27b977de71eb487f3d922df37b0da7868e123 [INFO] sha for GitHub repo nikofil/advent-rust: 36c27b977de71eb487f3d922df37b0da7868e123 [INFO] validating manifest of nikofil/advent-rust on toolchain master#60960a260f7b5c695fd0717311d72ce62dd4eb43 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of nikofil/advent-rust on toolchain try#266783e4e09e4e9d5307c1c8e695659c58bbcac7 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+266783e4e09e4e9d5307c1c8e695659c58bbcac7-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing nikofil/advent-rust [INFO] finished frobbing nikofil/advent-rust [INFO] frobbed toml for nikofil/advent-rust written to work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/nikofil/advent-rust/Cargo.toml [INFO] started frobbing nikofil/advent-rust [INFO] finished frobbing nikofil/advent-rust [INFO] frobbed toml for nikofil/advent-rust written to work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/gh/nikofil/advent-rust/Cargo.toml [INFO] crate nikofil/advent-rust already has a lockfile, it will not be regenerated [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+266783e4e09e4e9d5307c1c8e695659c58bbcac7-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] checking nikofil/advent-rust against master#60960a260f7b5c695fd0717311d72ce62dd4eb43 for pr-63376 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-63376/worker-6/master#60960a260f7b5c695fd0717311d72ce62dd4eb43:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/nikofil/advent-rust:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "check" "--frozen" "--all" "--all-targets"` [INFO] [stdout] 04143b1849d46ce51ddd23b23c5ff8ed9f4ab69d6a776ff9e48e9039fd4f43f5 [INFO] running `"docker" "start" "-a" "04143b1849d46ce51ddd23b23c5ff8ed9f4ab69d6a776ff9e48e9039fd4f43f5"` [INFO] [stderr] Checking memchr v2.1.2 [INFO] [stderr] Checking aho-corasick v0.6.9 [INFO] [stderr] Checking regex v1.1.0 [INFO] [stderr] Checking advent-rust v0.1.0 (/opt/crater/workdir) [INFO] [stderr] warning: unreachable statement [INFO] [stderr] --> src/bin/day14_1.rs:21:5 [INFO] [stderr] | [INFO] [stderr] 21 | println!("{}", i); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unreachable_code)]` on by default [INFO] [stderr] = note: this warning originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] warning: variable `i` is assigned to, but never used [INFO] [stderr] --> src/bin/day14_1.rs:6:13 [INFO] [stderr] | [INFO] [stderr] 6 | let mut i = 0; [INFO] [stderr] | ^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] = note: consider using `_i` instead [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:19:25 [INFO] [stderr] | [INFO] [stderr] 19 | fn is_enemy(&self, &Player) -> bool; [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:29:16 [INFO] [stderr] | [INFO] [stderr] 29 | impl PartialEq for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:29:28 [INFO] [stderr] | [INFO] [stderr] 29 | impl PartialEq for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:30:26 [INFO] [stderr] | [INFO] [stderr] 30 | fn eq(&self, other: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:35:17 [INFO] [stderr] | [INFO] [stderr] 35 | impl PartialOrd for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:35:29 [INFO] [stderr] | [INFO] [stderr] 35 | impl PartialOrd for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:36:35 [INFO] [stderr] | [INFO] [stderr] 36 | fn partial_cmp(&self, other: &Player) -> Option { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:41:14 [INFO] [stderr] | [INFO] [stderr] 41 | impl Ord for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:47:13 [INFO] [stderr] | [INFO] [stderr] 47 | impl Eq for Player {} [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:86:28 [INFO] [stderr] | [INFO] [stderr] 86 | fn is_enemy(&self, o: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:110:28 [INFO] [stderr] | [INFO] [stderr] 110 | fn is_enemy(&self, o: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:234:50 [INFO] [stderr] | [INFO] [stderr] 234 | fn setatk(x: usize, y: usize, v: &Board, b: &Box) -> Option<(usize, usize, i32)> { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:266:51 [INFO] [stderr] | [INFO] [stderr] 266 | fn take(&mut self, x: usize, y: usize) -> Box { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:276:50 [INFO] [stderr] | [INFO] [stderr] 276 | fn set(&mut self, x: usize, y: usize, p: Box) { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/day15_1.rs:306:17 [INFO] [stderr] | [INFO] [stderr] 306 | f.write_str(i); [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:19:25 [INFO] [stderr] | [INFO] [stderr] 19 | fn is_enemy(&self, &Player) -> bool; [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:29:16 [INFO] [stderr] | [INFO] [stderr] 29 | impl PartialEq for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:29:28 [INFO] [stderr] | [INFO] [stderr] 29 | impl PartialEq for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:30:26 [INFO] [stderr] | [INFO] [stderr] 30 | fn eq(&self, other: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:35:17 [INFO] [stderr] | [INFO] [stderr] 35 | impl PartialOrd for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:35:29 [INFO] [stderr] | [INFO] [stderr] 35 | impl PartialOrd for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:36:35 [INFO] [stderr] | [INFO] [stderr] 36 | fn partial_cmp(&self, other: &Player) -> Option { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:41:14 [INFO] [stderr] | [INFO] [stderr] 41 | impl Ord for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:47:13 [INFO] [stderr] | [INFO] [stderr] 47 | impl Eq for Player {} [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:86:28 [INFO] [stderr] | [INFO] [stderr] 86 | fn is_enemy(&self, o: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:110:28 [INFO] [stderr] | [INFO] [stderr] 110 | fn is_enemy(&self, o: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:234:50 [INFO] [stderr] | [INFO] [stderr] 234 | fn setatk(x: usize, y: usize, v: &Board, b: &Box) -> Option<(usize, usize, i32)> { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:266:51 [INFO] [stderr] | [INFO] [stderr] 266 | fn take(&mut self, x: usize, y: usize) -> Box { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_1.rs:276:50 [INFO] [stderr] | [INFO] [stderr] 276 | fn set(&mut self, x: usize, y: usize, p: Box) { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: unreachable statement [INFO] [stderr] --> src/bin/day14_1.rs:21:5 [INFO] [stderr] | [INFO] [stderr] 21 | println!("{}", i); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unreachable_code)]` on by default [INFO] [stderr] = note: this warning originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] warning: variable `i` is assigned to, but never used [INFO] [stderr] --> src/bin/day14_1.rs:6:13 [INFO] [stderr] | [INFO] [stderr] 6 | let mut i = 0; [INFO] [stderr] | ^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] = note: consider using `_i` instead [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/day15_1.rs:306:17 [INFO] [stderr] | [INFO] [stderr] 306 | f.write_str(i); [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/bin/day9_1.rs:65:24 [INFO] [stderr] | [INFO] [stderr] 65 | Ok(mut x) => x.borrow_mut().next.take(), [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/bin/day9_2.rs:65:24 [INFO] [stderr] | [INFO] [stderr] 65 | Ok(mut x) => x.borrow_mut().next.take(), [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/bin/day9_2.rs:65:24 [INFO] [stderr] | [INFO] [stderr] 65 | Ok(mut x) => x.borrow_mut().next.take(), [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/bin/day9_1.rs:65:24 [INFO] [stderr] | [INFO] [stderr] 65 | Ok(mut x) => x.borrow_mut().next.take(), [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::process::exit` [INFO] [stderr] --> src/bin/day15_2.rs:16:5 [INFO] [stderr] | [INFO] [stderr] 16 | use std::process::exit; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:19:25 [INFO] [stderr] | [INFO] [stderr] 19 | fn is_enemy(&self, &Player) -> bool; [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:30:16 [INFO] [stderr] | [INFO] [stderr] 30 | impl PartialEq for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:30:28 [INFO] [stderr] | [INFO] [stderr] 30 | impl PartialEq for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:31:26 [INFO] [stderr] | [INFO] [stderr] 31 | fn eq(&self, other: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:36:17 [INFO] [stderr] | [INFO] [stderr] 36 | impl PartialOrd for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:36:29 [INFO] [stderr] | [INFO] [stderr] 36 | impl PartialOrd for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:37:35 [INFO] [stderr] | [INFO] [stderr] 37 | fn partial_cmp(&self, other: &Player) -> Option { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:42:14 [INFO] [stderr] | [INFO] [stderr] 42 | impl Ord for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:48:13 [INFO] [stderr] | [INFO] [stderr] 48 | impl Eq for Player {} [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:88:28 [INFO] [stderr] | [INFO] [stderr] 88 | fn is_enemy(&self, o: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:117:28 [INFO] [stderr] | [INFO] [stderr] 117 | fn is_enemy(&self, o: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:264:50 [INFO] [stderr] | [INFO] [stderr] 264 | fn setatk(x: usize, y: usize, v: &Board, b: &Box) -> Option<(usize, usize, i32)> { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:296:51 [INFO] [stderr] | [INFO] [stderr] 296 | fn take(&mut self, x: usize, y: usize) -> Box { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:306:50 [INFO] [stderr] | [INFO] [stderr] 306 | fn set(&mut self, x: usize, y: usize, p: Box) { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/day15_2.rs:336:17 [INFO] [stderr] | [INFO] [stderr] 336 | f.write_str(i); [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::process::exit` [INFO] [stderr] --> src/bin/day15_2.rs:16:5 [INFO] [stderr] | [INFO] [stderr] 16 | use std::process::exit; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:19:25 [INFO] [stderr] | [INFO] [stderr] 19 | fn is_enemy(&self, &Player) -> bool; [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:30:16 [INFO] [stderr] | [INFO] [stderr] 30 | impl PartialEq for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:30:28 [INFO] [stderr] | [INFO] [stderr] 30 | impl PartialEq for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:31:26 [INFO] [stderr] | [INFO] [stderr] 31 | fn eq(&self, other: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:36:17 [INFO] [stderr] | [INFO] [stderr] 36 | impl PartialOrd for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:36:29 [INFO] [stderr] | [INFO] [stderr] 36 | impl PartialOrd for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:37:35 [INFO] [stderr] | [INFO] [stderr] 37 | fn partial_cmp(&self, other: &Player) -> Option { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:42:14 [INFO] [stderr] | [INFO] [stderr] 42 | impl Ord for Player { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:48:13 [INFO] [stderr] | [INFO] [stderr] 48 | impl Eq for Player {} [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:88:28 [INFO] [stderr] | [INFO] [stderr] 88 | fn is_enemy(&self, o: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:117:28 [INFO] [stderr] | [INFO] [stderr] 117 | fn is_enemy(&self, o: &Player) -> bool { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:264:50 [INFO] [stderr] | [INFO] [stderr] 264 | fn setatk(x: usize, y: usize, v: &Board, b: &Box) -> Option<(usize, usize, i32)> { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:296:51 [INFO] [stderr] | [INFO] [stderr] 296 | fn take(&mut self, x: usize, y: usize) -> Box { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/bin/day15_2.rs:306:50 [INFO] [stderr] | [INFO] [stderr] 306 | fn set(&mut self, x: usize, y: usize, p: Box) { [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Player` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/day15_2.rs:336:17 [INFO] [stderr] | [INFO] [stderr] 336 | f.write_str(i); [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 19.19s [INFO] running `"docker" "inspect" "04143b1849d46ce51ddd23b23c5ff8ed9f4ab69d6a776ff9e48e9039fd4f43f5"` [INFO] running `"docker" "rm" "-f" "04143b1849d46ce51ddd23b23c5ff8ed9f4ab69d6a776ff9e48e9039fd4f43f5"` [INFO] [stdout] 04143b1849d46ce51ddd23b23c5ff8ed9f4ab69d6a776ff9e48e9039fd4f43f5