[INFO] cloning repository https://github.com/AddisonMink/strategy-rpg
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/AddisonMink/strategy-rpg" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAddisonMink%2Fstrategy-rpg", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAddisonMink%2Fstrategy-rpg'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] d91e61243e84364254163043eab14c5f62eecae8
[INFO] checking AddisonMink/strategy-rpg against master#36b21637e93b038453924d3c66821089e71d8baa for pr-143164
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAddisonMink%2Fstrategy-rpg" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/AddisonMink/strategy-rpg
[INFO] finished tweaking git repo https://github.com/AddisonMink/strategy-rpg
[INFO] tweaked toml for git repo https://github.com/AddisonMink/strategy-rpg written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/AddisonMink/strategy-rpg on toolchain 36b21637e93b038453924d3c66821089e71d8baa
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/AddisonMink/strategy-rpg already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded quad-rand v0.2.3
[INFO] [stderr]   Downloaded macroquad_macro v0.1.8
[INFO] [stderr]   Downloaded objc-rs v0.2.8
[INFO] [stderr]   Downloaded fontdue v0.9.3
[INFO] [stderr]   Downloaded miniquad v0.4.8
[INFO] [stderr]   Downloaded glam v0.27.0
[INFO] [stderr]   Downloaded macroquad v0.4.14
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cf8efcab8866f2cf4285301c7418e2f4f2a9b088c91ba69c40d5b659f81557f7" "/opt/rustwide/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 8e23ce2100055d37e357fe3d561edfa1021c6c13eedaa9f23f262f644b5fbba9
[INFO] running `Command { std: "docker" "start" "-a" "8e23ce2100055d37e357fe3d561edfa1021c6c13eedaa9f23f262f644b5fbba9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "8e23ce2100055d37e357fe3d561edfa1021c6c13eedaa9f23f262f644b5fbba9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8e23ce2100055d37e357fe3d561edfa1021c6c13eedaa9f23f262f644b5fbba9", kill_on_drop: false }`
[INFO] [stdout] 8e23ce2100055d37e357fe3d561edfa1021c6c13eedaa9f23f262f644b5fbba9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cf8efcab8866f2cf4285301c7418e2f4f2a9b088c91ba69c40d5b659f81557f7" "/opt/rustwide/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d4f0ac791f9f19a48c67623e7dad0519ed481a70a0bad26582b3f4190d8f52e6
[INFO] running `Command { std: "docker" "start" "-a" "d4f0ac791f9f19a48c67623e7dad0519ed481a70a0bad26582b3f4190d8f52e6", kill_on_drop: false }`
[INFO] [stderr]     Checking simd-adler32 v0.3.7
[INFO] [stderr]    Compiling libc v0.2.172
[INFO] [stderr]    Compiling miniquad v0.4.8
[INFO] [stderr]     Checking foldhash v0.1.5
[INFO] [stderr]     Checking ttf-parser v0.21.1
[INFO] [stderr]     Checking bytemuck v1.23.0
[INFO] [stderr]     Checking color_quant v1.1.0
[INFO] [stderr]    Compiling macroquad_macro v0.1.8
[INFO] [stderr]     Checking quad-rand v0.2.3
[INFO] [stderr]     Checking glam v0.27.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking hashbrown v0.15.3
[INFO] [stderr]     Checking miniz_oxide v0.8.8
[INFO] [stderr]     Checking fdeflate v0.3.7
[INFO] [stderr]     Checking flate2 v1.1.1
[INFO] [stderr]     Checking png v0.17.16
[INFO] [stderr]     Checking fontdue v0.9.3
[INFO] [stderr]     Checking image v0.24.9
[INFO] [stderr]     Checking macroquad v0.4.14
[INFO] [stderr]     Checking strategy_rpg v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `macroquad::prelude::trace`
[INFO] [stdout]  --> src/level/update/state/ending_turn.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use macroquad::prelude::trace;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `macroquad::prelude::trace`
[INFO] [stdout]  --> src/level/update/mod.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use macroquad::prelude::trace;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/level/update/mod.rs:188:13
[INFO] [stdout]     |
[INFO] [stdout] 188 |             (item.charges == 0)
[INFO] [stdout]     |             ^                 ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 188 -             (item.charges == 0)
[INFO] [stdout] 188 +             item.charges == 0
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::f32::consts::E`
[INFO] [stdout]  --> src/level/world/light_grid.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f32::consts::E;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `macroquad::color`
[INFO] [stdout]  --> src/level/world/light_grid.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use macroquad::color;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::engine::*`
[INFO] [stdout]  --> src/level/world/map.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::engine::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `macroquad::prelude::trace`
[INFO] [stdout]  --> src/level/update/state/ending_turn.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use macroquad::prelude::trace;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `macroquad::prelude::trace`
[INFO] [stdout]  --> src/level/update/mod.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use macroquad::prelude::trace;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/level/update/mod.rs:188:13
[INFO] [stdout]     |
[INFO] [stdout] 188 |             (item.charges == 0)
[INFO] [stdout]     |             ^                 ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 188 -             (item.charges == 0)
[INFO] [stdout] 188 +             item.charges == 0
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `macroquad::prelude::trace`
[INFO] [stdout]   --> src/level/world/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use macroquad::prelude::trace;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::f32::consts::E`
[INFO] [stdout]  --> src/level/world/light_grid.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f32::consts::E;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `macroquad::color`
[INFO] [stdout]  --> src/level/world/light_grid.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use macroquad::color;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::engine::*`
[INFO] [stdout]  --> src/level/world/map.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::engine::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `macroquad::prelude::trace`
[INFO] [stdout]   --> src/level/world/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use macroquad::prelude::trace;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/level/draw/mod.rs:131:15
[INFO] [stdout]     |
[INFO] [stdout] 131 | fn draw_state(world: &World, state: &State) {
[INFO] [stdout]     |               ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]  --> src/level/update/state/ending_turn.rs:5:19
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn transition(world: &mut World, state: &mut State) {
[INFO] [stdout]   |                   ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `id`
[INFO] [stdout]   --> src/level/update/state/ending_turn.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |         let id = world.end_turn();
[INFO] [stdout]    |             ^^ help: if this is intentional, prefix it with an underscore: `_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/level/draw/mod.rs:131:15
[INFO] [stdout]     |
[INFO] [stdout] 131 | fn draw_state(world: &World, state: &State) {
[INFO] [stdout]     |               ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result_code`
[INFO] [stdout]   --> src/level/update/state/mod.rs:35:23
[INFO] [stdout]    |
[INFO] [stdout] 35 |         State::Ending(result_code) => {}
[INFO] [stdout]    |                       ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_result_code`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]  --> src/level/update/state/ending_turn.rs:5:19
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn transition(world: &mut World, state: &mut State) {
[INFO] [stdout]   |                   ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `id`
[INFO] [stdout]   --> src/level/update/state/ending_turn.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |         let id = world.end_turn();
[INFO] [stdout]    |             ^^ help: if this is intentional, prefix it with an underscore: `_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]   --> src/level/world/item.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 63 |         world: &World,
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target_id`
[INFO] [stdout]   --> src/level/world/item.rs:65:9
[INFO] [stdout]    |
[INFO] [stdout] 65 |         target_id: UnitId,
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result_code`
[INFO] [stdout]   --> src/level/update/state/mod.rs:35:23
[INFO] [stdout]    |
[INFO] [stdout] 35 |         State::Ending(result_code) => {}
[INFO] [stdout]    |                       ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_result_code`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]   --> src/level/world/item.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 63 |         world: &World,
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target_id`
[INFO] [stdout]   --> src/level/world/item.rs:65:9
[INFO] [stdout]    |
[INFO] [stdout] 65 |         target_id: UnitId,
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_colors` is never used
[INFO] [stdout]  --> src/engine/color.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn add_colors(primary: Color, secondary: Color) -> Color {
[INFO] [stdout]   |        ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalize_color` is never used
[INFO] [stdout]   --> src/engine/color.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn normalize_color(color: Color) -> Color {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `next_point_light_id` is never read
[INFO] [stdout]   --> src/level/world/mod.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct World {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 45 |     next_point_light_id: u32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `add_point_light` and `remove_point_light` are never used
[INFO] [stdout]    --> src/level/world/mod.rs:148:12
[INFO] [stdout]     |
[INFO] [stdout] 52  | impl World {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 148 |     pub fn add_point_light(&mut self, radius: u16, color: Color, coord: Coord) -> PointLightId {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 158 |     pub fn remove_point_light(&mut self, id: PointLightId) -> Option<PointLight> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ActionTarget` is never used
[INFO] [stdout]   --> src/level/world/action.rs:75:10
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub enum ActionTarget {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ReachExit` is never constructed
[INFO] [stdout]  --> src/level/world/goal.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub enum Goal {
[INFO] [stdout]   |          ---- variant in this enum
[INFO] [stdout] 3 |     KillAllEnemies,
[INFO] [stdout] 4 |     ReachExit,
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Goal` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `id` is never read
[INFO] [stdout]   --> src/level/world/point_light.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout] 9  | pub struct PointLight {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] 10 |     pub id: PointLightId,
[INFO] [stdout]    |         ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PointLight` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/level/world/point_light.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl PointLight {
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 16 |     pub fn new(id: PointLightId, radius: u16, color: Color, coord: Coord) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `perlin_noise_1d` is never used
[INFO] [stdout]    --> src/util/algorithm.rs:103:8
[INFO] [stdout]     |
[INFO] [stdout] 103 | pub fn perlin_noise_1d(x: f32, period: f32, amplitude: f32, seed: u64) -> f32 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `color` is never used
[INFO] [stdout]    --> src/util/ui/button.rs:113:12
[INFO] [stdout]     |
[INFO] [stdout] 89  | impl ButtonBuilder {
[INFO] [stdout]     | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 113 |     pub fn color(mut self, color: Color) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_y` is never used
[INFO] [stdout]   --> src/util/ui/panel.rs:73:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl Panel {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 73 |     pub fn get_y(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `meter` is never used
[INFO] [stdout]    --> src/util/ui/panel.rs:283:12
[INFO] [stdout]     |
[INFO] [stdout] 226 | impl PanelBuilder {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 283 |     pub fn meter(mut self, value: u16, diff_value: u16, max_value: u16, color: Color) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_text` is never used
[INFO] [stdout]   --> src/util/grid.rs:42:8
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub fn draw_text(coord: Coord, text: &str, color: Color) {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_colors` is never used
[INFO] [stdout]  --> src/engine/color.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn add_colors(primary: Color, secondary: Color) -> Color {
[INFO] [stdout]   |        ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalize_color` is never used
[INFO] [stdout]   --> src/engine/color.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn normalize_color(color: Color) -> Color {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `next_point_light_id` is never read
[INFO] [stdout]   --> src/level/world/mod.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct World {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 45 |     next_point_light_id: u32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `add_point_light` and `remove_point_light` are never used
[INFO] [stdout]    --> src/level/world/mod.rs:148:12
[INFO] [stdout]     |
[INFO] [stdout] 52  | impl World {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 148 |     pub fn add_point_light(&mut self, radius: u16, color: Color, coord: Coord) -> PointLightId {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 158 |     pub fn remove_point_light(&mut self, id: PointLightId) -> Option<PointLight> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ActionTarget` is never used
[INFO] [stdout]   --> src/level/world/action.rs:75:10
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub enum ActionTarget {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ReachExit` is never constructed
[INFO] [stdout]  --> src/level/world/goal.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub enum Goal {
[INFO] [stdout]   |          ---- variant in this enum
[INFO] [stdout] 3 |     KillAllEnemies,
[INFO] [stdout] 4 |     ReachExit,
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Goal` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `id` is never read
[INFO] [stdout]   --> src/level/world/point_light.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout] 9  | pub struct PointLight {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] 10 |     pub id: PointLightId,
[INFO] [stdout]    |         ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PointLight` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/level/world/point_light.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl PointLight {
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 16 |     pub fn new(id: PointLightId, radius: u16, color: Color, coord: Coord) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `perlin_noise_1d` is never used
[INFO] [stdout]    --> src/util/algorithm.rs:103:8
[INFO] [stdout]     |
[INFO] [stdout] 103 | pub fn perlin_noise_1d(x: f32, period: f32, amplitude: f32, seed: u64) -> f32 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `color` is never used
[INFO] [stdout]    --> src/util/ui/button.rs:113:12
[INFO] [stdout]     |
[INFO] [stdout] 89  | impl ButtonBuilder {
[INFO] [stdout]     | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 113 |     pub fn color(mut self, color: Color) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_y` is never used
[INFO] [stdout]   --> src/util/ui/panel.rs:73:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl Panel {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 73 |     pub fn get_y(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `meter` is never used
[INFO] [stdout]    --> src/util/ui/panel.rs:283:12
[INFO] [stdout]     |
[INFO] [stdout] 226 | impl PanelBuilder {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 283 |     pub fn meter(mut self, value: u16, diff_value: u16, max_value: u16, color: Color) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_text` is never used
[INFO] [stdout]   --> src/util/grid.rs:42:8
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub fn draw_text(coord: Coord, text: &str, color: Color) {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 8.16s
[INFO] running `Command { std: "docker" "inspect" "d4f0ac791f9f19a48c67623e7dad0519ed481a70a0bad26582b3f4190d8f52e6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d4f0ac791f9f19a48c67623e7dad0519ed481a70a0bad26582b3f4190d8f52e6", kill_on_drop: false }`
[INFO] [stdout] d4f0ac791f9f19a48c67623e7dad0519ed481a70a0bad26582b3f4190d8f52e6
