[INFO] cloning repository https://github.com/jossse69/roguelike_project
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/jossse69/roguelike_project" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjossse69%2Froguelike_project", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjossse69%2Froguelike_project'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] ce09d7404d770a5d09968a2ed53561f2a6cb6cd5
[INFO] checking jossse69/roguelike_project against 1.95.0 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjossse69%2Froguelike_project" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/jossse69/roguelike_project
[INFO] finished tweaking git repo https://github.com/jossse69/roguelike_project
[INFO] tweaked toml for git repo https://github.com/jossse69/roguelike_project written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/jossse69/roguelike_project on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/jossse69/roguelike_project 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" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded cmake v0.1.50
[INFO] [stderr]   Downloaded thiserror-impl v1.0.47
[INFO] [stderr]   Downloaded libloading v0.8.0
[INFO] [stderr]   Downloaded thiserror v1.0.47
[INFO] [stderr]   Downloaded bracket-algorithm-traits v0.8.7
[INFO] [stderr]   Downloaded xml-rs v0.8.16
[INFO] [stderr]   Downloaded glutin_glx_sys v0.1.8
[INFO] [stderr]   Downloaded send_wrapper v0.2.0
[INFO] [stderr]   Downloaded bracket-rex v0.8.7
[INFO] [stderr]   Downloaded wayland-egl v0.29.5
[INFO] [stderr]   Downloaded tokio-executor v0.1.10
[INFO] [stderr]   Downloaded ndk-glue v0.5.2
[INFO] [stderr]   Downloaded cocoa-foundation v0.1.1
[INFO] [stderr]   Downloaded wasm-timer v0.1.3
[INFO] [stderr]   Downloaded glutin_egl_sys v0.1.6
[INFO] [stderr]   Downloaded flate2 v1.0.27
[INFO] [stderr]   Downloaded bracket-geometry v0.7.0
[INFO] [stderr]   Downloaded bracket-noise v0.8.7
[INFO] [stderr]   Downloaded bracket-pathfinding v0.8.7
[INFO] [stderr]   Downloaded memchr v2.6.1
[INFO] [stderr]   Downloaded bracket-random v0.8.7
[INFO] [stderr]   Downloaded ultraviolet v0.4.6
[INFO] [stderr]   Downloaded bracket-color v0.8.7
[INFO] [stderr]   Downloaded wide v0.4.6
[INFO] [stderr]   Downloaded ultraviolet v0.9.1
[INFO] [stderr]   Downloaded bracket-embedding v0.8.7
[INFO] [stderr]   Downloaded glutin v0.29.1
[INFO] [stderr]   Downloaded calloop v0.9.3
[INFO] [stderr]   Downloaded memmap2 v0.3.1
[INFO] [stderr]   Downloaded smithay-client-toolkit v0.15.4
[INFO] [stderr]   Downloaded aho-corasick v1.0.4
[INFO] [stderr]   Downloaded futures v0.1.31
[INFO] [stderr]   Downloaded winnow v0.5.15
[INFO] [stderr]   Downloaded nix v0.22.3
[INFO] [stderr]   Downloaded regex v1.9.4
[INFO] [stderr]   Downloaded bracket-geometry v0.8.7
[INFO] [stderr]   Downloaded tokio-timer v0.2.13
[INFO] [stderr]   Downloaded ndk v0.5.0
[INFO] [stderr]   Downloaded winit v0.26.1
[INFO] [stderr]   Downloaded regex-automata v0.3.7
[INFO] [stderr]   Downloaded bracket-terminal v0.8.7
[INFO] [stderr]   Downloaded object-pool v0.5.4
[INFO] [stderr]   Downloaded bracket-lib v0.8.7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 61e3d9b24bd62d0640b2c2463ec479a4dcefbeac07b1d256365f711f94fca2d6
[INFO] running `Command { std: "docker" "start" "-a" "61e3d9b24bd62d0640b2c2463ec479a4dcefbeac07b1d256365f711f94fca2d6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "61e3d9b24bd62d0640b2c2463ec479a4dcefbeac07b1d256365f711f94fca2d6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "61e3d9b24bd62d0640b2c2463ec479a4dcefbeac07b1d256365f711f94fca2d6", kill_on_drop: false }`
[INFO] [stdout] 61e3d9b24bd62d0640b2c2463ec479a4dcefbeac07b1d256365f711f94fca2d6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cb527d55d944d865c08fe4b5684767a164ac52ec1002a35e2647adcef214ae2a
[INFO] running `Command { std: "docker" "start" "-a" "cb527d55d944d865c08fe4b5684767a164ac52ec1002a35e2647adcef214ae2a", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.147
[INFO] [stderr]    Compiling proc-macro2 v1.0.66
[INFO] [stderr]    Compiling unicode-ident v1.0.11
[INFO] [stderr]    Compiling xml-rs v0.8.16
[INFO] [stderr]     Checking smallvec v1.11.0
[INFO] [stderr]     Checking bytemuck v1.13.1
[INFO] [stderr]     Checking memchr v2.6.1
[INFO] [stderr]    Compiling wayland-sys v0.29.5
[INFO] [stderr]     Checking libloading v0.8.0
[INFO] [stderr]     Checking lock_api v0.4.10
[INFO] [stderr]     Checking flate2 v1.0.27
[INFO] [stderr]    Compiling servo-fontconfig-sys v5.1.0
[INFO] [stderr]    Compiling thiserror v1.0.47
[INFO] [stderr]    Compiling num-traits v0.2.16
[INFO] [stderr]     Checking fdeflate v0.3.0
[INFO] [stderr]    Compiling smithay-client-toolkit v0.16.0
[INFO] [stderr]    Compiling crossfont v0.5.1
[INFO] [stderr]     Checking dlib v0.5.2
[INFO] [stderr]     Checking foreign-types-shared v0.3.1
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]     Checking arrayvec v0.5.2
[INFO] [stderr]     Checking cty v0.2.2
[INFO] [stderr]     Checking safe_arch v0.7.1
[INFO] [stderr]     Checking tiny-skia-path v0.7.0
[INFO] [stderr]     Checking safe_arch v0.5.2
[INFO] [stderr]     Checking regex-syntax v0.7.5
[INFO] [stderr]     Checking raw-window-handle v0.4.3
[INFO] [stderr]    Compiling wide v0.4.6
[INFO] [stderr]     Checking jpeg-decoder v0.3.0
[INFO] [stderr]     Checking png v0.17.10
[INFO] [stderr]    Compiling serde v1.0.188
[INFO] [stderr]     Checking wide v0.7.11
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking aho-corasick v1.0.4
[INFO] [stderr]     Checking anyhow v1.0.75
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]     Checking glow v0.11.2
[INFO] [stderr]    Compiling serde_json v1.0.105
[INFO] [stderr]    Compiling quote v1.0.33
[INFO] [stderr]    Compiling cc v1.0.83
[INFO] [stderr]     Checking ultraviolet v0.4.6
[INFO] [stderr]    Compiling glutin_glx_sys v0.1.8
[INFO] [stderr]    Compiling glutin_egl_sys v0.1.6
[INFO] [stderr]    Compiling syn v2.0.29
[INFO] [stderr]    Compiling wayland-scanner v0.29.5
[INFO] [stderr]     Checking num-integer v0.1.45
[INFO] [stderr]     Checking tiny-skia v0.7.0
[INFO] [stderr]     Checking nix v0.24.3
[INFO] [stderr]     Checking parking_lot_core v0.9.8
[INFO] [stderr]     Checking getrandom v0.2.10
[INFO] [stderr]     Checking nix v0.25.1
[INFO] [stderr]     Checking memmap2 v0.5.10
[INFO] [stderr]     Checking x11-dl v2.21.0
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking parking_lot_core v0.8.6
[INFO] [stderr]     Checking shared_library v0.1.9
[INFO] [stderr]     Checking mio v0.8.8
[INFO] [stderr]     Checking bracket-color v0.8.7
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand_xorshift v0.3.0
[INFO] [stderr]     Checking bracket-embedding v0.8.7
[INFO] [stderr]     Checking osmesa-sys v0.1.2
[INFO] [stderr]     Checking regex-automata v0.3.7
[INFO] [stderr]     Checking ultraviolet v0.9.1
[INFO] [stderr]     Checking image v0.24.7
[INFO] [stderr]     Checking bracket-geometry v0.7.0
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling wayland-client v0.29.5
[INFO] [stderr]    Compiling wayland-protocols v0.29.5
[INFO] [stderr]    Compiling cmake v0.1.50
[INFO] [stderr]     Checking parking_lot v0.11.2
[INFO] [stderr]     Checking xcursor v0.3.4
[INFO] [stderr]     Checking wayland-commons v0.29.5
[INFO] [stderr]     Checking object-pool v0.5.4
[INFO] [stderr]     Checking bracket-rex v0.8.7
[INFO] [stderr]    Compiling freetype-sys v0.13.1
[INFO] [stderr]    Compiling expat-sys v2.1.6
[INFO] [stderr]     Checking bracket-geometry v0.8.7
[INFO] [stderr]     Checking bracket-algorithm-traits v0.8.7
[INFO] [stderr]     Checking bracket-pathfinding v0.8.7
[INFO] [stderr]     Checking freetype-rs v0.26.0
[INFO] [stderr]     Checking servo-fontconfig v0.5.1
[INFO] [stderr]     Checking regex v1.9.4
[INFO] [stderr]     Checking bracket-random v0.8.7
[INFO] [stderr]     Checking bracket-noise v0.8.7
[INFO] [stderr]    Compiling thiserror-impl v1.0.47
[INFO] [stderr]    Compiling foreign-types-macros v0.2.3
[INFO] [stderr]    Compiling serde_derive v1.0.188
[INFO] [stderr]     Checking wayland-cursor v0.29.5
[INFO] [stderr]     Checking wayland-egl v0.29.5
[INFO] [stderr]     Checking foreign-types v0.5.0
[INFO] [stderr]     Checking calloop v0.10.6
[INFO] [stderr]     Checking sctk-adwaita v0.4.3
[INFO] [stderr]     Checking winit v0.27.5
[INFO] [stderr]     Checking glutin v0.29.1
[INFO] [stderr]     Checking bracket-terminal v0.8.7
[INFO] [stderr]     Checking bracket-lib v0.8.7
[INFO] [stderr]     Checking roguelike_project v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/player.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::map::{Map, self, TileType};
[INFO] [stdout]   |                       ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PopupWindow` and `self`
[INFO] [stdout]  --> src/player.rs:7:21
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::ui::{UI, PopupWindow, self};
[INFO] [stdout]   |                     ^^^^^^^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::seq::index`
[INFO] [stdout]  --> src/ui.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use rand::seq::index;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PopupWindow` and `self`
[INFO] [stdout]  --> src/item.rs:9:17
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::ui::{self, PopupWindow, UI};
[INFO] [stdout]   |                 ^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/mobs_loader.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::map::Map`
[INFO] [stdout]  --> src/mobs_loader.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::map::Map;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `color`
[INFO] [stdout]   --> src/main.rs:11:31
[INFO] [stdout]    |
[INFO] [stdout] 11 | use bracket_lib::{prelude::*, color};
[INFO] [stdout]    |                               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `entity::Entity`
[INFO] [stdout]   --> src/main.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use entity::Entity;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SCREEN_WIDTH`
[INFO] [stdout]   --> src/main.rs:17:26
[INFO] [stdout]    |
[INFO] [stdout] 17 | use map::{Map, TileType, SCREEN_WIDTH};
[INFO] [stdout]    |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/player.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::map::{Map, self, TileType};
[INFO] [stdout]   |                       ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PopupWindow` and `self`
[INFO] [stdout]  --> src/player.rs:7:21
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::ui::{UI, PopupWindow, self};
[INFO] [stdout]   |                     ^^^^^^^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::seq::index`
[INFO] [stdout]  --> src/ui.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use rand::seq::index;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PopupWindow` and `self`
[INFO] [stdout]  --> src/item.rs:9:17
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::ui::{self, PopupWindow, UI};
[INFO] [stdout]   |                 ^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/mobs_loader.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::map::Map`
[INFO] [stdout]  --> src/mobs_loader.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::map::Map;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `color`
[INFO] [stdout]   --> src/main.rs:11:31
[INFO] [stdout]    |
[INFO] [stdout] 11 | use bracket_lib::{prelude::*, color};
[INFO] [stdout]    |                               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `entity::Entity`
[INFO] [stdout]   --> src/main.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use entity::Entity;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SCREEN_WIDTH`
[INFO] [stdout]   --> src/main.rs:17:26
[INFO] [stdout]    |
[INFO] [stdout] 17 | use map::{Map, TileType, SCREEN_WIDTH};
[INFO] [stdout]    |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `active_popup_index`
[INFO] [stdout]   --> src/ui.rs:83:25
[INFO] [stdout]    |
[INFO] [stdout] 83 |             if let Some(active_popup_index) = self.active_popup {
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_active_popup_index`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `active_popup_index`
[INFO] [stdout]   --> src/ui.rs:83:25
[INFO] [stdout]    |
[INFO] [stdout] 83 |             if let Some(active_popup_index) = self.active_popup {
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_active_popup_index`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_idx`
[INFO] [stdout]    --> src/map.rs:137:13
[INFO] [stdout]     |
[INFO] [stdout] 137 |         let player_idx = map_idx(player_x, player_y);
[INFO] [stdout]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_idx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_idx`
[INFO] [stdout]    --> src/map.rs:137:13
[INFO] [stdout]     |
[INFO] [stdout] 137 |         let player_idx = map_idx(player_x, player_y);
[INFO] [stdout]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_idx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ctx`
[INFO] [stdout]   --> src/item.rs:61:27
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn inspect(&self, ctx: &mut BTerm, ui: &mut UI) {
[INFO] [stdout]    |                           ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ai_module_code`
[INFO] [stdout]   --> src/mobs_loader.rs:75:13
[INFO] [stdout]    |
[INFO] [stdout] 75 |         let ai_module_code = fs::read_to_string(ai_module_path)?;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ai_module_code`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `remove_popup` is never used
[INFO] [stdout]   --> src/ui.rs:69:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl UI {
[INFO] [stdout]    | ------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 69 |     pub fn remove_popup(&mut self, index: usize) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `update_content` is never used
[INFO] [stdout]    --> src/ui.rs:201:12
[INFO] [stdout]     |
[INFO] [stdout] 162 | impl PopupWindow {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 201 |     pub fn update_content(&mut self, index: usize, content: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `description` is never read
[INFO] [stdout]   --> src/mob.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub struct MobData {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub description: String,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MobData` 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: function `load_mob_data` is never used
[INFO] [stdout]   --> src/mob.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub fn load_mob_data(dir_path: &str) -> Result<MobData, Box<dyn std::error::Error>> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `mob_data`, `HP`, `max_HP`, `attack`, `defense`, and `speed` are never read
[INFO] [stdout]   --> src/mob.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct Mob {
[INFO] [stdout]    |            --- fields in this struct
[INFO] [stdout] 32 |     pub entity: Entity,
[INFO] [stdout] 33 |     mob_data: MobData,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 34 |     HP: i32,
[INFO] [stdout]    |     ^^
[INFO] [stdout] 35 |     max_HP: i32,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 36 |     attack: i32,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 37 |     defense: i32,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 38 |     speed: i32,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Mob` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_tile_revealed` is never used
[INFO] [stdout]    --> src/map.rs:133:12
[INFO] [stdout]     |
[INFO] [stdout]  79 | impl Map {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 133 |     pub fn set_tile_revealed(&mut self, x: i32, y: i32) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `value` and `onuse` are never read
[INFO] [stdout]   --> src/item.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct ItemData {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 12 |     pub name: String,
[INFO] [stdout] 13 |     pub value: i32,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 14 |     pub description: String,
[INFO] [stdout] 15 |     pub onuse: Option<OnUse>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ItemData` 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: fields `type`, `hunger_restoration`, and `thirst_quenching` are never read
[INFO] [stdout]   --> src/item.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct OnUse {
[INFO] [stdout]    |            ----- fields in this struct
[INFO] [stdout] 22 |     pub r#type: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 23 |     #[serde(default)]
[INFO] [stdout] 24 |     pub hunger_restoration: i32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 25 |     #[serde(default)]
[INFO] [stdout] 26 |     pub thirst_quenching: i32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `OnUse` 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: constant `MESSAGE_LOG_MAX_LINES` is never used
[INFO] [stdout]  --> src/ui_component.rs:6:7
[INFO] [stdout]   |
[INFO] [stdout] 6 | const MESSAGE_LOG_MAX_LINES: usize = 5; // Maximum lines in the message log
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UI` is never constructed
[INFO] [stdout]  --> src/ui_component.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct UI {
[INFO] [stdout]   |            ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `add_message`, `create_popup`, `update_popup_title`, `draw_popups`, and `draw` are never used
[INFO] [stdout]   --> src/ui_component.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl UI {
[INFO] [stdout]    | ------- associated items in this implementation
[INFO] [stdout] 14 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 21 |     pub fn add_message(&mut self, message: &str) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn create_popup(&mut self, x: i32, y: i32, width: i32, height: i32, title: &str) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn update_popup_title(&mut self, index: usize, title: &str) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn draw_popups(&self, ctx: &mut BTerm) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn draw(&self, ctx: &mut BTerm, player: &Player) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PopupWindow` is never constructed
[INFO] [stdout]    --> src/ui_component.rs:112:12
[INFO] [stdout]     |
[INFO] [stdout] 112 | pub struct PopupWindow {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `add_content`, `update_title`, and `draw` are never used
[INFO] [stdout]    --> src/ui_component.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 121 | impl PopupWindow {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 122 |     pub fn new(x: i32, y: i32, width: i32, height: i32, title: &str) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 133 |     pub fn add_content(&mut self, content: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub fn update_title(&mut self, title: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 141 |     pub fn draw(&self, ctx: &mut BTerm) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `HP` should have a snake case name
[INFO] [stdout]   --> src/mob.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     HP: i32,
[INFO] [stdout]    |     ^^ help: convert the identifier to snake case: `hp`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `max_HP` should have a snake case name
[INFO] [stdout]   --> src/mob.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     max_HP: i32,
[INFO] [stdout]    |     ^^^^^^ help: convert the identifier to snake case: `max_hp`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ctx`
[INFO] [stdout]   --> src/item.rs:61:27
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn inspect(&self, ctx: &mut BTerm, ui: &mut UI) {
[INFO] [stdout]    |                           ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ai_module_code`
[INFO] [stdout]   --> src/mobs_loader.rs:75:13
[INFO] [stdout]    |
[INFO] [stdout] 75 |         let ai_module_code = fs::read_to_string(ai_module_path)?;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ai_module_code`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `remove_popup` is never used
[INFO] [stdout]   --> src/ui.rs:69:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl UI {
[INFO] [stdout]    | ------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 69 |     pub fn remove_popup(&mut self, index: usize) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `update_content` is never used
[INFO] [stdout]    --> src/ui.rs:201:12
[INFO] [stdout]     |
[INFO] [stdout] 162 | impl PopupWindow {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 201 |     pub fn update_content(&mut self, index: usize, content: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `description` is never read
[INFO] [stdout]   --> src/mob.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub struct MobData {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub description: String,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MobData` 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: function `load_mob_data` is never used
[INFO] [stdout]   --> src/mob.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub fn load_mob_data(dir_path: &str) -> Result<MobData, Box<dyn std::error::Error>> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `mob_data`, `HP`, `max_HP`, `attack`, `defense`, and `speed` are never read
[INFO] [stdout]   --> src/mob.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct Mob {
[INFO] [stdout]    |            --- fields in this struct
[INFO] [stdout] 32 |     pub entity: Entity,
[INFO] [stdout] 33 |     mob_data: MobData,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 34 |     HP: i32,
[INFO] [stdout]    |     ^^
[INFO] [stdout] 35 |     max_HP: i32,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 36 |     attack: i32,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 37 |     defense: i32,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 38 |     speed: i32,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Mob` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_tile_revealed` is never used
[INFO] [stdout]    --> src/map.rs:133:12
[INFO] [stdout]     |
[INFO] [stdout]  79 | impl Map {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 133 |     pub fn set_tile_revealed(&mut self, x: i32, y: i32) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `value` and `onuse` are never read
[INFO] [stdout]   --> src/item.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct ItemData {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 12 |     pub name: String,
[INFO] [stdout] 13 |     pub value: i32,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 14 |     pub description: String,
[INFO] [stdout] 15 |     pub onuse: Option<OnUse>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ItemData` 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: fields `type`, `hunger_restoration`, and `thirst_quenching` are never read
[INFO] [stdout]   --> src/item.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct OnUse {
[INFO] [stdout]    |            ----- fields in this struct
[INFO] [stdout] 22 |     pub r#type: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 23 |     #[serde(default)]
[INFO] [stdout] 24 |     pub hunger_restoration: i32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 25 |     #[serde(default)]
[INFO] [stdout] 26 |     pub thirst_quenching: i32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `OnUse` 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: constant `MESSAGE_LOG_MAX_LINES` is never used
[INFO] [stdout]  --> src/ui_component.rs:6:7
[INFO] [stdout]   |
[INFO] [stdout] 6 | const MESSAGE_LOG_MAX_LINES: usize = 5; // Maximum lines in the message log
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UI` is never constructed
[INFO] [stdout]  --> src/ui_component.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct UI {
[INFO] [stdout]   |            ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `add_message`, `create_popup`, `update_popup_title`, `draw_popups`, and `draw` are never used
[INFO] [stdout]   --> src/ui_component.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl UI {
[INFO] [stdout]    | ------- associated items in this implementation
[INFO] [stdout] 14 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 21 |     pub fn add_message(&mut self, message: &str) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn create_popup(&mut self, x: i32, y: i32, width: i32, height: i32, title: &str) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn update_popup_title(&mut self, index: usize, title: &str) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn draw_popups(&self, ctx: &mut BTerm) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn draw(&self, ctx: &mut BTerm, player: &Player) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PopupWindow` is never constructed
[INFO] [stdout]    --> src/ui_component.rs:112:12
[INFO] [stdout]     |
[INFO] [stdout] 112 | pub struct PopupWindow {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `add_content`, `update_title`, and `draw` are never used
[INFO] [stdout]    --> src/ui_component.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 121 | impl PopupWindow {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 122 |     pub fn new(x: i32, y: i32, width: i32, height: i32, title: &str) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 133 |     pub fn add_content(&mut self, content: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub fn update_title(&mut self, title: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 141 |     pub fn draw(&self, ctx: &mut BTerm) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `HP` should have a snake case name
[INFO] [stdout]   --> src/mob.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     HP: i32,
[INFO] [stdout]    |     ^^ help: convert the identifier to snake case: `hp`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `max_HP` should have a snake case name
[INFO] [stdout]   --> src/mob.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     max_HP: i32,
[INFO] [stdout]    |     ^^^^^^ help: convert the identifier to snake case: `max_hp`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 40.48s
[INFO] running `Command { std: "docker" "inspect" "cb527d55d944d865c08fe4b5684767a164ac52ec1002a35e2647adcef214ae2a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cb527d55d944d865c08fe4b5684767a164ac52ec1002a35e2647adcef214ae2a", kill_on_drop: false }`
[INFO] [stdout] cb527d55d944d865c08fe4b5684767a164ac52ec1002a35e2647adcef214ae2a
