[INFO] cloning repository https://github.com/H-Chris233/Terminal-Pixel-Dungeon
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/H-Chris233/Terminal-Pixel-Dungeon" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FH-Chris233%2FTerminal-Pixel-Dungeon", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FH-Chris233%2FTerminal-Pixel-Dungeon'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] d0e7fc24384465946de1d89fe620b0381c0fda97
[INFO] testing H-Chris233/Terminal-Pixel-Dungeon against try#bd7d74411512a3dd3b35d2f699c51dd2557c7e7e+cargoflags=-Zbuild-dir-new-layout for pr-149852-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FH-Chris233%2FTerminal-Pixel-Dungeon" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/H-Chris233/Terminal-Pixel-Dungeon
[INFO] finished tweaking git repo https://github.com/H-Chris233/Terminal-Pixel-Dungeon
[INFO] tweaked toml for git repo https://github.com/H-Chris233/Terminal-Pixel-Dungeon written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/H-Chris233/Terminal-Pixel-Dungeon on toolchain bd7d74411512a3dd3b35d2f699c51dd2557c7e7e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/H-Chris233/Terminal-Pixel-Dungeon 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" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7d9ea60a31c4abb8404a56f0a6a6e728a8c4014c46c896a474ef8d68d0e054f3
[INFO] running `Command { std: "docker" "start" "-a" "7d9ea60a31c4abb8404a56f0a6a6e728a8c4014c46c896a474ef8d68d0e054f3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7d9ea60a31c4abb8404a56f0a6a6e728a8c4014c46c896a474ef8d68d0e054f3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7d9ea60a31c4abb8404a56f0a6a6e728a8c4014c46c896a474ef8d68d0e054f3", kill_on_drop: false }`
[INFO] [stdout] 7d9ea60a31c4abb8404a56f0a6a6e728a8c4014c46c896a474ef8d68d0e054f3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "build" "--frozen" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 7f8abe117d0b42b38136293d8851f9f4e53898b5c26731e8a240a167d8e1b22a
[INFO] running `Command { std: "docker" "start" "-a" "7f8abe117d0b42b38136293d8851f9f4e53898b5c26731e8a240a167d8e1b22a", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.94
[INFO] [stderr]    Compiling unicode-ident v1.0.18
[INFO] [stderr]    Compiling libc v0.2.171
[INFO] [stderr]    Compiling zerocopy v0.8.24
[INFO] [stderr]    Compiling autocfg v1.4.0
[INFO] [stderr]    Compiling getrandom v0.3.2
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling signal-hook v0.3.17
[INFO] [stderr]    Compiling bitflags v2.9.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling heck v0.5.0
[INFO] [stderr]    Compiling log v0.4.27
[INFO] [stderr]    Compiling smallvec v1.15.0
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]    Compiling scopeguard v1.2.0
[INFO] [stderr]    Compiling virtue v0.0.18
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling ryu v1.0.20
[INFO] [stderr]    Compiling itoa v1.0.15
[INFO] [stderr]    Compiling allocator-api2 v0.2.21
[INFO] [stderr]    Compiling unty v0.0.4
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]    Compiling paste v1.0.15
[INFO] [stderr]    Compiling linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling equivalent v1.0.2
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling unicode-width v0.1.14
[INFO] [stderr]    Compiling indoc v2.0.6
[INFO] [stderr]    Compiling cassowary v0.3.0
[INFO] [stderr]    Compiling anyhow v1.0.97
[INFO] [stderr]    Compiling thiserror v2.0.12
[INFO] [stderr]    Compiling seahash v4.1.0
[INFO] [stderr]    Compiling version_check v0.9.5
[INFO] [stderr]    Compiling rustix v1.0.5
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling convert_case v0.7.1
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling linux-raw-sys v0.9.3
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling compact_str v0.8.1
[INFO] [stderr]    Compiling bincode_derive v2.0.1
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling litrs v0.4.1
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling memchr v2.7.4
[INFO] [stderr]    Compiling syn v2.0.100
[INFO] [stderr]    Compiling signal-hook-registry v1.4.2
[INFO] [stderr]    Compiling mio v1.0.3
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling document-features v0.2.11
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling parking_lot v0.12.3
[INFO] [stderr]    Compiling signal-hook-mio v0.2.4
[INFO] [stderr]    Compiling lru v0.12.5
[INFO] [stderr]    Compiling unicode-truncate v1.1.0
[INFO] [stderr]    Compiling crossterm v0.28.1
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand v0.9.0
[INFO] [stderr]    Compiling hecs v0.10.5
[INFO] [stderr]    Compiling tempfile v3.19.1
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling strum_macros v0.27.2
[INFO] [stderr]    Compiling thiserror-impl v2.0.12
[INFO] [stderr]    Compiling derive_more-impl v2.0.1
[INFO] [stderr]    Compiling derive_more v2.0.1
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling strum v0.27.2
[INFO] [stderr]    Compiling ratatui v0.28.1
[INFO] [stderr]    Compiling bincode v2.0.1
[INFO] [stderr]    Compiling rand_pcg v0.9.0
[INFO] [stderr]    Compiling items v0.1.0 (/opt/rustwide/workdir/src/items)
[INFO] [stderr]    Compiling error v0.1.0 (/opt/rustwide/workdir/src/error)
[INFO] [stderr]    Compiling achievements v0.1.0 (/opt/rustwide/workdir/src/achievements)
[INFO] [stderr]    Compiling combat v0.1.0 (/opt/rustwide/workdir/src/combat)
[INFO] [stderr]    Compiling dungeon v0.1.0 (/opt/rustwide/workdir/src/dungeon)
[INFO] [stdout] warning: unused import: `Boss`
[INFO] [stdout]   --> src/dungeon/src/level.rs:18:20
[INFO] [stdout]    |
[INFO] [stdout] 18 | use combat::boss::{Boss, BossType};
[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 import: `Hazard`
[INFO] [stdout]   --> src/dungeon/src/lib.rs:14:34
[INFO] [stdout]    |
[INFO] [stdout] 14 | use crate::boss_room::{BossRoom, Hazard};
[INFO] [stdout]    |                                  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BossType`
[INFO] [stdout]   --> src/dungeon/src/lib.rs:19:26
[INFO] [stdout]    |
[INFO] [stdout] 19 | use combat::boss::{Boss, BossType};
[INFO] [stdout]    |                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling hero v0.1.0 (/opt/rustwide/workdir/src/hero)
[INFO] [stderr]    Compiling save v0.1.0 (/opt/rustwide/workdir/src/save)
[INFO] [stderr]    Compiling terminal_pixel_dungeon v0.0.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `combat::effect::EffectType`
[INFO] [stdout]     --> src/ecs.rs:1213:13
[INFO] [stdout]      |
[INFO] [stdout] 1213 |         use combat::effect::EffectType;
[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: `PlayerProgress` and `Wealth`
[INFO] [stdout]  --> src/systems.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     PlayerProgress, Position, Renderable, Resources, StatType, Stats, StatusEffects, TerrainType,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 6 |     Tile, Viewshed, Wealth,
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/systems.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]    --> src/systems.rs:362:13
[INFO] [stdout]     |
[INFO] [stdout] 362 |         use crate::event_bus::GameEvent;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `LogLevel`
[INFO] [stdout]    --> src/systems.rs:631:43
[INFO] [stdout]     |
[INFO] [stdout] 631 |         use crate::event_bus::{GameEvent, LogLevel};
[INFO] [stdout]     |                                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:1167:13
[INFO] [stdout]      |
[INFO] [stdout] 1167 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2529:13
[INFO] [stdout]      |
[INFO] [stdout] 2529 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:2530:13
[INFO] [stdout]      |
[INFO] [stdout] 2530 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2631:13
[INFO] [stdout]      |
[INFO] [stdout] 2631 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:3261:13
[INFO] [stdout]      |
[INFO] [stdout] 3261 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: ambiguous glob re-exports
[INFO] [stdout]   --> src/lib.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use event_bus::*;
[INFO] [stdout]    |         ------------ but the name `TurnPhase` in the type namespace is also re-exported here
[INFO] [stdout] ...
[INFO] [stdout] 18 | pub use save::*;
[INFO] [stdout]    |         ^^^^^^^ the name `TurnPhase` in the type namespace is first re-exported here
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(ambiguous_glob_reexports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2263:83
[INFO] [stdout]      |
[INFO] [stdout] 2263 | ...                   pos.x = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2264:83
[INFO] [stdout]      |
[INFO] [stdout] 2264 | ...                   pos.y = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2813:69
[INFO] [stdout]      |
[INFO] [stdout] 2813 | ...                   pos.x = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2814:69
[INFO] [stdout]      |
[INFO] [stdout] 2814 | ...                   pos.y = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/core/entity_factory.rs:147:13
[INFO] [stdout]     |
[INFO] [stdout] 147 |         let name = item.name();
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_name`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:509:33
[INFO] [stdout]     |
[INFO] [stdout] 509 |     fn before_handle(&mut self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:514:32
[INFO] [stdout]     |
[INFO] [stdout] 514 |     fn after_handle(&mut self, event: &GameEvent) {
[INFO] [stdout]     |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:541:29
[INFO] [stdout]     |
[INFO] [stdout] 541 |     fn should_handle(&self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `trap_entity`
[INFO] [stdout]    --> src/systems.rs:299:14
[INFO] [stdout]     |
[INFO] [stdout] 299 |         for (trap_entity, (trap_pos, tile)) in world.query::<(&Position, &Tile)>().iter() {
[INFO] [stdout]     |              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_trap_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:600:23
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]    --> src/systems.rs:600:42
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:857:9
[INFO] [stdout]     |
[INFO] [stdout] 857 |         world: &World,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ai_state`
[INFO] [stdout]    --> src/systems.rs:859:9
[INFO] [stdout]     |
[INFO] [stdout] 859 |         ai_state: &AIState,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ai_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `direction`
[INFO] [stdout]    --> src/systems.rs:898:17
[INFO] [stdout]     |
[INFO] [stdout] 898 |             let direction = Self::signum_to_direction(dx, dy);
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_direction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_state`
[INFO] [stdout]    --> src/systems.rs:926:17
[INFO] [stdout]     |
[INFO] [stdout] 926 |             let old_state = ai.state.clone();
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1147:23
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1147:42
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `damage`
[INFO] [stdout]     --> src/systems.rs:1351:34
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                  ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_critical`
[INFO] [stdout]     --> src/systems.rs:1351:42
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                          ^^^^^^^^^^^ help: try ignoring the field: `is_critical: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_ambush`
[INFO] [stdout]     --> src/systems.rs:1351:55
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                                       ^^^^^^^^^ help: try ignoring the field: `is_ambush: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1505:23
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1505:42
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_id`
[INFO] [stdout]     --> src/systems.rs:1520:49
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                 ^^^^^^^^^ help: try ignoring the field: `entity_id: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_name`
[INFO] [stdout]     --> src/systems.rs:1520:60
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                            ^^^^^^^^^^^ help: try ignoring the field: `entity_name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `killer`
[INFO] [stdout]     --> src/systems.rs:1520:73
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                                         ^^^^^^ help: try ignoring the field: `killer: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1537:44
[INFO] [stdout]      |
[INFO] [stdout] 1537 |                 AftermathEvent::LootDrop { entity, position } => {
[INFO] [stdout]      |                                            ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1545:50
[INFO] [stdout]      |
[INFO] [stdout] 1545 |                 AftermathEvent::ExperienceGain { entity, amount } => {
[INFO] [stdout]      |                                                  ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1569:14
[INFO] [stdout]      |
[INFO] [stdout] 1569 |         for (entity, (actor, stats)) in world.query::<(&Actor, &Stats)>().iter() {
[INFO] [stdout]      |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1586:18
[INFO] [stdout]      |
[INFO] [stdout] 1586 |             for (entity, (actor, pos)) in world.query::<(&Actor, &Position)>().iter() {
[INFO] [stdout]      |                  ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:1867:17
[INFO] [stdout]      |
[INFO] [stdout] 1867 |             let mut total_healing = 0u32;
[INFO] [stdout]      |                 ----^^^^^^^^^^^^^
[INFO] [stdout]      |                 |
[INFO] [stdout]      |                 help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_player`
[INFO] [stdout]     --> src/systems.rs:1858:53
[INFO] [stdout]      |
[INFO] [stdout] 1858 |         for (entity, mut status_effects, mut stats, is_player, entity_name) in entities_to_process {
[INFO] [stdout]      |                                                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_player`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2100:56
[INFO] [stdout]      |
[INFO] [stdout] 2100 | ...                   if let Ok((mut food_item, _)) = bincode::decode_from_slice::<Item, _>(
[INFO] [stdout]      |                                  ----^^^^^^^^^
[INFO] [stdout]      |                                  |
[INFO] [stdout]      |                                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2076:29
[INFO] [stdout]      |
[INFO] [stdout] 2076 |                         let player_id = player_entity.id();
[INFO] [stdout]      |                             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2392:60
[INFO] [stdout]      |
[INFO] [stdout] 2392 |                     if let Some((player_pos, item_to_drop, player_id)) = drop_result {
[INFO] [stdout]      |                                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2633:13
[INFO] [stdout]      |
[INFO] [stdout] 2633 |         let player_id = player_entity.id();
[INFO] [stdout]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2677:24
[INFO] [stdout]      |
[INFO] [stdout] 2677 |             if let Ok((mut food_item, _)) = bincode::decode_from_slice::<items::Item, _>(
[INFO] [stdout]      |                        ----^^^^^^^^^
[INFO] [stdout]      |                        |
[INFO] [stdout]      |                        help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2723:21
[INFO] [stdout]      |
[INFO] [stdout] 2723 |                 let mut success = true;
[INFO] [stdout]      |                     ----^^^^^^^
[INFO] [stdout]      |                     |
[INFO] [stdout]      |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `effect_description` is never read
[INFO] [stdout]     --> src/systems.rs:2722:46
[INFO] [stdout]      |
[INFO] [stdout] 2722 |                 let mut effect_description = String::new();
[INFO] [stdout]      |                                              ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message`
[INFO] [stdout]     --> src/systems.rs:3116:37
[INFO] [stdout]      |
[INFO] [stdout] 3116 | ...                   let message = "You descend to the next level...".to_string();
[INFO] [stdout]      |                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `weapon` is never read
[INFO] [stdout]     --> src/systems.rs:1410:5
[INFO] [stdout]      |
[INFO] [stdout] 1407 | struct SimpleCombatant<'a> {
[INFO] [stdout]      |        --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 1410 |     weapon: Option<crate::ecs::ECSItem>,
[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 `generate_level` is never used
[INFO] [stdout]     --> src/systems.rs:3641:8
[INFO] [stdout]      |
[INFO] [stdout] 3257 | impl DungeonSystem {
[INFO] [stdout]      | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 3641 |     fn generate_level(&mut self, world: &mut World, resources: &mut Resources, level: i32) {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `intent_queue` is never read
[INFO] [stdout]    --> src/turn_system.rs:278:5
[INFO] [stdout]     |
[INFO] [stdout] 272 | pub struct TurnSystem {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 278 |     intent_queue: BinaryHeap<ActionIntent>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `build_intent_queue` and `resolve_intents` are never used
[INFO] [stdout]    --> src/turn_system.rs:328:8
[INFO] [stdout]     |
[INFO] [stdout] 283 | impl TurnSystem {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 328 |     fn build_intent_queue(&mut self, world: &World) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 360 |     fn resolve_intents(&mut self, world: &mut World) -> Result<(), anyhow::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_player` is never used
[INFO] [stdout]    --> src/turn_system.rs:567:4
[INFO] [stdout]     |
[INFO] [stdout] 567 | fn is_player(world: &World, entity: Entity) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `combat::effect::EffectType`
[INFO] [stdout]     --> src/ecs.rs:1213:13
[INFO] [stdout]      |
[INFO] [stdout] 1213 |         use combat::effect::EffectType;
[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 import: `TurnPhase`
[INFO] [stdout]   --> src/game_loop.rs:19:26
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::turn_system::{TurnPhase, TurnState, TurnSystem};
[INFO] [stdout]    |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hecs::World`
[INFO] [stdout]  --> src/render/class_selection.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use hecs::World;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Clear`
[INFO] [stdout]   --> src/render/class_selection.rs:13:31
[INFO] [stdout]    |
[INFO] [stdout] 13 |     widgets::{Block, Borders, Clear, List, ListItem, Paragraph, Wrap},
[INFO] [stdout]    |                               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `backend::Backend`
[INFO] [stdout]   --> src/render/dungeon.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     backend::Backend,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hecs::World`
[INFO] [stdout]  --> src/render/game_over.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use hecs::World;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Clear` and `Gauge`
[INFO] [stdout]   --> src/render/game_over.rs:13:31
[INFO] [stdout]    |
[INFO] [stdout] 13 |     widgets::{Block, Borders, Clear, Gauge, Paragraph},
[INFO] [stdout]    |                               ^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hecs::World`
[INFO] [stdout]  --> src/render/menu.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use hecs::World;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PlayerProgress` and `Wealth`
[INFO] [stdout]  --> src/systems.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     PlayerProgress, Position, Renderable, Resources, StatType, Stats, StatusEffects, TerrainType,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 6 |     Tile, Viewshed, Wealth,
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/systems.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]    --> src/systems.rs:362:13
[INFO] [stdout]     |
[INFO] [stdout] 362 |         use crate::event_bus::GameEvent;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `LogLevel`
[INFO] [stdout]    --> src/systems.rs:631:43
[INFO] [stdout]     |
[INFO] [stdout] 631 |         use crate::event_bus::{GameEvent, LogLevel};
[INFO] [stdout]     |                                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:1167:13
[INFO] [stdout]      |
[INFO] [stdout] 1167 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2529:13
[INFO] [stdout]      |
[INFO] [stdout] 2529 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:2530:13
[INFO] [stdout]      |
[INFO] [stdout] 2530 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2631:13
[INFO] [stdout]      |
[INFO] [stdout] 2631 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:3261:13
[INFO] [stdout]      |
[INFO] [stdout] 3261 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2263:83
[INFO] [stdout]      |
[INFO] [stdout] 2263 | ...                   pos.x = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2264:83
[INFO] [stdout]      |
[INFO] [stdout] 2264 | ...                   pos.y = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2813:69
[INFO] [stdout]      |
[INFO] [stdout] 2813 | ...                   pos.x = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2814:69
[INFO] [stdout]      |
[INFO] [stdout] 2814 | ...                   pos.y = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/core/entity_factory.rs:147:13
[INFO] [stdout]     |
[INFO] [stdout] 147 |         let name = item.name();
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_name`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:509:33
[INFO] [stdout]     |
[INFO] [stdout] 509 |     fn before_handle(&mut self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:514:32
[INFO] [stdout]     |
[INFO] [stdout] 514 |     fn after_handle(&mut self, event: &GameEvent) {
[INFO] [stdout]     |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:541:29
[INFO] [stdout]     |
[INFO] [stdout] 541 |     fn should_handle(&self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `trap_entity`
[INFO] [stdout]    --> src/systems.rs:299:14
[INFO] [stdout]     |
[INFO] [stdout] 299 |         for (trap_entity, (trap_pos, tile)) in world.query::<(&Position, &Tile)>().iter() {
[INFO] [stdout]     |              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_trap_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:600:23
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]    --> src/systems.rs:600:42
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:857:9
[INFO] [stdout]     |
[INFO] [stdout] 857 |         world: &World,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ai_state`
[INFO] [stdout]    --> src/systems.rs:859:9
[INFO] [stdout]     |
[INFO] [stdout] 859 |         ai_state: &AIState,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ai_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `direction`
[INFO] [stdout]    --> src/systems.rs:898:17
[INFO] [stdout]     |
[INFO] [stdout] 898 |             let direction = Self::signum_to_direction(dx, dy);
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_direction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_state`
[INFO] [stdout]    --> src/systems.rs:926:17
[INFO] [stdout]     |
[INFO] [stdout] 926 |             let old_state = ai.state.clone();
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1147:23
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1147:42
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `damage`
[INFO] [stdout]     --> src/systems.rs:1351:34
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                  ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_critical`
[INFO] [stdout]     --> src/systems.rs:1351:42
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                          ^^^^^^^^^^^ help: try ignoring the field: `is_critical: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_ambush`
[INFO] [stdout]     --> src/systems.rs:1351:55
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                                       ^^^^^^^^^ help: try ignoring the field: `is_ambush: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1505:23
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1505:42
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_id`
[INFO] [stdout]     --> src/systems.rs:1520:49
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                 ^^^^^^^^^ help: try ignoring the field: `entity_id: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_name`
[INFO] [stdout]     --> src/systems.rs:1520:60
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                            ^^^^^^^^^^^ help: try ignoring the field: `entity_name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `killer`
[INFO] [stdout]     --> src/systems.rs:1520:73
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                                         ^^^^^^ help: try ignoring the field: `killer: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1537:44
[INFO] [stdout]      |
[INFO] [stdout] 1537 |                 AftermathEvent::LootDrop { entity, position } => {
[INFO] [stdout]      |                                            ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1545:50
[INFO] [stdout]      |
[INFO] [stdout] 1545 |                 AftermathEvent::ExperienceGain { entity, amount } => {
[INFO] [stdout]      |                                                  ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1569:14
[INFO] [stdout]      |
[INFO] [stdout] 1569 |         for (entity, (actor, stats)) in world.query::<(&Actor, &Stats)>().iter() {
[INFO] [stdout]      |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1586:18
[INFO] [stdout]      |
[INFO] [stdout] 1586 |             for (entity, (actor, pos)) in world.query::<(&Actor, &Position)>().iter() {
[INFO] [stdout]      |                  ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:1867:17
[INFO] [stdout]      |
[INFO] [stdout] 1867 |             let mut total_healing = 0u32;
[INFO] [stdout]      |                 ----^^^^^^^^^^^^^
[INFO] [stdout]      |                 |
[INFO] [stdout]      |                 help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_player`
[INFO] [stdout]     --> src/systems.rs:1858:53
[INFO] [stdout]      |
[INFO] [stdout] 1858 |         for (entity, mut status_effects, mut stats, is_player, entity_name) in entities_to_process {
[INFO] [stdout]      |                                                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_player`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2100:56
[INFO] [stdout]      |
[INFO] [stdout] 2100 | ...                   if let Ok((mut food_item, _)) = bincode::decode_from_slice::<Item, _>(
[INFO] [stdout]      |                                  ----^^^^^^^^^
[INFO] [stdout]      |                                  |
[INFO] [stdout]      |                                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2076:29
[INFO] [stdout]      |
[INFO] [stdout] 2076 |                         let player_id = player_entity.id();
[INFO] [stdout]      |                             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2392:60
[INFO] [stdout]      |
[INFO] [stdout] 2392 |                     if let Some((player_pos, item_to_drop, player_id)) = drop_result {
[INFO] [stdout]      |                                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2633:13
[INFO] [stdout]      |
[INFO] [stdout] 2633 |         let player_id = player_entity.id();
[INFO] [stdout]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2677:24
[INFO] [stdout]      |
[INFO] [stdout] 2677 |             if let Ok((mut food_item, _)) = bincode::decode_from_slice::<items::Item, _>(
[INFO] [stdout]      |                        ----^^^^^^^^^
[INFO] [stdout]      |                        |
[INFO] [stdout]      |                        help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2723:21
[INFO] [stdout]      |
[INFO] [stdout] 2723 |                 let mut success = true;
[INFO] [stdout]      |                     ----^^^^^^^
[INFO] [stdout]      |                     |
[INFO] [stdout]      |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `effect_description` is never read
[INFO] [stdout]     --> src/systems.rs:2722:46
[INFO] [stdout]      |
[INFO] [stdout] 2722 |                 let mut effect_description = String::new();
[INFO] [stdout]      |                                              ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message`
[INFO] [stdout]     --> src/systems.rs:3116:37
[INFO] [stdout]      |
[INFO] [stdout] 3116 | ...                   let message = "You descend to the next level...".to_string();
[INFO] [stdout]      |                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `update` is never used
[INFO] [stdout]    --> src/game_loop.rs:743:8
[INFO] [stdout]     |
[INFO] [stdout]  66 | impl<R: Renderer, I: InputSource<Event = crate::input::InputEvent>, C: Clock> GameLoop<R, I, C> {
[INFO] [stdout]     | ----------------------------------------------------------------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 743 |     fn update(&mut self) -> anyhow::Result<()> {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `last_render_time` and `render_cache` are never read
[INFO] [stdout]   --> src/renderer.rs:60:5
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub struct RatatuiRenderer {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 59 |     terminal: Terminal<ratatui::backend::CrosstermBackend<Stdout>>,
[INFO] [stdout] 60 |     last_render_time: std::time::Instant,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 61 |     render_cache: HashMap<(i32, i32, i32), RenderCacheEntry>, // x, y, z coordinates
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `symbol`, `fg`, `bg`, and `timestamp` are never read
[INFO] [stdout]   --> src/renderer.rs:73:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | struct RenderCacheEntry {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] 73 |     symbol: char,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 74 |     fg: TuiColor,
[INFO] [stdout]    |     ^^
[INFO] [stdout] 75 |     bg: TuiColor,
[INFO] [stdout]    |     ^^
[INFO] [stdout] 76 |     timestamp: std::time::Instant,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_messages` is never used
[INFO] [stdout]    --> src/renderer.rs:474:4
[INFO] [stdout]     |
[INFO] [stdout] 474 | fn format_messages(messages: &[String]) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `start_time` is never read
[INFO] [stdout]    --> src/renderer.rs:493:5
[INFO] [stdout]     |
[INFO] [stdout] 491 | pub struct GameClock {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] 492 |     tick_rate: Duration,
[INFO] [stdout] 493 |     start_time: std::time::SystemTime,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `weapon` is never read
[INFO] [stdout]     --> src/systems.rs:1410:5
[INFO] [stdout]      |
[INFO] [stdout] 1407 | struct SimpleCombatant<'a> {
[INFO] [stdout]      |        --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 1410 |     weapon: Option<crate::ecs::ECSItem>,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `generate_level` is never used
[INFO] [stdout]     --> src/systems.rs:3641:8
[INFO] [stdout]      |
[INFO] [stdout] 3257 | impl DungeonSystem {
[INFO] [stdout]      | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 3641 |     fn generate_level(&mut self, world: &mut World, resources: &mut Resources, level: i32) {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `intent_queue` is never read
[INFO] [stdout]    --> src/turn_system.rs:278:5
[INFO] [stdout]     |
[INFO] [stdout] 272 | pub struct TurnSystem {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 278 |     intent_queue: BinaryHeap<ActionIntent>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `build_intent_queue` and `resolve_intents` are never used
[INFO] [stdout]    --> src/turn_system.rs:328:8
[INFO] [stdout]     |
[INFO] [stdout] 283 | impl TurnSystem {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 328 |     fn build_intent_queue(&mut self, world: &World) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 360 |     fn resolve_intents(&mut self, world: &mut World) -> Result<(), anyhow::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_player` is never used
[INFO] [stdout]    --> src/turn_system.rs:567:4
[INFO] [stdout]     |
[INFO] [stdout] 567 | fn is_player(world: &World, entity: Entity) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/render/game_over.rs:207:28
[INFO] [stdout]     |
[INFO] [stdout] 207 |     fn get_game_statistics(&self, resources: &Resources) -> Vec<Line> {
[INFO] [stdout]     |                            ^^^^^ the lifetime is elided here    ^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 207 |     fn get_game_statistics(&self, resources: &Resources) -> Vec<Line<'_>> {
[INFO] [stdout]     |                                                                     ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 04s
[INFO] running `Command { std: "docker" "inspect" "7f8abe117d0b42b38136293d8851f9f4e53898b5c26731e8a240a167d8e1b22a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7f8abe117d0b42b38136293d8851f9f4e53898b5c26731e8a240a167d8e1b22a", kill_on_drop: false }`
[INFO] [stdout] 7f8abe117d0b42b38136293d8851f9f4e53898b5c26731e8a240a167d8e1b22a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "--no-run" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] cc0c65e90c46749a56e45ab1db069d10d8b7ac3d7195d2d550e1dadbdf4c1a04
[INFO] running `Command { std: "docker" "start" "-a" "cc0c65e90c46749a56e45ab1db069d10d8b7ac3d7195d2d550e1dadbdf4c1a04", kill_on_drop: false }`
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling regex-syntax v0.8.8
[INFO] [stderr]    Compiling half v2.6.0
[INFO] [stderr]    Compiling ciborium-io v0.2.2
[INFO] [stderr]    Compiling clap_lex v0.7.6
[INFO] [stderr]    Compiling plotters-backend v0.3.7
[INFO] [stderr]    Compiling anstyle v1.0.13
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling wait-timeout v0.2.1
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]    Compiling quick-error v1.2.3
[INFO] [stderr]    Compiling cast v0.3.0
[INFO] [stderr]    Compiling bit-vec v0.8.0
[INFO] [stderr]    Compiling walkdir v2.5.0
[INFO] [stderr]    Compiling tinytemplate v1.2.1
[INFO] [stderr]    Compiling rand_xorshift v0.4.0
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling tempfile v3.19.1
[INFO] [stderr]    Compiling clap_builder v4.5.50
[INFO] [stderr]    Compiling plotters-svg v0.3.7
[INFO] [stderr]    Compiling bit-set v0.8.0
[INFO] [stderr]    Compiling is-terminal v0.4.17
[INFO] [stderr]    Compiling diff v0.1.13
[INFO] [stderr]    Compiling unarray v0.1.4
[INFO] [stderr]    Compiling yansi v1.0.1
[INFO] [stderr]    Compiling oorandom v11.1.5
[INFO] [stderr]    Compiling anes v0.1.6
[INFO] [stderr]    Compiling lazy_static v1.5.0
[INFO] [stderr]    Compiling pretty_assertions v1.4.1
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling rusty-fork v0.3.1
[INFO] [stderr]    Compiling ciborium-ll v0.2.2
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling plotters v0.3.7
[INFO] [stderr]    Compiling ciborium v0.2.2
[INFO] [stderr]    Compiling criterion-plot v0.5.0
[INFO] [stderr]    Compiling crossbeam-deque v0.8.6
[INFO] [stderr]    Compiling hecs v0.10.5
[INFO] [stderr]    Compiling rayon v1.11.0
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]    Compiling clap v4.5.50
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling proptest v1.8.0
[INFO] [stderr]    Compiling ratatui v0.28.1
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling items v0.1.0 (/opt/rustwide/workdir/src/items)
[INFO] [stderr]    Compiling criterion v0.5.1
[INFO] [stderr]    Compiling combat v0.1.0 (/opt/rustwide/workdir/src/combat)
[INFO] [stderr]    Compiling dungeon v0.1.0 (/opt/rustwide/workdir/src/dungeon)
[INFO] [stdout] warning: unused import: `Boss`
[INFO] [stdout]   --> src/dungeon/src/level.rs:18:20
[INFO] [stdout]    |
[INFO] [stdout] 18 | use combat::boss::{Boss, BossType};
[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 import: `Hazard`
[INFO] [stdout]   --> src/dungeon/src/lib.rs:14:34
[INFO] [stdout]    |
[INFO] [stdout] 14 | use crate::boss_room::{BossRoom, Hazard};
[INFO] [stdout]    |                                  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BossType`
[INFO] [stdout]   --> src/dungeon/src/lib.rs:19:26
[INFO] [stdout]    |
[INFO] [stdout] 19 | use combat::boss::{Boss, BossType};
[INFO] [stdout]    |                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling hero v0.1.0 (/opt/rustwide/workdir/src/hero)
[INFO] [stderr]    Compiling save v0.1.0 (/opt/rustwide/workdir/src/save)
[INFO] [stderr]    Compiling terminal_pixel_dungeon v0.0.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `combat::effect::EffectType`
[INFO] [stdout]     --> src/ecs.rs:1213:13
[INFO] [stdout]      |
[INFO] [stdout] 1213 |         use combat::effect::EffectType;
[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: `PlayerProgress` and `Wealth`
[INFO] [stdout]  --> src/systems.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     PlayerProgress, Position, Renderable, Resources, StatType, Stats, StatusEffects, TerrainType,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 6 |     Tile, Viewshed, Wealth,
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/systems.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]    --> src/systems.rs:362:13
[INFO] [stdout]     |
[INFO] [stdout] 362 |         use crate::event_bus::GameEvent;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `LogLevel`
[INFO] [stdout]    --> src/systems.rs:631:43
[INFO] [stdout]     |
[INFO] [stdout] 631 |         use crate::event_bus::{GameEvent, LogLevel};
[INFO] [stdout]     |                                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:1167:13
[INFO] [stdout]      |
[INFO] [stdout] 1167 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2529:13
[INFO] [stdout]      |
[INFO] [stdout] 2529 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:2530:13
[INFO] [stdout]      |
[INFO] [stdout] 2530 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2631:13
[INFO] [stdout]      |
[INFO] [stdout] 2631 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:3261:13
[INFO] [stdout]      |
[INFO] [stdout] 3261 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: ambiguous glob re-exports
[INFO] [stdout]   --> src/lib.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use event_bus::*;
[INFO] [stdout]    |         ------------ but the name `TurnPhase` in the type namespace is also re-exported here
[INFO] [stdout] ...
[INFO] [stdout] 18 | pub use save::*;
[INFO] [stdout]    |         ^^^^^^^ the name `TurnPhase` in the type namespace is first re-exported here
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(ambiguous_glob_reexports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `combat::effect::EffectType`
[INFO] [stdout]     --> src/ecs.rs:1213:13
[INFO] [stdout]      |
[INFO] [stdout] 1213 |         use combat::effect::EffectType;
[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: `PlayerProgress` and `Wealth`
[INFO] [stdout]  --> src/systems.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     PlayerProgress, Position, Renderable, Resources, StatType, Stats, StatusEffects, TerrainType,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 6 |     Tile, Viewshed, Wealth,
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/systems.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]    --> src/systems.rs:362:13
[INFO] [stdout]     |
[INFO] [stdout] 362 |         use crate::event_bus::GameEvent;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `LogLevel`
[INFO] [stdout]    --> src/systems.rs:631:43
[INFO] [stdout]     |
[INFO] [stdout] 631 |         use crate::event_bus::{GameEvent, LogLevel};
[INFO] [stdout]     |                                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:1167:13
[INFO] [stdout]      |
[INFO] [stdout] 1167 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2529:13
[INFO] [stdout]      |
[INFO] [stdout] 2529 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:2530:13
[INFO] [stdout]      |
[INFO] [stdout] 2530 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2631:13
[INFO] [stdout]      |
[INFO] [stdout] 2631 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:3261:13
[INFO] [stdout]      |
[INFO] [stdout] 3261 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: ambiguous glob re-exports
[INFO] [stdout]   --> src/lib.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use event_bus::*;
[INFO] [stdout]    |         ------------ but the name `TurnPhase` in the type namespace is also re-exported here
[INFO] [stdout] ...
[INFO] [stdout] 18 | pub use save::*;
[INFO] [stdout]    |         ^^^^^^^ the name `TurnPhase` in the type namespace is first re-exported here
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(ambiguous_glob_reexports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2263:83
[INFO] [stdout]      |
[INFO] [stdout] 2263 | ...                   pos.x = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2264:83
[INFO] [stdout]      |
[INFO] [stdout] 2264 | ...                   pos.y = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2813:69
[INFO] [stdout]      |
[INFO] [stdout] 2813 | ...                   pos.x = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2814:69
[INFO] [stdout]      |
[INFO] [stdout] 2814 | ...                   pos.y = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/core/entity_factory.rs:147:13
[INFO] [stdout]     |
[INFO] [stdout] 147 |         let name = item.name();
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_name`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2263:83
[INFO] [stdout]      |
[INFO] [stdout] 2263 | ...                   pos.x = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2264:83
[INFO] [stdout]      |
[INFO] [stdout] 2264 | ...                   pos.y = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2813:69
[INFO] [stdout]      |
[INFO] [stdout] 2813 | ...                   pos.x = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2814:69
[INFO] [stdout]      |
[INFO] [stdout] 2814 | ...                   pos.y = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/core/entity_factory.rs:147:13
[INFO] [stdout]     |
[INFO] [stdout] 147 |         let name = item.name();
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_name`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:509:33
[INFO] [stdout]     |
[INFO] [stdout] 509 |     fn before_handle(&mut self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:514:32
[INFO] [stdout]     |
[INFO] [stdout] 514 |     fn after_handle(&mut self, event: &GameEvent) {
[INFO] [stdout]     |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:541:29
[INFO] [stdout]     |
[INFO] [stdout] 541 |     fn should_handle(&self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `trap_entity`
[INFO] [stdout]    --> src/systems.rs:299:14
[INFO] [stdout]     |
[INFO] [stdout] 299 |         for (trap_entity, (trap_pos, tile)) in world.query::<(&Position, &Tile)>().iter() {
[INFO] [stdout]     |              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_trap_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:600:23
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]    --> src/systems.rs:600:42
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:857:9
[INFO] [stdout]     |
[INFO] [stdout] 857 |         world: &World,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ai_state`
[INFO] [stdout]    --> src/systems.rs:859:9
[INFO] [stdout]     |
[INFO] [stdout] 859 |         ai_state: &AIState,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ai_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `direction`
[INFO] [stdout]    --> src/systems.rs:898:17
[INFO] [stdout]     |
[INFO] [stdout] 898 |             let direction = Self::signum_to_direction(dx, dy);
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_direction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_state`
[INFO] [stdout]    --> src/systems.rs:926:17
[INFO] [stdout]     |
[INFO] [stdout] 926 |             let old_state = ai.state.clone();
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1147:23
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1147:42
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `damage`
[INFO] [stdout]     --> src/systems.rs:1351:34
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                  ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_critical`
[INFO] [stdout]     --> src/systems.rs:1351:42
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                          ^^^^^^^^^^^ help: try ignoring the field: `is_critical: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_ambush`
[INFO] [stdout]     --> src/systems.rs:1351:55
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                                       ^^^^^^^^^ help: try ignoring the field: `is_ambush: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1505:23
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1505:42
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_id`
[INFO] [stdout]     --> src/systems.rs:1520:49
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                 ^^^^^^^^^ help: try ignoring the field: `entity_id: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_name`
[INFO] [stdout]     --> src/systems.rs:1520:60
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                            ^^^^^^^^^^^ help: try ignoring the field: `entity_name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `killer`
[INFO] [stdout]     --> src/systems.rs:1520:73
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                                         ^^^^^^ help: try ignoring the field: `killer: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1537:44
[INFO] [stdout]      |
[INFO] [stdout] 1537 |                 AftermathEvent::LootDrop { entity, position } => {
[INFO] [stdout]      |                                            ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1545:50
[INFO] [stdout]      |
[INFO] [stdout] 1545 |                 AftermathEvent::ExperienceGain { entity, amount } => {
[INFO] [stdout]      |                                                  ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1569:14
[INFO] [stdout]      |
[INFO] [stdout] 1569 |         for (entity, (actor, stats)) in world.query::<(&Actor, &Stats)>().iter() {
[INFO] [stdout]      |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1586:18
[INFO] [stdout]      |
[INFO] [stdout] 1586 |             for (entity, (actor, pos)) in world.query::<(&Actor, &Position)>().iter() {
[INFO] [stdout]      |                  ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:1867:17
[INFO] [stdout]      |
[INFO] [stdout] 1867 |             let mut total_healing = 0u32;
[INFO] [stdout]      |                 ----^^^^^^^^^^^^^
[INFO] [stdout]      |                 |
[INFO] [stdout]      |                 help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_player`
[INFO] [stdout]     --> src/systems.rs:1858:53
[INFO] [stdout]      |
[INFO] [stdout] 1858 |         for (entity, mut status_effects, mut stats, is_player, entity_name) in entities_to_process {
[INFO] [stdout]      |                                                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_player`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2100:56
[INFO] [stdout]      |
[INFO] [stdout] 2100 | ...                   if let Ok((mut food_item, _)) = bincode::decode_from_slice::<Item, _>(
[INFO] [stdout]      |                                  ----^^^^^^^^^
[INFO] [stdout]      |                                  |
[INFO] [stdout]      |                                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2076:29
[INFO] [stdout]      |
[INFO] [stdout] 2076 |                         let player_id = player_entity.id();
[INFO] [stdout]      |                             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2392:60
[INFO] [stdout]      |
[INFO] [stdout] 2392 |                     if let Some((player_pos, item_to_drop, player_id)) = drop_result {
[INFO] [stdout]      |                                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2633:13
[INFO] [stdout]      |
[INFO] [stdout] 2633 |         let player_id = player_entity.id();
[INFO] [stdout]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2677:24
[INFO] [stdout]      |
[INFO] [stdout] 2677 |             if let Ok((mut food_item, _)) = bincode::decode_from_slice::<items::Item, _>(
[INFO] [stdout]      |                        ----^^^^^^^^^
[INFO] [stdout]      |                        |
[INFO] [stdout]      |                        help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2723:21
[INFO] [stdout]      |
[INFO] [stdout] 2723 |                 let mut success = true;
[INFO] [stdout]      |                     ----^^^^^^^
[INFO] [stdout]      |                     |
[INFO] [stdout]      |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `effect_description` is never read
[INFO] [stdout]     --> src/systems.rs:2722:46
[INFO] [stdout]      |
[INFO] [stdout] 2722 |                 let mut effect_description = String::new();
[INFO] [stdout]      |                                              ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message`
[INFO] [stdout]     --> src/systems.rs:3116:37
[INFO] [stdout]      |
[INFO] [stdout] 3116 | ...                   let message = "You descend to the next level...".to_string();
[INFO] [stdout]      |                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `weapon` is never read
[INFO] [stdout]     --> src/systems.rs:1410:5
[INFO] [stdout]      |
[INFO] [stdout] 1407 | struct SimpleCombatant<'a> {
[INFO] [stdout]      |        --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 1410 |     weapon: Option<crate::ecs::ECSItem>,
[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 `generate_level` is never used
[INFO] [stdout]     --> src/systems.rs:3641:8
[INFO] [stdout]      |
[INFO] [stdout] 3257 | impl DungeonSystem {
[INFO] [stdout]      | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 3641 |     fn generate_level(&mut self, world: &mut World, resources: &mut Resources, level: i32) {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `intent_queue` is never read
[INFO] [stdout]    --> src/turn_system.rs:278:5
[INFO] [stdout]     |
[INFO] [stdout] 272 | pub struct TurnSystem {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 278 |     intent_queue: BinaryHeap<ActionIntent>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `build_intent_queue` and `resolve_intents` are never used
[INFO] [stdout]    --> src/turn_system.rs:328:8
[INFO] [stdout]     |
[INFO] [stdout] 283 | impl TurnSystem {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 328 |     fn build_intent_queue(&mut self, world: &World) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 360 |     fn resolve_intents(&mut self, world: &mut World) -> Result<(), anyhow::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_player` is never used
[INFO] [stdout]    --> src/turn_system.rs:567:4
[INFO] [stdout]     |
[INFO] [stdout] 567 | fn is_player(world: &World, entity: Entity) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:509:33
[INFO] [stdout]     |
[INFO] [stdout] 509 |     fn before_handle(&mut self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:514:32
[INFO] [stdout]     |
[INFO] [stdout] 514 |     fn after_handle(&mut self, event: &GameEvent) {
[INFO] [stdout]     |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:541:29
[INFO] [stdout]     |
[INFO] [stdout] 541 |     fn should_handle(&self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/event_bus.rs:2265:13
[INFO] [stdout]      |
[INFO] [stdout] 2265 |         let mut counting_middleware = CountingMiddleware::new();
[INFO] [stdout]      |             ----^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `counting_middleware`
[INFO] [stdout]     --> src/event_bus.rs:2281:13
[INFO] [stdout]      |
[INFO] [stdout] 2281 |         let counting_middleware = CountingMiddleware::new();
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_counting_middleware`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/event_bus.rs:2309:13
[INFO] [stdout]      |
[INFO] [stdout] 2309 |         let mut test_handler = TestHandler::new();
[INFO] [stdout]      |             ----^^^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `call_count_clone`
[INFO] [stdout]     --> src/event_bus.rs:2306:13
[INFO] [stdout]      |
[INFO] [stdout] 2306 |         let call_count_clone = handler_call_count.clone();
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_call_count_clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/event_bus.rs:2393:13
[INFO] [stdout]      |
[INFO] [stdout] 2393 |         let mut stats_handler = CombatStatsHandler::new(Some(1)); // 假设玩家ID是1
[INFO] [stdout]      |             ----^^^^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/event_bus.rs:2430:13
[INFO] [stdout]      |
[INFO] [stdout] 2430 |         let mut state_tracker = GameStateTracker::new();
[INFO] [stdout]      |             ----^^^^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/event_bus.rs:2451:13
[INFO] [stdout]      |
[INFO] [stdout] 2451 |         let mut stats = EventStatistics::new();
[INFO] [stdout]      |             ----^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `stats`
[INFO] [stdout]     --> src/event_bus.rs:2451:13
[INFO] [stdout]      |
[INFO] [stdout] 2451 |         let mut stats = EventStatistics::new();
[INFO] [stdout]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stats`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `trap_entity`
[INFO] [stdout]    --> src/systems.rs:299:14
[INFO] [stdout]     |
[INFO] [stdout] 299 |         for (trap_entity, (trap_pos, tile)) in world.query::<(&Position, &Tile)>().iter() {
[INFO] [stdout]     |              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_trap_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:600:23
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]    --> src/systems.rs:600:42
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:857:9
[INFO] [stdout]     |
[INFO] [stdout] 857 |         world: &World,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ai_state`
[INFO] [stdout]    --> src/systems.rs:859:9
[INFO] [stdout]     |
[INFO] [stdout] 859 |         ai_state: &AIState,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ai_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `direction`
[INFO] [stdout]    --> src/systems.rs:898:17
[INFO] [stdout]     |
[INFO] [stdout] 898 |             let direction = Self::signum_to_direction(dx, dy);
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_direction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_state`
[INFO] [stdout]    --> src/systems.rs:926:17
[INFO] [stdout]     |
[INFO] [stdout] 926 |             let old_state = ai.state.clone();
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1147:23
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1147:42
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `damage`
[INFO] [stdout]     --> src/systems.rs:1351:34
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                  ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_critical`
[INFO] [stdout]     --> src/systems.rs:1351:42
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                          ^^^^^^^^^^^ help: try ignoring the field: `is_critical: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_ambush`
[INFO] [stdout]     --> src/systems.rs:1351:55
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                                       ^^^^^^^^^ help: try ignoring the field: `is_ambush: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1505:23
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1505:42
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_id`
[INFO] [stdout]     --> src/systems.rs:1520:49
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                 ^^^^^^^^^ help: try ignoring the field: `entity_id: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_name`
[INFO] [stdout]     --> src/systems.rs:1520:60
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                            ^^^^^^^^^^^ help: try ignoring the field: `entity_name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `killer`
[INFO] [stdout]     --> src/systems.rs:1520:73
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                                         ^^^^^^ help: try ignoring the field: `killer: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1537:44
[INFO] [stdout]      |
[INFO] [stdout] 1537 |                 AftermathEvent::LootDrop { entity, position } => {
[INFO] [stdout]      |                                            ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1545:50
[INFO] [stdout]      |
[INFO] [stdout] 1545 |                 AftermathEvent::ExperienceGain { entity, amount } => {
[INFO] [stdout]      |                                                  ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1569:14
[INFO] [stdout]      |
[INFO] [stdout] 1569 |         for (entity, (actor, stats)) in world.query::<(&Actor, &Stats)>().iter() {
[INFO] [stdout]      |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1586:18
[INFO] [stdout]      |
[INFO] [stdout] 1586 |             for (entity, (actor, pos)) in world.query::<(&Actor, &Position)>().iter() {
[INFO] [stdout]      |                  ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:1867:17
[INFO] [stdout]      |
[INFO] [stdout] 1867 |             let mut total_healing = 0u32;
[INFO] [stdout]      |                 ----^^^^^^^^^^^^^
[INFO] [stdout]      |                 |
[INFO] [stdout]      |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_player`
[INFO] [stdout]     --> src/systems.rs:1858:53
[INFO] [stdout]      |
[INFO] [stdout] 1858 |         for (entity, mut status_effects, mut stats, is_player, entity_name) in entities_to_process {
[INFO] [stdout]      |                                                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_player`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2100:56
[INFO] [stdout]      |
[INFO] [stdout] 2100 | ...                   if let Ok((mut food_item, _)) = bincode::decode_from_slice::<Item, _>(
[INFO] [stdout]      |                                  ----^^^^^^^^^
[INFO] [stdout]      |                                  |
[INFO] [stdout]      |                                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2076:29
[INFO] [stdout]      |
[INFO] [stdout] 2076 |                         let player_id = player_entity.id();
[INFO] [stdout]      |                             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2392:60
[INFO] [stdout]      |
[INFO] [stdout] 2392 |                     if let Some((player_pos, item_to_drop, player_id)) = drop_result {
[INFO] [stdout]      |                                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2633:13
[INFO] [stdout]      |
[INFO] [stdout] 2633 |         let player_id = player_entity.id();
[INFO] [stdout]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2677:24
[INFO] [stdout]      |
[INFO] [stdout] 2677 |             if let Ok((mut food_item, _)) = bincode::decode_from_slice::<items::Item, _>(
[INFO] [stdout]      |                        ----^^^^^^^^^
[INFO] [stdout]      |                        |
[INFO] [stdout]      |                        help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2723:21
[INFO] [stdout]      |
[INFO] [stdout] 2723 |                 let mut success = true;
[INFO] [stdout]      |                     ----^^^^^^^
[INFO] [stdout]      |                     |
[INFO] [stdout]      |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `effect_description` is never read
[INFO] [stdout]     --> src/systems.rs:2722:46
[INFO] [stdout]      |
[INFO] [stdout] 2722 |                 let mut effect_description = String::new();
[INFO] [stdout]      |                                              ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message`
[INFO] [stdout]     --> src/systems.rs:3116:37
[INFO] [stdout]      |
[INFO] [stdout] 3116 | ...                   let message = "You descend to the next level...".to_string();
[INFO] [stdout]      |                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `enemy`
[INFO] [stdout]     --> src/systems.rs:4862:13
[INFO] [stdout]      |
[INFO] [stdout] 4862 |         let enemy = create_enemy(&mut world, 5, 6); // Enemy to the south
[INFO] [stdout]      |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_enemy`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_call_count` and `get_last_event` are never used
[INFO] [stdout]     --> src/event_bus.rs:1989:12
[INFO] [stdout]      |
[INFO] [stdout] 1981 |     impl TestHandler {
[INFO] [stdout]      |     ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1989 |         fn get_call_count(&self) -> usize {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1993 |         fn get_last_event(&self) -> Option<String> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `weapon` is never read
[INFO] [stdout]     --> src/systems.rs:1410:5
[INFO] [stdout]      |
[INFO] [stdout] 1407 | struct SimpleCombatant<'a> {
[INFO] [stdout]      |        --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 1410 |     weapon: Option<crate::ecs::ECSItem>,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `generate_level` is never used
[INFO] [stdout]     --> src/systems.rs:3641:8
[INFO] [stdout]      |
[INFO] [stdout] 3257 | impl DungeonSystem {
[INFO] [stdout]      | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 3641 |     fn generate_level(&mut self, world: &mut World, resources: &mut Resources, level: i32) {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `intent_queue` is never read
[INFO] [stdout]    --> src/turn_system.rs:278:5
[INFO] [stdout]     |
[INFO] [stdout] 272 | pub struct TurnSystem {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 278 |     intent_queue: BinaryHeap<ActionIntent>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `build_intent_queue` and `resolve_intents` are never used
[INFO] [stdout]    --> src/turn_system.rs:328:8
[INFO] [stdout]     |
[INFO] [stdout] 283 | impl TurnSystem {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 328 |     fn build_intent_queue(&mut self, world: &World) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 360 |     fn resolve_intents(&mut self, world: &mut World) -> Result<(), anyhow::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_player` is never used
[INFO] [stdout]    --> src/turn_system.rs:567:4
[INFO] [stdout]     |
[INFO] [stdout] 567 | fn is_player(world: &World, entity: Entity) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `collect` that must be used
[INFO] [stdout]     --> src/event_bus.rs:1965:9
[INFO] [stdout]      |
[INFO] [stdout] 1965 |         event_bus.drain().collect::<Vec<_>>();
[INFO] [stdout]      |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: if you really need to exhaust the iterator, consider `.for_each(drop)` instead
[INFO] [stdout]      = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]      |
[INFO] [stdout] 1965 |         let _ = event_bus.drain().collect::<Vec<_>>();
[INFO] [stdout]      |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_test_world` is never used
[INFO] [stdout]  --> tests/dungeon_turn_costs_test.rs:9:4
[INFO] [stdout]   |
[INFO] [stdout] 9 | fn create_test_world() -> (World, Resources) {
[INFO] [stdout]   |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> tests/save_turn_state_integration.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::path::PathBuf;
[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 import: `terminal_pixel_dungeon::turn_system::*`
[INFO] [stdout]   --> tests/ai_energy_integration_test.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use terminal_pixel_dungeon::turn_system::*;
[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 import: `EventBus`
[INFO] [stdout]   --> tests/ai_energy_integration_test.rs:14:41
[INFO] [stdout]    |
[INFO] [stdout] 14 | use terminal_pixel_dungeon::event_bus::{EventBus, GameEvent};
[INFO] [stdout]    |                                         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_entity`
[INFO] [stdout]   --> tests/save_turn_state_integration.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |     let player_entity = ecs_world.world.spawn((
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_entity`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> tests/save_turn_state_integration.rs:243:9
[INFO] [stdout]     |
[INFO] [stdout] 243 |     let mut loaded_data = save_system.load_game(1).expect("Failed to load v1 game");
[INFO] [stdout]     |         ----^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_entity`
[INFO] [stdout]    --> tests/save_turn_state_integration.rs:186:9
[INFO] [stdout]     |
[INFO] [stdout] 186 |     let player_entity = ecs_world.world.spawn((
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player`
[INFO] [stdout]   --> tests/ai_energy_integration_test.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 21 |     let player = ecs_world.world.spawn((
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_player`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `enemy2`
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:110:9
[INFO] [stdout]     |
[INFO] [stdout] 110 |     let enemy2 = spawn_enemy(&mut ecs_world.world, 13, 10, "Goblin2", 80, AIType::Aggressive);
[INFO] [stdout]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_enemy2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `enemy3`
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:111:9
[INFO] [stdout]     |
[INFO] [stdout] 111 |     let enemy3 = spawn_enemy(&mut ecs_world.world, 14, 10, "Goblin3", 120, AIType::Aggressive);
[INFO] [stdout]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_enemy3`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:349:9
[INFO] [stdout]     |
[INFO] [stdout] 349 |     let mut decision_count = 0;
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:350:9
[INFO] [stdout]     |
[INFO] [stdout] 350 |     let mut target_change_count = 0;
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `decision_count`
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:349:9
[INFO] [stdout]     |
[INFO] [stdout] 349 |     let mut decision_count = 0;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_decision_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target_change_count`
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:350:9
[INFO] [stdout]     |
[INFO] [stdout] 350 |     let mut target_change_count = 0;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_change_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `targets`
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:391:9
[INFO] [stdout]     |
[INFO] [stdout] 391 |     let targets = *target_arc.lock().unwrap();
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_targets`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_entity`
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:402:10
[INFO] [stdout]     |
[INFO] [stdout] 402 |     let (player_entity, player_pos) = ecs_world.world.query::<(&Player, &Position)>()
[INFO] [stdout]     |          ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_pos`
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:402:25
[INFO] [stdout]     |
[INFO] [stdout] 402 |     let (player_entity, player_pos) = ecs_world.world.query::<(&Player, &Position)>()
[INFO] [stdout]     |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `final_energy`
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:482:13
[INFO] [stdout]     |
[INFO] [stdout] 482 |         let final_energy = ecs_world.world.get::<&Energy>(enemy).unwrap().current;
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_energy`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]    --> tests/ai_energy_integration_test.rs:474:13
[INFO] [stdout]     |
[INFO] [stdout] 474 |     assert!(energy >= 0, "Energy should not go negative");
[INFO] [stdout]     |             ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `combat::effect::EffectType`
[INFO] [stdout]     --> src/ecs.rs:1213:13
[INFO] [stdout]      |
[INFO] [stdout] 1213 |         use combat::effect::EffectType;
[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 import: `TurnPhase`
[INFO] [stdout]   --> src/game_loop.rs:19:26
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::turn_system::{TurnPhase, TurnState, TurnSystem};
[INFO] [stdout]    |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hecs::World`
[INFO] [stdout]  --> src/render/class_selection.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use hecs::World;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Clear`
[INFO] [stdout]   --> src/render/class_selection.rs:13:31
[INFO] [stdout]    |
[INFO] [stdout] 13 |     widgets::{Block, Borders, Clear, List, ListItem, Paragraph, Wrap},
[INFO] [stdout]    |                               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `backend::Backend`
[INFO] [stdout]   --> src/render/dungeon.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     backend::Backend,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hecs::World`
[INFO] [stdout]  --> src/render/game_over.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use hecs::World;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Clear` and `Gauge`
[INFO] [stdout]   --> src/render/game_over.rs:13:31
[INFO] [stdout]    |
[INFO] [stdout] 13 |     widgets::{Block, Borders, Clear, Gauge, Paragraph},
[INFO] [stdout]    |                               ^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hecs::World`
[INFO] [stdout]  --> src/render/menu.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use hecs::World;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PlayerProgress` and `Wealth`
[INFO] [stdout]  --> src/systems.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     PlayerProgress, Position, Renderable, Resources, StatType, Stats, StatusEffects, TerrainType,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 6 |     Tile, Viewshed, Wealth,
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/systems.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]    --> src/systems.rs:362:13
[INFO] [stdout]     |
[INFO] [stdout] 362 |         use crate::event_bus::GameEvent;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `LogLevel`
[INFO] [stdout]    --> src/systems.rs:631:43
[INFO] [stdout]     |
[INFO] [stdout] 631 |         use crate::event_bus::{GameEvent, LogLevel};
[INFO] [stdout]     |                                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:1167:13
[INFO] [stdout]      |
[INFO] [stdout] 1167 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2529:13
[INFO] [stdout]      |
[INFO] [stdout] 2529 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:2530:13
[INFO] [stdout]      |
[INFO] [stdout] 2530 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2631:13
[INFO] [stdout]      |
[INFO] [stdout] 2631 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:3261:13
[INFO] [stdout]      |
[INFO] [stdout] 3261 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_handled_events` and `clear` are never used
[INFO] [stdout]   --> tests/event_bus_taxonomy_tests.rs:30:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl TestHandler {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 30 |     fn get_handled_events(&self) -> Vec<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 34 |     fn clear(&self) {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> tests/hunger_system_tests.rs:54:9
[INFO] [stdout]    |
[INFO] [stdout] 54 |     for i in 0..10 {
[INFO] [stdout]    |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> tests/hunger_system_tests.rs:99:9
[INFO] [stdout]    |
[INFO] [stdout] 99 |     for i in 0..20 {
[INFO] [stdout]    |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event_logger`
[INFO] [stdout]    --> tests/hunger_system_tests.rs:145:9
[INFO] [stdout]     |
[INFO] [stdout] 145 |     let event_logger = |event: &GameEvent| {
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_logger`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> tests/hunger_system_tests.rs:150:9
[INFO] [stdout]     |
[INFO] [stdout] 150 |     for i in 0..10 {
[INFO] [stdout]     |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> tests/hunger_system_tests.rs:372:9
[INFO] [stdout]     |
[INFO] [stdout] 372 |     for i in 0..10 {
[INFO] [stdout]     |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player`
[INFO] [stdout]    --> tests/hunger_system_tests.rs:397:9
[INFO] [stdout]     |
[INFO] [stdout] 397 |     let player = ecs_world.world.spawn((
[INFO] [stdout]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_player`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_player_entity` is never used
[INFO] [stdout]   --> tests/hunger_system_tests.rs:18:4
[INFO] [stdout]    |
[INFO] [stdout] 18 | fn find_player_entity(world: &hecs::World) -> Option<hecs::Entity> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `combat::effect::EffectType`
[INFO] [stdout]     --> src/ecs.rs:1213:13
[INFO] [stdout]      |
[INFO] [stdout] 1213 |         use combat::effect::EffectType;
[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 import: `TurnPhase`
[INFO] [stdout]   --> src/game_loop.rs:19:26
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::turn_system::{TurnPhase, TurnState, TurnSystem};
[INFO] [stdout]    |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hecs::World`
[INFO] [stdout]  --> src/render/class_selection.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use hecs::World;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Clear`
[INFO] [stdout]   --> src/render/class_selection.rs:13:31
[INFO] [stdout]    |
[INFO] [stdout] 13 |     widgets::{Block, Borders, Clear, List, ListItem, Paragraph, Wrap},
[INFO] [stdout]    |                               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `backend::Backend`
[INFO] [stdout]   --> src/render/dungeon.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     backend::Backend,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hecs::World`
[INFO] [stdout]  --> src/render/game_over.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use hecs::World;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Clear` and `Gauge`
[INFO] [stdout]   --> src/render/game_over.rs:13:31
[INFO] [stdout]    |
[INFO] [stdout] 13 |     widgets::{Block, Borders, Clear, Gauge, Paragraph},
[INFO] [stdout]    |                               ^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hecs::World`
[INFO] [stdout]  --> src/render/menu.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use hecs::World;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PlayerProgress` and `Wealth`
[INFO] [stdout]  --> src/systems.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     PlayerProgress, Position, Renderable, Resources, StatType, Stats, StatusEffects, TerrainType,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 6 |     Tile, Viewshed, Wealth,
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/systems.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]    --> src/systems.rs:362:13
[INFO] [stdout]     |
[INFO] [stdout] 362 |         use crate::event_bus::GameEvent;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `LogLevel`
[INFO] [stdout]    --> src/systems.rs:631:43
[INFO] [stdout]     |
[INFO] [stdout] 631 |         use crate::event_bus::{GameEvent, LogLevel};
[INFO] [stdout]     |                                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:1167:13
[INFO] [stdout]      |
[INFO] [stdout] 1167 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2529:13
[INFO] [stdout]      |
[INFO] [stdout] 2529 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:2530:13
[INFO] [stdout]      |
[INFO] [stdout] 2530 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stdout]     --> src/systems.rs:2631:13
[INFO] [stdout]      |
[INFO] [stdout] 2631 |         use crate::event_bus::GameEvent;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stdout]     --> src/systems.rs:3261:13
[INFO] [stdout]      |
[INFO] [stdout] 3261 |         use crate::turn_system::energy_costs;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2263:83
[INFO] [stdout]      |
[INFO] [stdout] 2263 | ...                   pos.x = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2264:83
[INFO] [stdout]      |
[INFO] [stdout] 2264 | ...                   pos.y = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2813:69
[INFO] [stdout]      |
[INFO] [stdout] 2813 | ...                   pos.x = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2814:69
[INFO] [stdout]      |
[INFO] [stdout] 2814 | ...                   pos.y = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/core/entity_factory.rs:147:13
[INFO] [stdout]     |
[INFO] [stdout] 147 |         let name = item.name();
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_name`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2263:83
[INFO] [stdout]      |
[INFO] [stdout] 2263 | ...                   pos.x = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2264:83
[INFO] [stdout]      |
[INFO] [stdout] 2264 | ...                   pos.y = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stdout]      |                                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2813:69
[INFO] [stdout]      |
[INFO] [stdout] 2813 | ...                   pos.x = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stdout]     --> src/systems.rs:2814:69
[INFO] [stdout]      |
[INFO] [stdout] 2814 | ...                   pos.y = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stdout]      |                                                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/core/entity_factory.rs:147:13
[INFO] [stdout]     |
[INFO] [stdout] 147 |         let name = item.name();
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_name`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:509:33
[INFO] [stdout]     |
[INFO] [stdout] 509 |     fn before_handle(&mut self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:514:32
[INFO] [stdout]     |
[INFO] [stdout] 514 |     fn after_handle(&mut self, event: &GameEvent) {
[INFO] [stdout]     |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:541:29
[INFO] [stdout]     |
[INFO] [stdout] 541 |     fn should_handle(&self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `trap_entity`
[INFO] [stdout]    --> src/systems.rs:299:14
[INFO] [stdout]     |
[INFO] [stdout] 299 |         for (trap_entity, (trap_pos, tile)) in world.query::<(&Position, &Tile)>().iter() {
[INFO] [stdout]     |              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_trap_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:600:23
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]    --> src/systems.rs:600:42
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:857:9
[INFO] [stdout]     |
[INFO] [stdout] 857 |         world: &World,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ai_state`
[INFO] [stdout]    --> src/systems.rs:859:9
[INFO] [stdout]     |
[INFO] [stdout] 859 |         ai_state: &AIState,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ai_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `direction`
[INFO] [stdout]    --> src/systems.rs:898:17
[INFO] [stdout]     |
[INFO] [stdout] 898 |             let direction = Self::signum_to_direction(dx, dy);
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_direction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_state`
[INFO] [stdout]    --> src/systems.rs:926:17
[INFO] [stdout]     |
[INFO] [stdout] 926 |             let old_state = ai.state.clone();
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1147:23
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1147:42
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `damage`
[INFO] [stdout]     --> src/systems.rs:1351:34
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                  ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_critical`
[INFO] [stdout]     --> src/systems.rs:1351:42
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                          ^^^^^^^^^^^ help: try ignoring the field: `is_critical: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_ambush`
[INFO] [stdout]     --> src/systems.rs:1351:55
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                                       ^^^^^^^^^ help: try ignoring the field: `is_ambush: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1505:23
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1505:42
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_id`
[INFO] [stdout]     --> src/systems.rs:1520:49
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                 ^^^^^^^^^ help: try ignoring the field: `entity_id: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_name`
[INFO] [stdout]     --> src/systems.rs:1520:60
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                            ^^^^^^^^^^^ help: try ignoring the field: `entity_name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `killer`
[INFO] [stdout]     --> src/systems.rs:1520:73
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                                         ^^^^^^ help: try ignoring the field: `killer: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1537:44
[INFO] [stdout]      |
[INFO] [stdout] 1537 |                 AftermathEvent::LootDrop { entity, position } => {
[INFO] [stdout]      |                                            ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1545:50
[INFO] [stdout]      |
[INFO] [stdout] 1545 |                 AftermathEvent::ExperienceGain { entity, amount } => {
[INFO] [stdout]      |                                                  ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1569:14
[INFO] [stdout]      |
[INFO] [stdout] 1569 |         for (entity, (actor, stats)) in world.query::<(&Actor, &Stats)>().iter() {
[INFO] [stdout]      |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1586:18
[INFO] [stdout]      |
[INFO] [stdout] 1586 |             for (entity, (actor, pos)) in world.query::<(&Actor, &Position)>().iter() {
[INFO] [stdout]      |                  ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:1867:17
[INFO] [stdout]      |
[INFO] [stdout] 1867 |             let mut total_healing = 0u32;
[INFO] [stdout]      |                 ----^^^^^^^^^^^^^
[INFO] [stdout]      |                 |
[INFO] [stdout]      |                 help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_player`
[INFO] [stdout]     --> src/systems.rs:1858:53
[INFO] [stdout]      |
[INFO] [stdout] 1858 |         for (entity, mut status_effects, mut stats, is_player, entity_name) in entities_to_process {
[INFO] [stdout]      |                                                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_player`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2100:56
[INFO] [stdout]      |
[INFO] [stdout] 2100 | ...                   if let Ok((mut food_item, _)) = bincode::decode_from_slice::<Item, _>(
[INFO] [stdout]      |                                  ----^^^^^^^^^
[INFO] [stdout]      |                                  |
[INFO] [stdout]      |                                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2076:29
[INFO] [stdout]      |
[INFO] [stdout] 2076 |                         let player_id = player_entity.id();
[INFO] [stdout]      |                             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2392:60
[INFO] [stdout]      |
[INFO] [stdout] 2392 |                     if let Some((player_pos, item_to_drop, player_id)) = drop_result {
[INFO] [stdout]      |                                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2633:13
[INFO] [stdout]      |
[INFO] [stdout] 2633 |         let player_id = player_entity.id();
[INFO] [stdout]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2677:24
[INFO] [stdout]      |
[INFO] [stdout] 2677 |             if let Ok((mut food_item, _)) = bincode::decode_from_slice::<items::Item, _>(
[INFO] [stdout]      |                        ----^^^^^^^^^
[INFO] [stdout]      |                        |
[INFO] [stdout]      |                        help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2723:21
[INFO] [stdout]      |
[INFO] [stdout] 2723 |                 let mut success = true;
[INFO] [stdout]      |                     ----^^^^^^^
[INFO] [stdout]      |                     |
[INFO] [stdout]      |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `effect_description` is never read
[INFO] [stdout]     --> src/systems.rs:2722:46
[INFO] [stdout]      |
[INFO] [stdout] 2722 |                 let mut effect_description = String::new();
[INFO] [stdout]      |                                              ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message`
[INFO] [stdout]     --> src/systems.rs:3116:37
[INFO] [stdout]      |
[INFO] [stdout] 3116 | ...                   let message = "You descend to the next level...".to_string();
[INFO] [stdout]      |                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `update` is never used
[INFO] [stdout]    --> src/game_loop.rs:743:8
[INFO] [stdout]     |
[INFO] [stdout]  66 | impl<R: Renderer, I: InputSource<Event = crate::input::InputEvent>, C: Clock> GameLoop<R, I, C> {
[INFO] [stdout]     | ----------------------------------------------------------------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 743 |     fn update(&mut self) -> anyhow::Result<()> {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `last_render_time` and `render_cache` are never read
[INFO] [stdout]   --> src/renderer.rs:60:5
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub struct RatatuiRenderer {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 59 |     terminal: Terminal<ratatui::backend::CrosstermBackend<Stdout>>,
[INFO] [stdout] 60 |     last_render_time: std::time::Instant,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 61 |     render_cache: HashMap<(i32, i32, i32), RenderCacheEntry>, // x, y, z coordinates
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `symbol`, `fg`, `bg`, and `timestamp` are never read
[INFO] [stdout]   --> src/renderer.rs:73:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | struct RenderCacheEntry {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] 73 |     symbol: char,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 74 |     fg: TuiColor,
[INFO] [stdout]    |     ^^
[INFO] [stdout] 75 |     bg: TuiColor,
[INFO] [stdout]    |     ^^
[INFO] [stdout] 76 |     timestamp: std::time::Instant,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_messages` is never used
[INFO] [stdout]    --> src/renderer.rs:474:4
[INFO] [stdout]     |
[INFO] [stdout] 474 | fn format_messages(messages: &[String]) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `start_time` is never read
[INFO] [stdout]    --> src/renderer.rs:493:5
[INFO] [stdout]     |
[INFO] [stdout] 491 | pub struct GameClock {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] 492 |     tick_rate: Duration,
[INFO] [stdout] 493 |     start_time: std::time::SystemTime,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `weapon` is never read
[INFO] [stdout]     --> src/systems.rs:1410:5
[INFO] [stdout]      |
[INFO] [stdout] 1407 | struct SimpleCombatant<'a> {
[INFO] [stdout]      |        --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 1410 |     weapon: Option<crate::ecs::ECSItem>,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `generate_level` is never used
[INFO] [stdout]     --> src/systems.rs:3641:8
[INFO] [stdout]      |
[INFO] [stdout] 3257 | impl DungeonSystem {
[INFO] [stdout]      | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 3641 |     fn generate_level(&mut self, world: &mut World, resources: &mut Resources, level: i32) {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `intent_queue` is never read
[INFO] [stdout]    --> src/turn_system.rs:278:5
[INFO] [stdout]     |
[INFO] [stdout] 272 | pub struct TurnSystem {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 278 |     intent_queue: BinaryHeap<ActionIntent>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `build_intent_queue` and `resolve_intents` are never used
[INFO] [stdout]    --> src/turn_system.rs:328:8
[INFO] [stdout]     |
[INFO] [stdout] 283 | impl TurnSystem {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 328 |     fn build_intent_queue(&mut self, world: &World) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 360 |     fn resolve_intents(&mut self, world: &mut World) -> Result<(), anyhow::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_player` is never used
[INFO] [stdout]    --> src/turn_system.rs:567:4
[INFO] [stdout]     |
[INFO] [stdout] 567 | fn is_player(world: &World, entity: Entity) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/render/game_over.rs:207:28
[INFO] [stdout]     |
[INFO] [stdout] 207 |     fn get_game_statistics(&self, resources: &Resources) -> Vec<Line> {
[INFO] [stdout]     |                            ^^^^^ the lifetime is elided here    ^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 207 |     fn get_game_statistics(&self, resources: &Resources) -> Vec<Line<'_>> {
[INFO] [stdout]     |                                                                     ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:509:33
[INFO] [stdout]     |
[INFO] [stdout] 509 |     fn before_handle(&mut self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:514:32
[INFO] [stdout]     |
[INFO] [stdout] 514 |     fn after_handle(&mut self, event: &GameEvent) {
[INFO] [stdout]     |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]    --> src/event_bus.rs:541:29
[INFO] [stdout]     |
[INFO] [stdout] 541 |     fn should_handle(&self, event: &GameEvent) -> bool {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/event_bus.rs:2265:13
[INFO] [stdout]      |
[INFO] [stdout] 2265 |         let mut counting_middleware = CountingMiddleware::new();
[INFO] [stdout]      |             ----^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `counting_middleware`
[INFO] [stdout]     --> src/event_bus.rs:2281:13
[INFO] [stdout]      |
[INFO] [stdout] 2281 |         let counting_middleware = CountingMiddleware::new();
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_counting_middleware`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/event_bus.rs:2309:13
[INFO] [stdout]      |
[INFO] [stdout] 2309 |         let mut test_handler = TestHandler::new();
[INFO] [stdout]      |             ----^^^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `call_count_clone`
[INFO] [stdout]     --> src/event_bus.rs:2306:13
[INFO] [stdout]      |
[INFO] [stdout] 2306 |         let call_count_clone = handler_call_count.clone();
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_call_count_clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/event_bus.rs:2393:13
[INFO] [stdout]      |
[INFO] [stdout] 2393 |         let mut stats_handler = CombatStatsHandler::new(Some(1)); // 假设玩家ID是1
[INFO] [stdout]      |             ----^^^^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/event_bus.rs:2430:13
[INFO] [stdout]      |
[INFO] [stdout] 2430 |         let mut state_tracker = GameStateTracker::new();
[INFO] [stdout]      |             ----^^^^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/event_bus.rs:2451:13
[INFO] [stdout]      |
[INFO] [stdout] 2451 |         let mut stats = EventStatistics::new();
[INFO] [stdout]      |             ----^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `stats`
[INFO] [stdout]     --> src/event_bus.rs:2451:13
[INFO] [stdout]      |
[INFO] [stdout] 2451 |         let mut stats = EventStatistics::new();
[INFO] [stdout]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stats`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `prev_state`
[INFO] [stdout]    --> src/game_loop.rs:919:13
[INFO] [stdout]     |
[INFO] [stdout] 919 |         let prev_state = TurnState::AITurn;
[INFO] [stdout]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_prev_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `current_state`
[INFO] [stdout]    --> src/game_loop.rs:920:13
[INFO] [stdout]     |
[INFO] [stdout] 920 |         let current_state = TurnState::PlayerTurn;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_current_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `trap_entity`
[INFO] [stdout]    --> src/systems.rs:299:14
[INFO] [stdout]     |
[INFO] [stdout] 299 |         for (trap_entity, (trap_pos, tile)) in world.query::<(&Position, &Tile)>().iter() {
[INFO] [stdout]     |              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_trap_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:600:23
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]    --> src/systems.rs:600:42
[INFO] [stdout]     |
[INFO] [stdout] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]     |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]    --> src/systems.rs:857:9
[INFO] [stdout]     |
[INFO] [stdout] 857 |         world: &World,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ai_state`
[INFO] [stdout]    --> src/systems.rs:859:9
[INFO] [stdout]     |
[INFO] [stdout] 859 |         ai_state: &AIState,
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ai_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `direction`
[INFO] [stdout]    --> src/systems.rs:898:17
[INFO] [stdout]     |
[INFO] [stdout] 898 |             let direction = Self::signum_to_direction(dx, dy);
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_direction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_state`
[INFO] [stdout]    --> src/systems.rs:926:17
[INFO] [stdout]     |
[INFO] [stdout] 926 |             let old_state = ai.state.clone();
[INFO] [stdout]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1147:23
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1147:42
[INFO] [stdout]      |
[INFO] [stdout] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `damage`
[INFO] [stdout]     --> src/systems.rs:1351:34
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                  ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_critical`
[INFO] [stdout]     --> src/systems.rs:1351:42
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                          ^^^^^^^^^^^ help: try ignoring the field: `is_critical: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_ambush`
[INFO] [stdout]     --> src/systems.rs:1351:55
[INFO] [stdout]      |
[INFO] [stdout] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stdout]      |                                                       ^^^^^^^^^ help: try ignoring the field: `is_ambush: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `world`
[INFO] [stdout]     --> src/systems.rs:1505:23
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]     --> src/systems.rs:1505:42
[INFO] [stdout]      |
[INFO] [stdout] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stdout]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_id`
[INFO] [stdout]     --> src/systems.rs:1520:49
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                 ^^^^^^^^^ help: try ignoring the field: `entity_id: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_name`
[INFO] [stdout]     --> src/systems.rs:1520:60
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                            ^^^^^^^^^^^ help: try ignoring the field: `entity_name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `killer`
[INFO] [stdout]     --> src/systems.rs:1520:73
[INFO] [stdout]      |
[INFO] [stdout] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stdout]      |                                                                         ^^^^^^ help: try ignoring the field: `killer: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1537:44
[INFO] [stdout]      |
[INFO] [stdout] 1537 |                 AftermathEvent::LootDrop { entity, position } => {
[INFO] [stdout]      |                                            ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1545:50
[INFO] [stdout]      |
[INFO] [stdout] 1545 |                 AftermathEvent::ExperienceGain { entity, amount } => {
[INFO] [stdout]      |                                                  ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1569:14
[INFO] [stdout]      |
[INFO] [stdout] 1569 |         for (entity, (actor, stats)) in world.query::<(&Actor, &Stats)>().iter() {
[INFO] [stdout]      |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/systems.rs:1586:18
[INFO] [stdout]      |
[INFO] [stdout] 1586 |             for (entity, (actor, pos)) in world.query::<(&Actor, &Position)>().iter() {
[INFO] [stdout]      |                  ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:1867:17
[INFO] [stdout]      |
[INFO] [stdout] 1867 |             let mut total_healing = 0u32;
[INFO] [stdout]      |                 ----^^^^^^^^^^^^^
[INFO] [stdout]      |                 |
[INFO] [stdout]      |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_player`
[INFO] [stdout]     --> src/systems.rs:1858:53
[INFO] [stdout]      |
[INFO] [stdout] 1858 |         for (entity, mut status_effects, mut stats, is_player, entity_name) in entities_to_process {
[INFO] [stdout]      |                                                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_player`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2100:56
[INFO] [stdout]      |
[INFO] [stdout] 2100 | ...                   if let Ok((mut food_item, _)) = bincode::decode_from_slice::<Item, _>(
[INFO] [stdout]      |                                  ----^^^^^^^^^
[INFO] [stdout]      |                                  |
[INFO] [stdout]      |                                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2076:29
[INFO] [stdout]      |
[INFO] [stdout] 2076 |                         let player_id = player_entity.id();
[INFO] [stdout]      |                             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2392:60
[INFO] [stdout]      |
[INFO] [stdout] 2392 |                     if let Some((player_pos, item_to_drop, player_id)) = drop_result {
[INFO] [stdout]      |                                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_id`
[INFO] [stdout]     --> src/systems.rs:2633:13
[INFO] [stdout]      |
[INFO] [stdout] 2633 |         let player_id = player_entity.id();
[INFO] [stdout]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2677:24
[INFO] [stdout]      |
[INFO] [stdout] 2677 |             if let Ok((mut food_item, _)) = bincode::decode_from_slice::<items::Item, _>(
[INFO] [stdout]      |                        ----^^^^^^^^^
[INFO] [stdout]      |                        |
[INFO] [stdout]      |                        help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/systems.rs:2723:21
[INFO] [stdout]      |
[INFO] [stdout] 2723 |                 let mut success = true;
[INFO] [stdout]      |                     ----^^^^^^^
[INFO] [stdout]      |                     |
[INFO] [stdout]      |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `effect_description` is never read
[INFO] [stdout]     --> src/systems.rs:2722:46
[INFO] [stdout]      |
[INFO] [stdout] 2722 |                 let mut effect_description = String::new();
[INFO] [stdout]      |                                              ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `message`
[INFO] [stdout]     --> src/systems.rs:3116:37
[INFO] [stdout]      |
[INFO] [stdout] 3116 | ...                   let message = "You descend to the next level...".to_string();
[INFO] [stdout]      |                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `enemy`
[INFO] [stdout]     --> src/systems.rs:4862:13
[INFO] [stdout]      |
[INFO] [stdout] 4862 |         let enemy = create_enemy(&mut world, 5, 6); // Enemy to the south
[INFO] [stdout]      |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_enemy`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_call_count` and `get_last_event` are never used
[INFO] [stdout]     --> src/event_bus.rs:1989:12
[INFO] [stdout]      |
[INFO] [stdout] 1981 |     impl TestHandler {
[INFO] [stdout]      |     ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1989 |         fn get_call_count(&self) -> usize {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1993 |         fn get_last_event(&self) -> Option<String> {
[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` is never used
[INFO] [stdout]    --> src/game_loop.rs:743:8
[INFO] [stdout]     |
[INFO] [stdout]  66 | impl<R: Renderer, I: InputSource<Event = crate::input::InputEvent>, C: Clock> GameLoop<R, I, C> {
[INFO] [stdout]     | ----------------------------------------------------------------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 743 |     fn update(&mut self) -> anyhow::Result<()> {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `last_render_time` and `render_cache` are never read
[INFO] [stdout]   --> src/renderer.rs:60:5
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub struct RatatuiRenderer {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] 59 |     terminal: Terminal<ratatui::backend::CrosstermBackend<Stdout>>,
[INFO] [stdout] 60 |     last_render_time: std::time::Instant,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 61 |     render_cache: HashMap<(i32, i32, i32), RenderCacheEntry>, // x, y, z coordinates
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `symbol`, `fg`, `bg`, and `timestamp` are never read
[INFO] [stdout]   --> src/renderer.rs:73:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | struct RenderCacheEntry {
[INFO] [stdout]    |        ---------------- fields in this struct
[INFO] [stdout] 73 |     symbol: char,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 74 |     fg: TuiColor,
[INFO] [stdout]    |     ^^
[INFO] [stdout] 75 |     bg: TuiColor,
[INFO] [stdout]    |     ^^
[INFO] [stdout] 76 |     timestamp: std::time::Instant,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_messages` is never used
[INFO] [stdout]    --> src/renderer.rs:474:4
[INFO] [stdout]     |
[INFO] [stdout] 474 | fn format_messages(messages: &[String]) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `start_time` is never read
[INFO] [stdout]    --> src/renderer.rs:493:5
[INFO] [stdout]     |
[INFO] [stdout] 491 | pub struct GameClock {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] 492 |     tick_rate: Duration,
[INFO] [stdout] 493 |     start_time: std::time::SystemTime,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `weapon` is never read
[INFO] [stdout]     --> src/systems.rs:1410:5
[INFO] [stdout]      |
[INFO] [stdout] 1407 | struct SimpleCombatant<'a> {
[INFO] [stdout]      |        --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 1410 |     weapon: Option<crate::ecs::ECSItem>,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `generate_level` is never used
[INFO] [stdout]     --> src/systems.rs:3641:8
[INFO] [stdout]      |
[INFO] [stdout] 3257 | impl DungeonSystem {
[INFO] [stdout]      | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 3641 |     fn generate_level(&mut self, world: &mut World, resources: &mut Resources, level: i32) {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `intent_queue` is never read
[INFO] [stdout]    --> src/turn_system.rs:278:5
[INFO] [stdout]     |
[INFO] [stdout] 272 | pub struct TurnSystem {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 278 |     intent_queue: BinaryHeap<ActionIntent>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `build_intent_queue` and `resolve_intents` are never used
[INFO] [stdout]    --> src/turn_system.rs:328:8
[INFO] [stdout]     |
[INFO] [stdout] 283 | impl TurnSystem {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 328 |     fn build_intent_queue(&mut self, world: &World) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 360 |     fn resolve_intents(&mut self, world: &mut World) -> Result<(), anyhow::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_player` is never used
[INFO] [stdout]    --> src/turn_system.rs:567:4
[INFO] [stdout]     |
[INFO] [stdout] 567 | fn is_player(world: &World, entity: Entity) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `collect` that must be used
[INFO] [stdout]     --> src/event_bus.rs:1965:9
[INFO] [stdout]      |
[INFO] [stdout] 1965 |         event_bus.drain().collect::<Vec<_>>();
[INFO] [stdout]      |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: if you really need to exhaust the iterator, consider `.for_each(drop)` instead
[INFO] [stdout]      = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]      |
[INFO] [stdout] 1965 |         let _ = event_bus.drain().collect::<Vec<_>>();
[INFO] [stdout]      |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/render/game_over.rs:207:28
[INFO] [stdout]     |
[INFO] [stdout] 207 |     fn get_game_statistics(&self, resources: &Resources) -> Vec<Line> {
[INFO] [stdout]     |                            ^^^^^ the lifetime is elided here    ^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 207 |     fn get_game_statistics(&self, resources: &Resources) -> Vec<Line<'_>> {
[INFO] [stdout]     |                                                                     ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 49.69s
[INFO] running `Command { std: "docker" "inspect" "cc0c65e90c46749a56e45ab1db069d10d8b7ac3d7195d2d550e1dadbdf4c1a04", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cc0c65e90c46749a56e45ab1db069d10d8b7ac3d7195d2d550e1dadbdf4c1a04", kill_on_drop: false }`
[INFO] [stdout] cc0c65e90c46749a56e45ab1db069d10d8b7ac3d7195d2d550e1dadbdf4c1a04
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 6d7aaec8b48e44e2657c251269d85e3ddb633d661a56e35205fdc7e14565f82c
[INFO] running `Command { std: "docker" "start" "-a" "6d7aaec8b48e44e2657c251269d85e3ddb633d661a56e35205fdc7e14565f82c", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `Boss`
[INFO] [stderr]   --> src/dungeon/src/level.rs:18:20
[INFO] [stderr]    |
[INFO] [stderr] 18 | use combat::boss::{Boss, BossType};
[INFO] [stderr]    |                    ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Hazard`
[INFO] [stderr]   --> src/dungeon/src/lib.rs:14:34
[INFO] [stderr]    |
[INFO] [stderr] 14 | use crate::boss_room::{BossRoom, Hazard};
[INFO] [stderr]    |                                  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `BossType`
[INFO] [stderr]   --> src/dungeon/src/lib.rs:19:26
[INFO] [stderr]    |
[INFO] [stderr] 19 | use combat::boss::{Boss, BossType};
[INFO] [stderr]    |                          ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `dungeon` (lib) generated 3 warnings (run `cargo fix --lib -p dungeon` to apply 3 suggestions)
[INFO] [stderr] warning: unused import: `combat::effect::EffectType`
[INFO] [stderr]     --> src/ecs.rs:1213:13
[INFO] [stderr]      |
[INFO] [stderr] 1213 |         use combat::effect::EffectType;
[INFO] [stderr]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `PlayerProgress` and `Wealth`
[INFO] [stderr]  --> src/systems.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 |     PlayerProgress, Position, Renderable, Resources, StatType, Stats, StatusEffects, TerrainType,
[INFO] [stderr]   |     ^^^^^^^^^^^^^^
[INFO] [stderr] 6 |     Tile, Viewshed, Wealth,
[INFO] [stderr]   |                     ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::error::Error`
[INFO] [stderr]   --> src/systems.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use std::error::Error;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stderr]    --> src/systems.rs:362:13
[INFO] [stderr]     |
[INFO] [stderr] 362 |         use crate::event_bus::GameEvent;
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `LogLevel`
[INFO] [stderr]    --> src/systems.rs:631:43
[INFO] [stderr]     |
[INFO] [stderr] 631 |         use crate::event_bus::{GameEvent, LogLevel};
[INFO] [stderr]     |                                           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stderr]     --> src/systems.rs:1167:13
[INFO] [stderr]      |
[INFO] [stderr] 1167 |         use crate::event_bus::GameEvent;
[INFO] [stderr]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stderr]     --> src/systems.rs:2529:13
[INFO] [stderr]      |
[INFO] [stderr] 2529 |         use crate::event_bus::GameEvent;
[INFO] [stderr]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stderr]     --> src/systems.rs:2530:13
[INFO] [stderr]      |
[INFO] [stderr] 2530 |         use crate::turn_system::energy_costs;
[INFO] [stderr]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::event_bus::GameEvent`
[INFO] [stderr]     --> src/systems.rs:2631:13
[INFO] [stderr]      |
[INFO] [stderr] 2631 |         use crate::event_bus::GameEvent;
[INFO] [stderr]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::turn_system::energy_costs`
[INFO] [stderr]     --> src/systems.rs:3261:13
[INFO] [stderr]      |
[INFO] [stderr] 3261 |         use crate::turn_system::energy_costs;
[INFO] [stderr]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: ambiguous glob re-exports
[INFO] [stderr]   --> src/lib.rs:18:9
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub use event_bus::*;
[INFO] [stderr]    |         ------------ but the name `TurnPhase` in the type namespace is also re-exported here
[INFO] [stderr] ...
[INFO] [stderr] 18 | pub use save::*;
[INFO] [stderr]    |         ^^^^^^^ the name `TurnPhase` in the type namespace is first re-exported here
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(ambiguous_glob_reexports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stderr]     --> src/systems.rs:2263:83
[INFO] [stderr]      |
[INFO] [stderr] 2263 | ...                   pos.x = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stderr]      |                                                 ^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stderr]     --> src/systems.rs:2264:83
[INFO] [stderr]      |
[INFO] [stderr] 2264 | ...                   pos.y = 5 + resources.rng.gen_range(0..15); // Random position between 5-19
[INFO] [stderr]      |                                                 ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stderr]     --> src/systems.rs:2813:69
[INFO] [stderr]      |
[INFO] [stderr] 2813 | ...                   pos.x = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stderr]      |                                                           ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `rand::Rng::gen_range`: Renamed to `random_range`
[INFO] [stderr]     --> src/systems.rs:2814:69
[INFO] [stderr]      |
[INFO] [stderr] 2814 | ...                   pos.y = 5 + ecs_world.resources.rng.gen_range(0..15);
[INFO] [stderr]      |                                                           ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `name`
[INFO] [stderr]    --> src/core/entity_factory.rs:147:13
[INFO] [stderr]     |
[INFO] [stderr] 147 |         let name = item.name();
[INFO] [stderr]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_name`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `event`
[INFO] [stderr]    --> src/event_bus.rs:509:33
[INFO] [stderr]     |
[INFO] [stderr] 509 |     fn before_handle(&mut self, event: &GameEvent) -> bool {
[INFO] [stderr]     |                                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `event`
[INFO] [stderr]    --> src/event_bus.rs:514:32
[INFO] [stderr]     |
[INFO] [stderr] 514 |     fn after_handle(&mut self, event: &GameEvent) {
[INFO] [stderr]     |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `event`
[INFO] [stderr]    --> src/event_bus.rs:541:29
[INFO] [stderr]     |
[INFO] [stderr] 541 |     fn should_handle(&self, event: &GameEvent) -> bool {
[INFO] [stderr]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `trap_entity`
[INFO] [stderr]    --> src/systems.rs:299:14
[INFO] [stderr]     |
[INFO] [stderr] 299 |         for (trap_entity, (trap_pos, tile)) in world.query::<(&Position, &Tile)>().iter() {
[INFO] [stderr]     |              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_trap_entity`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `world`
[INFO] [stderr]    --> src/systems.rs:600:23
[INFO] [stderr]     |
[INFO] [stderr] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stderr]     |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `resources`
[INFO] [stderr]    --> src/systems.rs:600:42
[INFO] [stderr]     |
[INFO] [stderr] 600 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stderr]     |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `world`
[INFO] [stderr]    --> src/systems.rs:857:9
[INFO] [stderr]     |
[INFO] [stderr] 857 |         world: &World,
[INFO] [stderr]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `ai_state`
[INFO] [stderr]    --> src/systems.rs:859:9
[INFO] [stderr]     |
[INFO] [stderr] 859 |         ai_state: &AIState,
[INFO] [stderr]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ai_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `direction`
[INFO] [stderr]    --> src/systems.rs:898:17
[INFO] [stderr]     |
[INFO] [stderr] 898 |             let direction = Self::signum_to_direction(dx, dy);
[INFO] [stderr]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_direction`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `old_state`
[INFO] [stderr]    --> src/systems.rs:926:17
[INFO] [stderr]     |
[INFO] [stderr] 926 |             let old_state = ai.state.clone();
[INFO] [stderr]     |                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `world`
[INFO] [stderr]     --> src/systems.rs:1147:23
[INFO] [stderr]      |
[INFO] [stderr] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stderr]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `resources`
[INFO] [stderr]     --> src/systems.rs:1147:42
[INFO] [stderr]      |
[INFO] [stderr] 1147 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stderr]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `damage`
[INFO] [stderr]     --> src/systems.rs:1351:34
[INFO] [stderr]      |
[INFO] [stderr] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stderr]      |                                  ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `is_critical`
[INFO] [stderr]     --> src/systems.rs:1351:42
[INFO] [stderr]      |
[INFO] [stderr] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stderr]      |                                          ^^^^^^^^^^^ help: try ignoring the field: `is_critical: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `is_ambush`
[INFO] [stderr]     --> src/systems.rs:1351:55
[INFO] [stderr]      |
[INFO] [stderr] 1351 |             CombatOutcome::Hit { damage, is_critical, is_ambush } => {
[INFO] [stderr]      |                                                       ^^^^^^^^^ help: try ignoring the field: `is_ambush: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `world`
[INFO] [stderr]     --> src/systems.rs:1505:23
[INFO] [stderr]      |
[INFO] [stderr] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stderr]      |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_world`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `resources`
[INFO] [stderr]     --> src/systems.rs:1505:42
[INFO] [stderr]      |
[INFO] [stderr] 1505 |     fn run(&mut self, world: &mut World, resources: &mut Resources) -> SystemResult {
[INFO] [stderr]      |                                          ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_resources`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `entity_id`
[INFO] [stderr]     --> src/systems.rs:1520:49
[INFO] [stderr]      |
[INFO] [stderr] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stderr]      |                                                 ^^^^^^^^^ help: try ignoring the field: `entity_id: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `entity_name`
[INFO] [stderr]     --> src/systems.rs:1520:60
[INFO] [stderr]      |
[INFO] [stderr] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stderr]      |                                                            ^^^^^^^^^^^ help: try ignoring the field: `entity_name: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `killer`
[INFO] [stderr]     --> src/systems.rs:1520:73
[INFO] [stderr]      |
[INFO] [stderr] 1520 |                 AftermathEvent::Death { entity, entity_id, entity_name, killer } => {
[INFO] [stderr]      |                                                                         ^^^^^^ help: try ignoring the field: `killer: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `entity`
[INFO] [stderr]     --> src/systems.rs:1537:44
[INFO] [stderr]      |
[INFO] [stderr] 1537 |                 AftermathEvent::LootDrop { entity, position } => {
[INFO] [stderr]      |                                            ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `entity`
[INFO] [stderr]     --> src/systems.rs:1545:50
[INFO] [stderr]      |
[INFO] [stderr] 1545 |                 AftermathEvent::ExperienceGain { entity, amount } => {
[INFO] [stderr]      |                                                  ^^^^^^ help: try ignoring the field: `entity: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `entity`
[INFO] [stderr]     --> src/systems.rs:1569:14
[INFO] [stderr]      |
[INFO] [stderr] 1569 |         for (entity, (actor, stats)) in world.query::<(&Actor, &Stats)>().iter() {
[INFO] [stderr]      |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `entity`
[INFO] [stderr]     --> src/systems.rs:1586:18
[INFO] [stderr]      |
[INFO] [stderr] 1586 |             for (entity, (actor, pos)) in world.query::<(&Actor, &Position)>().iter() {
[INFO] [stderr]      |                  ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/systems.rs:1867:17
[INFO] [stderr]      |
[INFO] [stderr] 1867 |             let mut total_healing = 0u32;
[INFO] [stderr]      |                 ----^^^^^^^^^^^^^
[INFO] [stderr]      |                 |
[INFO] [stderr]      |                 help: remove this `mut`
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `is_player`
[INFO] [stderr]     --> src/systems.rs:1858:53
[INFO] [stderr]      |
[INFO] [stderr] 1858 |         for (entity, mut status_effects, mut stats, is_player, entity_name) in entities_to_process {
[INFO] [stderr]      |                                                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_player`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/systems.rs:2100:56
[INFO] [stderr]      |
[INFO] [stderr] 2100 | ...                   if let Ok((mut food_item, _)) = bincode::decode_from_slice::<Item, _>(
[INFO] [stderr]      |                                  ----^^^^^^^^^
[INFO] [stderr]      |                                  |
[INFO] [stderr]      |                                  help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player_id`
[INFO] [stderr]     --> src/systems.rs:2076:29
[INFO] [stderr]      |
[INFO] [stderr] 2076 |                         let player_id = player_entity.id();
[INFO] [stderr]      |                             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player_id`
[INFO] [stderr]     --> src/systems.rs:2392:60
[INFO] [stderr]      |
[INFO] [stderr] 2392 |                     if let Some((player_pos, item_to_drop, player_id)) = drop_result {
[INFO] [stderr]      |                                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player_id`
[INFO] [stderr]     --> src/systems.rs:2633:13
[INFO] [stderr]      |
[INFO] [stderr] 2633 |         let player_id = player_entity.id();
[INFO] [stderr]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_id`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/systems.rs:2677:24
[INFO] [stderr]      |
[INFO] [stderr] 2677 |             if let Ok((mut food_item, _)) = bincode::decode_from_slice::<items::Item, _>(
[INFO] [stderr]      |                        ----^^^^^^^^^
[INFO] [stderr]      |                        |
[INFO] [stderr]      |                        help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/systems.rs:2723:21
[INFO] [stderr]      |
[INFO] [stderr] 2723 |                 let mut success = true;
[INFO] [stderr]      |                     ----^^^^^^^
[INFO] [stderr]      |                     |
[INFO] [stderr]      |                     help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `effect_description` is never read
[INFO] [stderr]     --> src/systems.rs:2722:46
[INFO] [stderr]      |
[INFO] [stderr] 2722 |                 let mut effect_description = String::new();
[INFO] [stderr]      |                                              ^^^^^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = help: maybe it is overwritten before being read?
[INFO] [stderr]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `message`
[INFO] [stderr]     --> src/systems.rs:3116:37
[INFO] [stderr]      |
[INFO] [stderr] 3116 | ...                   let message = "You descend to the next level...".to_string();
[INFO] [stderr]      |                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message`
[INFO] [stderr] 
[INFO] [stderr] warning: field `weapon` is never read
[INFO] [stderr]     --> src/systems.rs:1410:5
[INFO] [stderr]      |
[INFO] [stderr] 1407 | struct SimpleCombatant<'a> {
[INFO] [stderr]      |        --------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 1410 |     weapon: Option<crate::ecs::ECSItem>,
[INFO] [stderr]      |     ^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: method `generate_level` is never used
[INFO] [stderr]     --> src/systems.rs:3641:8
[INFO] [stderr]      |
[INFO] [stderr] 3257 | impl DungeonSystem {
[INFO] [stderr]      | ------------------ method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 3641 |     fn generate_level(&mut self, world: &mut World, resources: &mut Resources, level: i32) {
[INFO] [stderr]      |        ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `intent_queue` is never read
[INFO] [stderr]    --> src/turn_system.rs:278:5
[INFO] [stderr]     |
[INFO] [stderr] 272 | pub struct TurnSystem {
[INFO] [stderr]     |            ---------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 278 |     intent_queue: BinaryHeap<ActionIntent>,
[INFO] [stderr]     |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `build_intent_queue` and `resolve_intents` are never used
[INFO] [stderr]    --> src/turn_system.rs:328:8
[INFO] [stderr]     |
[INFO] [stderr] 283 | impl TurnSystem {
[INFO] [stderr]     | --------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 328 |     fn build_intent_queue(&mut self, world: &World) {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 360 |     fn resolve_intents(&mut self, world: &mut World) -> Result<(), anyhow::Error> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `is_player` is never used
[INFO] [stderr]    --> src/turn_system.rs:567:4
[INFO] [stderr]     |
[INFO] [stderr] 567 | fn is_player(world: &World, entity: Entity) -> bool {
[INFO] [stderr]     |    ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/event_bus.rs:2265:13
[INFO] [stderr]      |
[INFO] [stderr] 2265 |         let mut counting_middleware = CountingMiddleware::new();
[INFO] [stderr]      |             ----^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]      |             |
[INFO] [stderr]      |             help: remove this `mut`
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `counting_middleware`
[INFO] [stderr]     --> src/event_bus.rs:2281:13
[INFO] [stderr]      |
[INFO] [stderr] 2281 |         let counting_middleware = CountingMiddleware::new();
[INFO] [stderr]      |             ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_counting_middleware`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/event_bus.rs:2309:13
[INFO] [stderr]      |
[INFO] [stderr] 2309 |         let mut test_handler = TestHandler::new();
[INFO] [stderr]      |             ----^^^^^^^^^^^^
[INFO] [stderr]      |             |
[INFO] [stderr]      |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `call_count_clone`
[INFO] [stderr]     --> src/event_bus.rs:2306:13
[INFO] [stderr]      |
[INFO] [stderr] 2306 |         let call_count_clone = handler_call_count.clone();
[INFO] [stderr]      |             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_call_count_clone`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/event_bus.rs:2393:13
[INFO] [stderr]      |
[INFO] [stderr] 2393 |         let mut stats_handler = CombatStatsHandler::new(Some(1)); // 假设玩家ID是1
[INFO] [stderr]      |             ----^^^^^^^^^^^^^
[INFO] [stderr]      |             |
[INFO] [stderr]      |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/event_bus.rs:2430:13
[INFO] [stderr]      |
[INFO] [stderr] 2430 |         let mut state_tracker = GameStateTracker::new();
[INFO] [stderr]      |             ----^^^^^^^^^^^^^
[INFO] [stderr]      |             |
[INFO] [stderr]      |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/event_bus.rs:2451:13
[INFO] [stderr]      |
[INFO] [stderr] 2451 |         let mut stats = EventStatistics::new();
[INFO] [stderr]      |             ----^^^^^
[INFO] [stderr]      |             |
[INFO] [stderr]      |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `stats`
[INFO] [stderr]     --> src/event_bus.rs:2451:13
[INFO] [stderr]      |
[INFO] [stderr] 2451 |         let mut stats = EventStatistics::new();
[INFO] [stderr]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stats`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/systems.rs:1867:17
[INFO] [stderr]      |
[INFO] [stderr] 1867 |             let mut total_healing = 0u32;
[INFO] [stderr]      |                 ----^^^^^^^^^^^^^
[INFO] [stderr]      |                 |
[INFO] [stderr]      |                 help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `enemy`
[INFO] [stderr]     --> src/systems.rs:4862:13
[INFO] [stderr]      |
[INFO] [stderr] 4862 |         let enemy = create_enemy(&mut world, 5, 6); // Enemy to the south
[INFO] [stderr]      |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_enemy`
[INFO] [stderr] 
[INFO] [stderr] warning: methods `get_call_count` and `get_last_event` are never used
[INFO] [stderr]     --> src/event_bus.rs:1989:12
[INFO] [stderr]      |
[INFO] [stderr] 1981 |     impl TestHandler {
[INFO] [stderr]      |     ---------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 1989 |         fn get_call_count(&self) -> usize {
[INFO] [stderr]      |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1993 |         fn get_last_event(&self) -> Option<String> {
[INFO] [stderr]      |            ^^^^^^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `weapon` is never read
[INFO] [stderr]     --> src/systems.rs:1410:5
[INFO] [stderr]      |
[INFO] [stderr] 1407 | struct SimpleCombatant<'a> {
[INFO] [stderr]      |        --------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 1410 |     weapon: Option<crate::ecs::ECSItem>,
[INFO] [stderr]      |     ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `collect` that must be used
[INFO] [stderr]     --> src/event_bus.rs:1965:9
[INFO] [stderr]      |
[INFO] [stderr] 1965 |         event_bus.drain().collect::<Vec<_>>();
[INFO] [stderr]      |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: if you really need to exhaust the iterator, consider `.for_each(drop)` instead
[INFO] [stderr]      = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]      |
[INFO] [stderr] 1965 |         let _ = event_bus.drain().collect::<Vec<_>>();
[INFO] [stderr]      |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `terminal_pixel_dungeon` (lib) generated 55 warnings (run `cargo fix --lib -p terminal_pixel_dungeon` to apply 44 suggestions)
[INFO] [stderr] warning: `terminal_pixel_dungeon` (lib test) generated 66 warnings (53 duplicates) (run `cargo fix --lib -p terminal_pixel_dungeon --tests` to apply 10 suggestions)
[INFO] [stderr] warning: unused import: `std::path::PathBuf`
[INFO] [stderr]  --> tests/save_turn_state_integration.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::path::PathBuf;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player_entity`
[INFO] [stderr]   --> tests/save_turn_state_integration.rs:26:9
[INFO] [stderr]    |
[INFO] [stderr] 26 |     let player_entity = ecs_world.world.spawn((
[INFO] [stderr]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_entity`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> tests/save_turn_state_integration.rs:243:9
[INFO] [stderr]     |
[INFO] [stderr] 243 |     let mut loaded_data = save_system.load_game(1).expect("Failed to load v1 game");
[INFO] [stderr]     |         ----^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player_entity`
[INFO] [stderr]    --> tests/save_turn_state_integration.rs:186:9
[INFO] [stderr]     |
[INFO] [stderr] 186 |     let player_entity = ecs_world.world.spawn((
[INFO] [stderr]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_entity`
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_test_world` is never used
[INFO] [stderr]  --> tests/dungeon_turn_costs_test.rs:9:4
[INFO] [stderr]   |
[INFO] [stderr] 9 | fn create_test_world() -> (World, Resources) {
[INFO] [stderr]   |    ^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: methods `get_handled_events` and `clear` are never used
[INFO] [stderr]   --> tests/event_bus_taxonomy_tests.rs:30:8
[INFO] [stderr]    |
[INFO] [stderr] 15 | impl TestHandler {
[INFO] [stderr]    | ---------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 30 |     fn get_handled_events(&self) -> Vec<String> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 34 |     fn clear(&self) {
[INFO] [stderr]    |        ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `TurnPhase`
[INFO] [stderr]   --> src/game_loop.rs:19:26
[INFO] [stderr]    |
[INFO] [stderr] 19 | use crate::turn_system::{TurnPhase, TurnState, TurnSystem};
[INFO] [stderr]    |                          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `hecs::World`
[INFO] [stderr]  --> src/render/class_selection.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use hecs::World;
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Clear`
[INFO] [stderr]   --> src/render/class_selection.rs:13:31
[INFO] [stderr]    |
[INFO] [stderr] 13 |     widgets::{Block, Borders, Clear, List, ListItem, Paragraph, Wrap},
[INFO] [stderr]    |                               ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `backend::Backend`
[INFO] [stderr]   --> src/render/dungeon.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 |     backend::Backend,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `hecs::World`
[INFO] [stderr]  --> src/render/game_over.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use hecs::World;
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Clear` and `Gauge`
[INFO] [stderr]   --> src/render/game_over.rs:13:31
[INFO] [stderr]    |
[INFO] [stderr] 13 |     widgets::{Block, Borders, Clear, Gauge, Paragraph},
[INFO] [stderr]    |                               ^^^^^  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `hecs::World`
[INFO] [stderr]  --> src/render/menu.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use hecs::World;
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `prev_state`
[INFO] [stderr]    --> src/game_loop.rs:919:13
[INFO] [stderr]     |
[INFO] [stderr] 919 |         let prev_state = TurnState::AITurn;
[INFO] [stderr]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_prev_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `current_state`
[INFO] [stderr]    --> src/game_loop.rs:920:13
[INFO] [stderr]     |
[INFO] [stderr] 920 |         let current_state = TurnState::PlayerTurn;
[INFO] [stderr]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_current_state`
[INFO] [stderr] 
[INFO] [stderr] warning: method `update` is never used
[INFO] [stderr]    --> src/game_loop.rs:743:8
[INFO] [stderr]     |
[INFO] [stderr]  66 | impl<R: Renderer, I: InputSource<Event = crate::input::InputEvent>, C: Clock> GameLoop<R, I, C> {
[INFO] [stderr]     | ----------------------------------------------------------------------------------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 743 |     fn update(&mut self) -> anyhow::Result<()> {
[INFO] [stderr]     |        ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `last_render_time` and `render_cache` are never read
[INFO] [stderr]   --> src/renderer.rs:60:5
[INFO] [stderr]    |
[INFO] [stderr] 58 | pub struct RatatuiRenderer {
[INFO] [stderr]    |            --------------- fields in this struct
[INFO] [stderr] 59 |     terminal: Terminal<ratatui::backend::CrosstermBackend<Stdout>>,
[INFO] [stderr] 60 |     last_render_time: std::time::Instant,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 61 |     render_cache: HashMap<(i32, i32, i32), RenderCacheEntry>, // x, y, z coordinates
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `symbol`, `fg`, `bg`, and `timestamp` are never read
[INFO] [stderr]   --> src/renderer.rs:73:5
[INFO] [stderr]    |
[INFO] [stderr] 72 | struct RenderCacheEntry {
[INFO] [stderr]    |        ---------------- fields in this struct
[INFO] [stderr] 73 |     symbol: char,
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] 74 |     fg: TuiColor,
[INFO] [stderr]    |     ^^
[INFO] [stderr] 75 |     bg: TuiColor,
[INFO] [stderr]    |     ^^
[INFO] [stderr] 76 |     timestamp: std::time::Instant,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `format_messages` is never used
[INFO] [stderr]    --> src/renderer.rs:474:4
[INFO] [stderr]     |
[INFO] [stderr] 474 | fn format_messages(messages: &[String]) -> String {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `start_time` is never read
[INFO] [stderr]    --> src/renderer.rs:493:5
[INFO] [stderr]     |
[INFO] [stderr] 491 | pub struct GameClock {
[INFO] [stderr]     |            --------- field in this struct
[INFO] [stderr] 492 |     tick_rate: Duration,
[INFO] [stderr] 493 |     start_time: std::time::SystemTime,
[INFO] [stderr]     |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/render/game_over.rs:207:28
[INFO] [stderr]     |
[INFO] [stderr] 207 |     fn get_game_statistics(&self, resources: &Resources) -> Vec<Line> {
[INFO] [stderr]     |                            ^^^^^ the lifetime is elided here    ^^^^ the same lifetime is hidden here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 207 |     fn get_game_statistics(&self, resources: &Resources) -> Vec<Line<'_>> {
[INFO] [stderr]     |                                                                     ++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `i`
[INFO] [stderr]   --> tests/hunger_system_tests.rs:54:9
[INFO] [stderr]    |
[INFO] [stderr] 54 |     for i in 0..10 {
[INFO] [stderr]    |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `i`
[INFO] [stderr]   --> tests/hunger_system_tests.rs:99:9
[INFO] [stderr]    |
[INFO] [stderr] 99 |     for i in 0..20 {
[INFO] [stderr]    |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `event_logger`
[INFO] [stderr]    --> tests/hunger_system_tests.rs:145:9
[INFO] [stderr]     |
[INFO] [stderr] 145 |     let event_logger = |event: &GameEvent| {
[INFO] [stderr]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_logger`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `i`
[INFO] [stderr]    --> tests/hunger_system_tests.rs:150:9
[INFO] [stderr]     |
[INFO] [stderr] 150 |     for i in 0..10 {
[INFO] [stderr]     |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `i`
[INFO] [stderr]    --> tests/hunger_system_tests.rs:372:9
[INFO] [stderr]     |
[INFO] [stderr] 372 |     for i in 0..10 {
[INFO] [stderr]     |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player`
[INFO] [stderr]    --> tests/hunger_system_tests.rs:397:9
[INFO] [stderr]     |
[INFO] [stderr] 397 |     let player = ecs_world.world.spawn((
[INFO] [stderr]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_player`
[INFO] [stderr] 
[INFO] [stderr] warning: function `find_player_entity` is never used
[INFO] [stderr]   --> tests/hunger_system_tests.rs:18:4
[INFO] [stderr]    |
[INFO] [stderr] 18 | fn find_player_entity(world: &hecs::World) -> Option<hecs::Entity> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `terminal_pixel_dungeon::turn_system::*`
[INFO] [stderr]   --> tests/ai_energy_integration_test.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | use terminal_pixel_dungeon::turn_system::*;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `EventBus`
[INFO] [stderr]   --> tests/ai_energy_integration_test.rs:14:41
[INFO] [stderr]    |
[INFO] [stderr] 14 | use terminal_pixel_dungeon::event_bus::{EventBus, GameEvent};
[INFO] [stderr]    |                                         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player`
[INFO] [stderr]   --> tests/ai_energy_integration_test.rs:21:9
[INFO] [stderr]    |
[INFO] [stderr] 21 |     let player = ecs_world.world.spawn((
[INFO] [stderr]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_player`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `enemy2`
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:110:9
[INFO] [stderr]     |
[INFO] [stderr] 110 |     let enemy2 = spawn_enemy(&mut ecs_world.world, 13, 10, "Goblin2", 80, AIType::Aggressive);
[INFO] [stderr]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_enemy2`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `enemy3`
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:111:9
[INFO] [stderr]     |
[INFO] [stderr] 111 |     let enemy3 = spawn_enemy(&mut ecs_world.world, 14, 10, "Goblin3", 120, AIType::Aggressive);
[INFO] [stderr]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_enemy3`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:349:9
[INFO] [stderr]     |
[INFO] [stderr] 349 |     let mut decision_count = 0;
[INFO] [stderr]     |         ----^^^^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:350:9
[INFO] [stderr]     |
[INFO] [stderr] 350 |     let mut target_change_count = 0;
[INFO] [stderr]     |         ----^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `decision_count`
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:349:9
[INFO] [stderr]     |
[INFO] [stderr] 349 |     let mut decision_count = 0;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_decision_count`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `target_change_count`
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:350:9
[INFO] [stderr]     |
[INFO] [stderr] 350 |     let mut target_change_count = 0;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_change_count`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `targets`
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:391:9
[INFO] [stderr]     |
[INFO] [stderr] 391 |     let targets = *target_arc.lock().unwrap();
[INFO] [stderr]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_targets`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player_entity`
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:402:10
[INFO] [stderr]     |
[INFO] [stderr] 402 |     let (player_entity, player_pos) = ecs_world.world.query::<(&Player, &Position)>()
[INFO] [stderr]     |          ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_entity`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player_pos`
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:402:25
[INFO] [stderr]     |
[INFO] [stderr] 402 |     let (player_entity, player_pos) = ecs_world.world.query::<(&Player, &Position)>()
[INFO] [stderr]     |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_pos`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `final_energy`
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:482:13
[INFO] [stderr]     |
[INFO] [stderr] 482 |         let final_energy = ecs_world.world.get::<&Energy>(enemy).unwrap().current;
[INFO] [stderr]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_energy`
[INFO] [stderr] 
[INFO] [stderr] warning: comparison is useless due to type limits
[INFO] [stderr]    --> tests/ai_energy_integration_test.rs:474:13
[INFO] [stderr]     |
[INFO] [stderr] 474 |     assert!(energy >= 0, "Energy should not go negative");
[INFO] [stderr]     |             ^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: method `update` is never used
[INFO] [stderr]    --> src/game_loop.rs:743:8
[INFO] [stderr]     |
[INFO] [stderr]  66 | impl<R: Renderer, I: InputSource<Event = crate::input::InputEvent>, C: Clock> GameLoop<R, I, C> {
[INFO] [stderr]     | ----------------------------------------------------------------------------------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 743 |     fn update(&mut self) -> anyhow::Result<()> {
[INFO] [stderr]     |        ^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `terminal_pixel_dungeon` (test "save_turn_state_integration") generated 4 warnings (run `cargo fix --test "save_turn_state_integration" -p terminal_pixel_dungeon` to apply 4 suggestions)
[INFO] [stderr] warning: `terminal_pixel_dungeon` (test "dungeon_turn_costs_test") generated 1 warning
[INFO] [stderr] warning: `terminal_pixel_dungeon` (test "event_bus_taxonomy_tests") generated 1 warning
[INFO] [stderr] warning: `terminal_pixel_dungeon` (bin "terminal_pixel_dungeon" test) generated 80 warnings (65 duplicates) (run `cargo fix --bin "terminal_pixel_dungeon" -p terminal_pixel_dungeon --tests` to apply 10 suggestions)
[INFO] [stderr] warning: `terminal_pixel_dungeon` (test "hunger_system_tests") generated 7 warnings (run `cargo fix --test "hunger_system_tests" -p terminal_pixel_dungeon` to apply 6 suggestions)
[INFO] [stderr] warning: `terminal_pixel_dungeon` (test "ai_energy_integration_test") generated 14 warnings (run `cargo fix --test "ai_energy_integration_test" -p terminal_pixel_dungeon` to apply 13 suggestions)
[INFO] [stderr] warning: `terminal_pixel_dungeon` (bin "terminal_pixel_dungeon") generated 67 warnings (66 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.28s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/build/terminal_pixel_dungeon/1a5f3bd7d267557f/deps/terminal_pixel_dungeon-1a5f3bd7d267557f)
[INFO] [stdout] 
[INFO] [stdout] running 61 tests
[INFO] [stdout] test ecs::tests::test_game_over_event ... ok
[INFO] [stdout] test ecs::tests::test_event_bus_integration ... ok
[INFO] [stdout] test event_bus::tests::test_combat_stats_handler_direct ... ok
[INFO] [stdout] test ecs::tests::test_combat_events ... ok
[INFO] [stdout] test event_bus::tests::test_delayed_events ... ok
[INFO] [stdout] test ecs::tests::test_herb_and_throwable_roundtrip_conversion ... ok
[INFO] [stdout] test event_bus::tests::test_combat_stats_handler ... ok
[INFO] [stdout] test event_bus::tests::test_conditional_filter ... ok
[INFO] [stdout] test event_bus::tests::test_counting_middleware ... ok
[INFO] [stdout] test event_bus::tests::test_event_bus_basic ... ok
[INFO] [stdout] test event_bus::tests::test_event_bus_drain ... ok
[INFO] [stdout] test event_bus::tests::test_event_history ... ok
[INFO] [stdout] test event_bus::tests::test_event_subscription ... ok
[INFO] [stdout] test event_bus::tests::test_filtered_handler ... ok
[INFO] [stdout] test event_bus::tests::test_game_state_tracker_direct ... ok
[INFO] [stdout] test event_bus::tests::test_get_recent_history ... ok
[INFO] [stdout] test event_bus::tests::test_logging_handler ... ok
[INFO] [stdout] test event_bus::tests::test_full_integration ... ok
[INFO] [stdout] test event_bus::tests::test_game_state_tracker ... ok
[INFO] [stdout] test systems::tests::test_aftermath_experience_gain ... ok
[INFO] [stdout] test systems::tests::test_aftermath_death_handling ... ok
[INFO] [stdout] test systems::tests::test_combat_intent_priority_ordering ... ok
[INFO] [stdout] test systems::tests::test_auto_pickup ... ok
[INFO] [stdout] test event_bus::tests::test_rate_limit_middleware ... ok
[INFO] [stdout] test systems::tests::test_calculate_target_position ... ok
[INFO] [stdout] test systems::tests::test_combat_intent_skips_dead_entities ... ok
[INFO] [stdout] test systems::tests::test_combat_intent_queuing ... ok
[INFO] [stdout] test systems::tests::test_counterattack_mechanics ... ok
[INFO] [stdout] test systems::tests::test_is_hostile ... ok
[INFO] [stdout] test systems::tests::test_movement_blocked_by_wall ... ok
[INFO] [stdout] test systems::tests::test_movement_collision_with_enemy_converts_to_attack ... ok
[INFO] [stdout] test systems::tests::test_movement_marks_viewshed_dirty ... ok
[INFO] [stdout] test event_bus::tests::test_middleware_blocking ... ok
[INFO] [stdout] test ecs::tests::test_level_change_event ... ok
[INFO] [stdout] test event_bus::tests::test_middleware_execution ... ok
[INFO] [stdout] test systems::tests::test_inventory_full ... ok
[INFO] [stdout] test systems::tests::test_movement_position_update ... ok
[INFO] [stdout] test systems::tests::test_movement_cost_application ... ok
[INFO] [stdout] test event_bus::tests::test_event_type ... ok
[INFO] [stdout] test turn_system::tests::test_energy_regeneration ... ok
[INFO] [stdout] test turn_system::tests::test_full_turn_cycle ... ok
[INFO] [stdout] test turn_system::tests::test_energy_consumption ... ok
[INFO] [stdout] test systems::tests::test_drop_item ... ok
[INFO] [stdout] test turn_system::tests::test_turn_meta_advancement ... ok
[INFO] [stdout] test systems::tests::test_multi_attacker_engagement ... ok
[INFO] [stdout] test turn_system::tests::test_player_progress_advancement ... ok
[INFO] [stdout] test turn_system::tests::test_turn_order_by_energy ... ok
[INFO] [stdout] test turn_system::tests::test_wait_action_costs_less ... ok
[INFO] [stdout] test event_bus::tests::test_global_subscription ... ok
[INFO] [stdout] test systems::tests::test_critical_hit_detection ... ok
[INFO] [stdout] test systems::tests::test_item_detection ... ok
[INFO] [stdout] test turn_system::tests::test_turn_system_initialization ... ok
[INFO] [stdout] test ecs::tests::test_delayed_events ... ok
[INFO] [stdout] test systems::tests::test_trap_detection ... ok
[INFO] [stdout] test event_bus::tests::test_event_statistics ... ok
[INFO] [stdout] test event_bus::tests::test_middleware_registration ... ok
[INFO] [stdout] test systems::tests::test_use_teleport_scroll ... ok
[INFO] [stdout] test event_bus::tests::test_priority_ordering ... ok
[INFO] [stdout] test turn_system::tests::test_action_intent_ordering ... ok
[INFO] [stdout] test turn_system::tests::test_energy_cost_lookup ... ok
[INFO] [stdout] test systems::tests::test_use_healing_potion ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 61 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/build/terminal_pixel_dungeon/2fdf539f3aac63ff/deps/terminal_pixel_dungeon-2fdf539f3aac63ff)
[INFO] [stdout] 
[INFO] [stdout] running 67 tests
[INFO] [stdout] test ecs::tests::test_event_bus_integration ... ok
[INFO] [stdout] test ecs::tests::test_combat_events ... ok
[INFO] [stdout] test ecs::tests::test_delayed_events ... ok
[INFO] [stdout] test ecs::tests::test_game_over_event ... ok
[INFO] [stdout] test ecs::tests::test_herb_and_throwable_roundtrip_conversion ... ok
[INFO] [stdout] test ecs::tests::test_level_change_event ... ok
[INFO] [stdout] test event_bus::tests::test_combat_stats_handler ... ok
[INFO] [stdout] test event_bus::tests::test_event_history ... ok
[INFO] [stdout] test event_bus::tests::test_event_subscription ... ok
[INFO] [stdout] test event_bus::tests::test_event_type ... ok
[INFO] [stdout] test event_bus::tests::test_game_state_tracker ... ok
[INFO] [stdout] test event_bus::tests::test_event_statistics ... ok
[INFO] [stdout] test event_bus::tests::test_global_subscription ... ok
[INFO] [stdout] test event_bus::tests::test_middleware_blocking ... ok
[INFO] [stdout] test event_bus::tests::test_middleware_execution ... ok
[INFO] [stdout] test event_bus::tests::test_combat_stats_handler_direct ... ok
[INFO] [stdout] test event_bus::tests::test_conditional_filter ... ok
[INFO] [stdout] test event_bus::tests::test_counting_middleware ... ok
[INFO] [stdout] test event_bus::tests::test_full_integration ... ok
[INFO] [stdout] test event_bus::tests::test_delayed_events ... ok
[INFO] [stdout] test event_bus::tests::test_event_bus_basic ... ok
[INFO] [stdout] test event_bus::tests::test_event_bus_drain ... ok
[INFO] [stdout] test event_bus::tests::test_filtered_handler ... ok
[INFO] [stdout] test event_bus::tests::test_game_state_tracker_direct ... ok
[INFO] [stdout] test event_bus::tests::test_get_recent_history ... ok
[INFO] [stdout] test event_bus::tests::test_priority_ordering ... ok
[INFO] [stdout] test event_bus::tests::test_rate_limit_middleware ... ok
[INFO] [stdout] test event_bus::tests::test_logging_handler ... ok
[INFO] [stdout] test event_bus::tests::test_middleware_registration ... ok
[INFO] [stdout] test systems::tests::test_aftermath_experience_gain ... ok
[INFO] [stdout] test systems::tests::test_combat_intent_queuing ... ok
[INFO] [stdout] test systems::tests::test_inventory_full ... ok
[INFO] [stdout] test systems::tests::test_is_hostile ... ok
[INFO] [stdout] test systems::tests::test_auto_pickup ... ok
[INFO] [stdout] test systems::tests::test_calculate_target_position ... ok
[INFO] [stdout] test systems::tests::test_drop_item ... ok
[INFO] [stdout] test systems::tests::test_combat_intent_skips_dead_entities ... ok
[INFO] [stdout] test systems::tests::test_item_detection ... ok
[INFO] [stdout] test systems::tests::test_combat_intent_priority_ordering ... ok
[INFO] [stdout] test systems::tests::test_movement_blocked_by_wall ... ok
[INFO] [stdout] test systems::tests::test_counterattack_mechanics ... ok
[INFO] [stdout] test systems::tests::test_critical_hit_detection ... ok
[INFO] [stdout] test systems::tests::test_aftermath_death_handling ... ok
[INFO] [stdout] test systems::tests::test_movement_marks_viewshed_dirty ... ok
[INFO] [stdout] test systems::tests::test_trap_detection ... ok
[INFO] [stdout] test systems::tests::test_use_teleport_scroll ... ok
[INFO] [stdout] test systems::tests::test_movement_collision_with_enemy_converts_to_attack ... ok
[INFO] [stdout] test systems::tests::test_movement_cost_application ... ok
[INFO] [stdout] test systems::tests::test_movement_position_update ... ok
[INFO] [stdout] test turn_system::tests::test_player_progress_advancement ... ok
[INFO] [stdout] test systems::tests::test_multi_attacker_engagement ... ok
[INFO] [stdout] test turn_system::tests::test_full_turn_cycle ... ok
[INFO] [stdout] test turn_system::tests::test_turn_system_initialization ... ok
[INFO] [stdout] test turn_system::tests::test_action_intent_ordering ... ok
[INFO] [stdout] test turn_system::tests::test_turn_order_by_energy ... ok
[INFO] [stdout] test turn_system::tests::test_energy_consumption ... ok
[INFO] [stdout] test turn_system::tests::test_energy_cost_lookup ... ok
[INFO] [stdout] test turn_system::tests::test_energy_regeneration ... ok
[INFO] [stdout] test turn_system::tests::test_turn_meta_advancement ... ok
[INFO] [stdout] test turn_system::tests::test_wait_action_costs_less ... ok
[INFO] [stdout] test systems::tests::test_use_healing_potion ... ok
[INFO] [stdout] test game_loop::tests::test_game_loop_initialization ... ok
[INFO] [stdout] test game_loop::tests::test_autosave_triggered_at_turn_end ... FAILED
[INFO] [stdout] test game_loop::tests::test_phased_system_execution_order ... ok
[INFO] [stdout] test game_loop::tests::test_menu_state_short_circuits_game_logic ... ok
[INFO] [stdout] test game_loop::tests::test_no_state_leakage_between_turns ... ok
[INFO] [stdout] test game_loop::tests::test_turn_timing_hooks ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- game_loop::tests::test_autosave_triggered_at_turn_end stdout ----
[INFO] [stdout] Failed to initialize save system: Save system error: Failed to create save directory
[INFO] [stdout] 
[INFO] [stdout] thread 'game_loop::tests::test_autosave_triggered_at_turn_end' (116) panicked at src/game_loop.rs:976:9:
[INFO] [stdout] assertion failed: game_loop.save_system.is_some()
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5d4ffa8fca32 - std[840933623431fd06]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5d4ffa8fca32 - std[840933623431fd06]::backtrace_rs::backtrace::trace_unsynchronized::<std[840933623431fd06]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5d4ffa8fca32 - std[840933623431fd06]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5d4ffa8fca32 - <<std[840933623431fd06]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[8f93d80df273fe75]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5d4ffa91321a - <core[8f93d80df273fe75]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5d4ffa91321a - core[8f93d80df273fe75]::fmt::write
[INFO] [stdout]    6:     0x5d4ffa901ed6 - std[840933623431fd06]::io::default_write_fmt::<alloc[40b2bae28975ac47]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5d4ffa901ed6 - <alloc[40b2bae28975ac47]::vec::Vec<u8> as std[840933623431fd06]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5d4ffa8d99df - <std[840933623431fd06]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5d4ffa8d99df - std[840933623431fd06]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5d4ffa8f4b49 - std[840933623431fd06]::panicking::default_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5d4ffa7602de - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x5d4ffa7602de - test[2f1252070343a163]::test_main_with_exit_callback::<test[2f1252070343a163]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5d4ffa8f4d02 - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5d4ffa8f4d02 - std[840933623431fd06]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5d4ffa8d9aca - std[840933623431fd06]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x5d4ffa8d0df9 - std[840933623431fd06]::sys::backtrace::__rust_end_short_backtrace::<std[840933623431fd06]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5d4ffa8daa9d - __rustc[5b4a0c6d8cc4a177]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5d4ffa9138ec - core[8f93d80df273fe75]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5d4ffa9138b2 - core[8f93d80df273fe75]::panicking::panic
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:150:5
[INFO] [stdout]   20:     0x5d4ffa7370b6 - terminal_pixel_dungeon[b294147a673ead80]::game_loop::tests::test_autosave_triggered_at_turn_end
[INFO] [stdout]                                at /opt/rustwide/workdir/src/game_loop.rs:976:9
[INFO] [stdout]   21:     0x5d4ffa721847 - terminal_pixel_dungeon[b294147a673ead80]::game_loop::tests::test_autosave_triggered_at_turn_end::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/game_loop.rs:967:45
[INFO] [stdout]   22:     0x5d4ffa6814b6 - <terminal_pixel_dungeon[b294147a673ead80]::game_loop::tests::test_autosave_triggered_at_turn_end::{closure#0} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x5d4ffa75468b - <fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5d4ffa75468b - test[2f1252070343a163]::__rust_begin_short_backtrace::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x5d4ffa760eea - test[2f1252070343a163]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x5d4ffa760eea - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x5d4ffa760eea - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x5d4ffa760eea - std[840933623431fd06]::panicking::catch_unwind::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x5d4ffa760eea - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x5d4ffa760eea - test[2f1252070343a163]::run_test_in_process
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x5d4ffa760eea - test[2f1252070343a163]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x5d4ffa75b3b4 - test[2f1252070343a163]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x5d4ffa75b3b4 - std[840933623431fd06]::sys::backtrace::__rust_begin_short_backtrace::<test[2f1252070343a163]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x5d4ffa7639e2 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x5d4ffa7639e2 - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x5d4ffa7639e2 - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x5d4ffa7639e2 - std[840933623431fd06]::panicking::catch_unwind::<(), core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x5d4ffa7639e2 - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x5d4ffa7639e2 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x5d4ffa7639e2 - <std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x5d4ffa8fc2df - <alloc[40b2bae28975ac47]::boxed::Box<dyn core[8f93d80df273fe75]::ops::function::FnOnce<(), Output = ()> + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x5d4ffa8fc2df - <std[840933623431fd06]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   43:     0x7148bb583aa4 - <unknown>
[INFO] [stdout]   44:     0x7148bb610a64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     game_loop::tests::test_autosave_triggered_at_turn_end
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 66 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.20s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin terminal_pixel_dungeon`
[INFO] running `Command { std: "docker" "inspect" "6d7aaec8b48e44e2657c251269d85e3ddb633d661a56e35205fdc7e14565f82c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6d7aaec8b48e44e2657c251269d85e3ddb633d661a56e35205fdc7e14565f82c", kill_on_drop: false }`
[INFO] [stdout] 6d7aaec8b48e44e2657c251269d85e3ddb633d661a56e35205fdc7e14565f82c
