[INFO] cloning repository https://github.com/royburner/algolib [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/royburner/algolib" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Froyburner%2Falgolib", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Froyburner%2Falgolib'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] ce7372768e46e5d8601e7fc80ec1cf4fa80a1ab0 [INFO] testing royburner/algolib against 1.59.0 for beta-1.60-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Froyburner%2Falgolib" "/workspace/builds/worker-21/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-21/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/royburner/algolib on toolchain 1.59.0 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.59.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/royburner/algolib [INFO] finished tweaking git repo https://github.com/royburner/algolib [INFO] tweaked toml for git repo https://github.com/royburner/algolib written to /workspace/builds/worker-21/source/Cargo.toml [INFO] crate git repo https://github.com/royburner/algolib already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.59.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-21/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-21/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:0cd99ca24d8e8c98e67c542213511d985b8778b5bdcbb160e038429496686047" "/opt/rustwide/cargo-home/bin/cargo" "+1.59.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 332af2709e3fb4f93df4d35a8cc7ed7e859d8694460b6271709adaf12ec34aa0 [INFO] running `Command { std: "docker" "start" "-a" "332af2709e3fb4f93df4d35a8cc7ed7e859d8694460b6271709adaf12ec34aa0", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "332af2709e3fb4f93df4d35a8cc7ed7e859d8694460b6271709adaf12ec34aa0", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "332af2709e3fb4f93df4d35a8cc7ed7e859d8694460b6271709adaf12ec34aa0", kill_on_drop: false }` [INFO] [stdout] 332af2709e3fb4f93df4d35a8cc7ed7e859d8694460b6271709adaf12ec34aa0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-21/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-21/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "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:0cd99ca24d8e8c98e67c542213511d985b8778b5bdcbb160e038429496686047" "/opt/rustwide/cargo-home/bin/cargo" "+1.59.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 441e705c4e2bded1c0747854dc8c94b48cbc3380fb9e6b1b0253b8d9222bb31f [INFO] running `Command { std: "docker" "start" "-a" "441e705c4e2bded1c0747854dc8c94b48cbc3380fb9e6b1b0253b8d9222bb31f", kill_on_drop: false }` [INFO] [stderr] Compiling algolib v0.0.1 (/opt/rustwide/workdir) [INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression [INFO] [stdout] --> src/a_star.rs:34:19 [INFO] [stdout] | [INFO] [stdout] 34 | let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 34 - let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stdout] 34 + let absX = match point.x>self.goal.x{//TODO refactor [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression [INFO] [stdout] --> src/a_star.rs:38:19 [INFO] [stdout] | [INFO] [stdout] 38 | let absY = match(point.y>self.goal.y){ [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 38 - let absY = match(point.y>self.goal.y){ [INFO] [stdout] 38 + let absY = match point.y>self.goal.y{ [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `closedSet` [INFO] [stdout] --> src/a_star.rs:46:11 [INFO] [stdout] | [INFO] [stdout] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_closedSet` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cameFrom` [INFO] [stdout] --> src/a_star.rs:49:11 [INFO] [stdout] | [INFO] [stdout] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cameFrom` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/a_star.rs:46:7 [INFO] [stdout] | [INFO] [stdout] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [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/a_star.rs:49:7 [INFO] [stdout] | [INFO] [stdout] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stdout] | ----^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct is never constructed: `Board` [INFO] [stdout] --> src/a_star.rs:9:8 [INFO] [stdout] | [INFO] [stdout] 9 | struct Board{ [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `new` [INFO] [stdout] --> src/a_star.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | fn new(width : usize)->Board{ [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `newGScoreWithInfinity` [INFO] [stdout] --> src/a_star.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | fn newGScoreWithInfinity(&self) -> HashMap{ [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `heuristic_cost_estimate` [INFO] [stdout] --> src/a_star.rs:33:5 [INFO] [stdout] | [INFO] [stdout] 33 | fn heuristic_cost_estimate(&self, point:Point)->usize{ [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `a_star` [INFO] [stdout] --> src/a_star.rs:45:5 [INFO] [stdout] | [INFO] [stdout] 45 | fn a_star(&self) -> Option>{ [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `newGScoreWithInfinity` should have a snake case name [INFO] [stdout] --> src/a_star.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | fn newGScoreWithInfinity(&self) -> HashMap{ [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `new_gscore_with_infinity` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `gScore` should have a snake case name [INFO] [stdout] --> src/a_star.rs:24:11 [INFO] [stdout] | [INFO] [stdout] 24 | let mut gScore : HashMap = HashMap::new(); [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `g_score` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `absX` should have a snake case name [INFO] [stdout] --> src/a_star.rs:34:7 [INFO] [stdout] | [INFO] [stdout] 34 | let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stdout] | ^^^^ help: convert the identifier to snake case: `abs_x` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `absY` should have a snake case name [INFO] [stdout] --> src/a_star.rs:38:7 [INFO] [stdout] | [INFO] [stdout] 38 | let absY = match(point.y>self.goal.y){ [INFO] [stdout] | ^^^^ help: convert the identifier to snake case: `abs_y` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `closedSet` should have a snake case name [INFO] [stdout] --> src/a_star.rs:46:11 [INFO] [stdout] | [INFO] [stdout] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `closed_set` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `openSet` should have a snake case name [INFO] [stdout] --> src/a_star.rs:47:11 [INFO] [stdout] | [INFO] [stdout] 47 | let mut openSet : HashSet = HashSet::new();// The set of tentative nodes to be evaluated [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `open_set` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `cameFrom` should have a snake case name [INFO] [stdout] --> src/a_star.rs:49:11 [INFO] [stdout] | [INFO] [stdout] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `came_from` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `gScore` should have a snake case name [INFO] [stdout] --> src/a_star.rs:51:11 [INFO] [stdout] | [INFO] [stdout] 51 | let mut gScore = self.newGScoreWithInfinity(); [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `g_score` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `fScore` should have a snake case name [INFO] [stdout] --> src/a_star.rs:55:11 [INFO] [stdout] | [INFO] [stdout] 55 | let mut fScore = self.newGScoreWithInfinity(); [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `f_score` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 20 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 0.28s [INFO] running `Command { std: "docker" "inspect" "441e705c4e2bded1c0747854dc8c94b48cbc3380fb9e6b1b0253b8d9222bb31f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "441e705c4e2bded1c0747854dc8c94b48cbc3380fb9e6b1b0253b8d9222bb31f", kill_on_drop: false }` [INFO] [stdout] 441e705c4e2bded1c0747854dc8c94b48cbc3380fb9e6b1b0253b8d9222bb31f [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-21/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-21/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "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:0cd99ca24d8e8c98e67c542213511d985b8778b5bdcbb160e038429496686047" "/opt/rustwide/cargo-home/bin/cargo" "+1.59.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] c30078b67592f7ba97144a5220aecfc3ff0017f5c0db5a31803baf5502985136 [INFO] running `Command { std: "docker" "start" "-a" "c30078b67592f7ba97144a5220aecfc3ff0017f5c0db5a31803baf5502985136", kill_on_drop: false }` [INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression [INFO] [stdout] --> src/a_star.rs:34:19 [INFO] [stdout] | [INFO] [stdout] 34 | let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 34 - let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stdout] 34 + let absX = match point.x>self.goal.x{//TODO refactor [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression [INFO] [stdout] --> src/a_star.rs:38:19 [INFO] [stdout] | [INFO] [stdout] 38 | let absY = match(point.y>self.goal.y){ [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 38 - let absY = match(point.y>self.goal.y){ [INFO] [stdout] 38 + let absY = match point.y>self.goal.y{ [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `closedSet` [INFO] [stdout] --> src/a_star.rs:46:11 [INFO] [stdout] | [INFO] [stdout] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_closedSet` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cameFrom` [INFO] [stdout] --> src/a_star.rs:49:11 [INFO] [stdout] | [INFO] [stdout] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cameFrom` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/a_star.rs:46:7 [INFO] [stdout] | [INFO] [stdout] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [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/a_star.rs:49:7 [INFO] [stdout] | [INFO] [stdout] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stdout] | ----^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct is never constructed: `Board` [INFO] [stdout] --> src/a_star.rs:9:8 [INFO] [stdout] | [INFO] [stdout] 9 | struct Board{ [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `new` [INFO] [stdout] --> src/a_star.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | fn new(width : usize)->Board{ [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `newGScoreWithInfinity` [INFO] [stdout] --> src/a_star.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | fn newGScoreWithInfinity(&self) -> HashMap{ [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `heuristic_cost_estimate` [INFO] [stdout] --> src/a_star.rs:33:5 [INFO] [stdout] | [INFO] [stdout] 33 | fn heuristic_cost_estimate(&self, point:Point)->usize{ [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `a_star` [INFO] [stdout] --> src/a_star.rs:45:5 [INFO] [stdout] | [INFO] [stdout] 45 | fn a_star(&self) -> Option>{ [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `newGScoreWithInfinity` should have a snake case name [INFO] [stdout] --> src/a_star.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | fn newGScoreWithInfinity(&self) -> HashMap{ [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `new_gscore_with_infinity` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `gScore` should have a snake case name [INFO] [stdout] --> src/a_star.rs:24:11 [INFO] [stdout] | [INFO] [stdout] 24 | let mut gScore : HashMap = HashMap::new(); [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `g_score` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `absX` should have a snake case name [INFO] [stdout] --> src/a_star.rs:34:7 [INFO] [stdout] | [INFO] [stdout] 34 | let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stdout] | ^^^^ help: convert the identifier to snake case: `abs_x` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `absY` should have a snake case name [INFO] [stdout] --> src/a_star.rs:38:7 [INFO] [stdout] | [INFO] [stdout] 38 | let absY = match(point.y>self.goal.y){ [INFO] [stdout] | ^^^^ help: convert the identifier to snake case: `abs_y` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `closedSet` should have a snake case name [INFO] [stdout] --> src/a_star.rs:46:11 [INFO] [stdout] | [INFO] [stdout] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `closed_set` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `openSet` should have a snake case name [INFO] [stdout] --> src/a_star.rs:47:11 [INFO] [stdout] | [INFO] [stdout] 47 | let mut openSet : HashSet = HashSet::new();// The set of tentative nodes to be evaluated [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `open_set` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `cameFrom` should have a snake case name [INFO] [stdout] --> src/a_star.rs:49:11 [INFO] [stdout] | [INFO] [stdout] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `came_from` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `gScore` should have a snake case name [INFO] [stdout] --> src/a_star.rs:51:11 [INFO] [stdout] | [INFO] [stdout] 51 | let mut gScore = self.newGScoreWithInfinity(); [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `g_score` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `fScore` should have a snake case name [INFO] [stdout] --> src/a_star.rs:55:11 [INFO] [stdout] | [INFO] [stdout] 55 | let mut fScore = self.newGScoreWithInfinity(); [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `f_score` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling algolib v0.0.1 (/opt/rustwide/workdir) [INFO] [stdout] warning: 20 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `algolib::*` [INFO] [stdout] --> tests/test_sort.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use algolib::*; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression [INFO] [stdout] --> src/a_star.rs:34:19 [INFO] [stdout] | [INFO] [stdout] 34 | let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 34 - let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stdout] 34 + let absX = match point.x>self.goal.x{//TODO refactor [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression [INFO] [stdout] --> src/a_star.rs:38:19 [INFO] [stdout] | [INFO] [stdout] 38 | let absY = match(point.y>self.goal.y){ [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 38 - let absY = match(point.y>self.goal.y){ [INFO] [stdout] 38 + let absY = match point.y>self.goal.y{ [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `closedSet` [INFO] [stdout] --> src/a_star.rs:46:11 [INFO] [stdout] | [INFO] [stdout] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_closedSet` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cameFrom` [INFO] [stdout] --> src/a_star.rs:49:11 [INFO] [stdout] | [INFO] [stdout] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cameFrom` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/a_star.rs:46:7 [INFO] [stdout] | [INFO] [stdout] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [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/a_star.rs:49:7 [INFO] [stdout] | [INFO] [stdout] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stdout] | ----^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct is never constructed: `Board` [INFO] [stdout] --> src/a_star.rs:9:8 [INFO] [stdout] | [INFO] [stdout] 9 | struct Board{ [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `new` [INFO] [stdout] --> src/a_star.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | fn new(width : usize)->Board{ [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `newGScoreWithInfinity` [INFO] [stdout] --> src/a_star.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | fn newGScoreWithInfinity(&self) -> HashMap{ [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `heuristic_cost_estimate` [INFO] [stdout] --> src/a_star.rs:33:5 [INFO] [stdout] | [INFO] [stdout] 33 | fn heuristic_cost_estimate(&self, point:Point)->usize{ [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `a_star` [INFO] [stdout] --> src/a_star.rs:45:5 [INFO] [stdout] | [INFO] [stdout] 45 | fn a_star(&self) -> Option>{ [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `newGScoreWithInfinity` should have a snake case name [INFO] [stdout] --> src/a_star.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | fn newGScoreWithInfinity(&self) -> HashMap{ [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `new_gscore_with_infinity` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `gScore` should have a snake case name [INFO] [stdout] --> src/a_star.rs:24:11 [INFO] [stdout] | [INFO] [stdout] 24 | let mut gScore : HashMap = HashMap::new(); [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `g_score` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `absX` should have a snake case name [INFO] [stdout] --> src/a_star.rs:34:7 [INFO] [stdout] | [INFO] [stdout] 34 | let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stdout] | ^^^^ help: convert the identifier to snake case: `abs_x` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `absY` should have a snake case name [INFO] [stdout] --> src/a_star.rs:38:7 [INFO] [stdout] | [INFO] [stdout] 38 | let absY = match(point.y>self.goal.y){ [INFO] [stdout] | ^^^^ help: convert the identifier to snake case: `abs_y` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `closedSet` should have a snake case name [INFO] [stdout] --> src/a_star.rs:46:11 [INFO] [stdout] | [INFO] [stdout] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `closed_set` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `openSet` should have a snake case name [INFO] [stdout] --> src/a_star.rs:47:11 [INFO] [stdout] | [INFO] [stdout] 47 | let mut openSet : HashSet = HashSet::new();// The set of tentative nodes to be evaluated [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `open_set` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `cameFrom` should have a snake case name [INFO] [stdout] --> src/a_star.rs:49:11 [INFO] [stdout] | [INFO] [stdout] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `came_from` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `gScore` should have a snake case name [INFO] [stdout] --> src/a_star.rs:51:11 [INFO] [stdout] | [INFO] [stdout] 51 | let mut gScore = self.newGScoreWithInfinity(); [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `g_score` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `fScore` should have a snake case name [INFO] [stdout] --> src/a_star.rs:55:11 [INFO] [stdout] | [INFO] [stdout] 55 | let mut fScore = self.newGScoreWithInfinity(); [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `f_score` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 20 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.39s [INFO] running `Command { std: "docker" "inspect" "c30078b67592f7ba97144a5220aecfc3ff0017f5c0db5a31803baf5502985136", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c30078b67592f7ba97144a5220aecfc3ff0017f5c0db5a31803baf5502985136", kill_on_drop: false }` [INFO] [stdout] c30078b67592f7ba97144a5220aecfc3ff0017f5c0db5a31803baf5502985136 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-21/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-21/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "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:0cd99ca24d8e8c98e67c542213511d985b8778b5bdcbb160e038429496686047" "/opt/rustwide/cargo-home/bin/cargo" "+1.59.0" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 84070ab0bf3cbf210e18202a01f9ef6d44c4fee6139104be5d56ad3a4ac7aee8 [INFO] running `Command { std: "docker" "start" "-a" "84070ab0bf3cbf210e18202a01f9ef6d44c4fee6139104be5d56ad3a4ac7aee8", kill_on_drop: false }` [INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression [INFO] [stderr] --> src/a_star.rs:34:19 [INFO] [stderr] | [INFO] [stderr] 34 | let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 34 - let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stderr] 34 + let absX = match point.x>self.goal.x{//TODO refactor [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression [INFO] [stderr] --> src/a_star.rs:38:19 [INFO] [stderr] | [INFO] [stderr] 38 | let absY = match(point.y>self.goal.y){ [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 38 - let absY = match(point.y>self.goal.y){ [INFO] [stderr] 38 + let absY = match point.y>self.goal.y{ [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused variable: `closedSet` [INFO] [stderr] --> src/a_star.rs:46:11 [INFO] [stderr] | [INFO] [stderr] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_closedSet` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `cameFrom` [INFO] [stderr] --> src/a_star.rs:49:11 [INFO] [stderr] | [INFO] [stderr] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cameFrom` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/a_star.rs:46:7 [INFO] [stderr] | [INFO] [stderr] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [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/a_star.rs:49:7 [INFO] [stderr] | [INFO] [stderr] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stderr] | ----^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Board` [INFO] [stderr] --> src/a_star.rs:9:8 [INFO] [stderr] | [INFO] [stderr] 9 | struct Board{ [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/a_star.rs:19:5 [INFO] [stderr] | [INFO] [stderr] 19 | fn new(width : usize)->Board{ [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `newGScoreWithInfinity` [INFO] [stderr] --> src/a_star.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | fn newGScoreWithInfinity(&self) -> HashMap{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `heuristic_cost_estimate` [INFO] [stderr] --> src/a_star.rs:33:5 [INFO] [stderr] | [INFO] [stderr] 33 | fn heuristic_cost_estimate(&self, point:Point)->usize{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `a_star` [INFO] [stderr] --> src/a_star.rs:45:5 [INFO] [stderr] | [INFO] [stderr] 45 | fn a_star(&self) -> Option>{ [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method `newGScoreWithInfinity` should have a snake case name [INFO] [stderr] --> src/a_star.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | fn newGScoreWithInfinity(&self) -> HashMap{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `new_gscore_with_infinity` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `gScore` should have a snake case name [INFO] [stderr] --> src/a_star.rs:24:11 [INFO] [stderr] | [INFO] [stderr] 24 | let mut gScore : HashMap = HashMap::new(); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `g_score` [INFO] [stderr] [INFO] [stderr] warning: variable `absX` should have a snake case name [INFO] [stderr] --> src/a_star.rs:34:7 [INFO] [stderr] | [INFO] [stderr] 34 | let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stderr] | ^^^^ help: convert the identifier to snake case: `abs_x` [INFO] [stderr] [INFO] [stderr] warning: variable `absY` should have a snake case name [INFO] [stderr] --> src/a_star.rs:38:7 [INFO] [stderr] | [INFO] [stderr] 38 | let absY = match(point.y>self.goal.y){ [INFO] [stderr] | ^^^^ help: convert the identifier to snake case: `abs_y` [INFO] [stderr] [INFO] [stderr] warning: variable `closedSet` should have a snake case name [INFO] [stderr] --> src/a_star.rs:46:11 [INFO] [stderr] | [INFO] [stderr] 46 | let mut closedSet : HashSet = HashSet::new();// The set of nodes already evaluated. [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `closed_set` [INFO] [stderr] [INFO] [stderr] warning: variable `openSet` should have a snake case name [INFO] [stderr] --> src/a_star.rs:47:11 [INFO] [stderr] | [INFO] [stderr] 47 | let mut openSet : HashSet = HashSet::new();// The set of tentative nodes to be evaluated [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `open_set` [INFO] [stderr] [INFO] [stderr] warning: variable `cameFrom` should have a snake case name [INFO] [stderr] --> src/a_star.rs:49:11 [INFO] [stderr] | [INFO] [stderr] 49 | let mut cameFrom : HashMap = HashMap::new(); // The map of navigated nodes. [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `came_from` [INFO] [stderr] [INFO] [stderr] warning: variable `gScore` should have a snake case name [INFO] [stderr] --> src/a_star.rs:51:11 [INFO] [stderr] | [INFO] [stderr] 51 | let mut gScore = self.newGScoreWithInfinity(); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `g_score` [INFO] [stderr] [INFO] [stderr] warning: variable `fScore` should have a snake case name [INFO] [stderr] --> src/a_star.rs:55:11 [INFO] [stderr] | [INFO] [stderr] 55 | let mut fScore = self.newGScoreWithInfinity(); [INFO] [stderr] | ^^^^^^ help: convert the identifier to snake case: `f_score` [INFO] [stderr] [INFO] [stderr] warning: `algolib` (lib) generated 20 warnings [INFO] [stderr] warning: `algolib` (lib test) generated 20 warnings (20 duplicates) [INFO] [stderr] warning: unused import: `algolib::*` [INFO] [stderr] --> tests/test_sort.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use algolib::*; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: `algolib` (test "test_sort") generated 1 warning [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.01s [INFO] [stdout] [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/algolib-925d724fd38b8f57) [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/test_sort.rs (/opt/rustwide/target/debug/deps/test_sort-3bab065515ac79b2) [INFO] [stdout] [INFO] [stdout] running 2 tests [INFO] [stderr] Running tests/test_union_find.rs (/opt/rustwide/target/debug/deps/test_union_find-976457ee26d2c4e4) [INFO] [stdout] test test_multi_sort_shell_sort ... ok [INFO] [stdout] test test_multi_sort_sel_sort ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 8 tests [INFO] [stdout] test test_quick_find_connected ... ok [INFO] [stdout] test test_quick_union_connected ... ok [INFO] [stdout] test test_quick_union_root ... ok [INFO] [stdout] test test_quick_union_new ... ok [INFO] [stdout] test test_quick_union_union ... ok [INFO] [stdout] test test_quick_find_not_connected ... ok [INFO] [stdout] test test_quick_find_connected_bigger ... ok [INFO] [stdout] test test_quick_find_union ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 8 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stderr] Doc-tests algolib [INFO] [stdout] [INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression [INFO] [stdout] running 0 tests [INFO] [stderr] --> /opt/rustwide/workdir/src/a_star.rs:34:19 [INFO] [stdout] [INFO] [stderr] | [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stderr] 34 | let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stdout] [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 34 - let absX = match(point.x>self.goal.x){//TODO refactor [INFO] [stderr] 34 + let absX = match point.x>self.goal.x{//TODO refactor [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression [INFO] [stderr] --> /opt/rustwide/workdir/src/a_star.rs:38:19 [INFO] [stderr] | [INFO] [stderr] 38 | let absY = match(point.y>self.goal.y){ [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 38 - let absY = match(point.y>self.goal.y){ [INFO] [stderr] 38 + let absY = match point.y>self.goal.y{ [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: 2 warnings emitted [INFO] [stderr] [INFO] running `Command { std: "docker" "inspect" "84070ab0bf3cbf210e18202a01f9ef6d44c4fee6139104be5d56ad3a4ac7aee8", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "84070ab0bf3cbf210e18202a01f9ef6d44c4fee6139104be5d56ad3a4ac7aee8", kill_on_drop: false }` [INFO] [stdout] 84070ab0bf3cbf210e18202a01f9ef6d44c4fee6139104be5d56ad3a4ac7aee8