[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] checking H-Chris233/Terminal-Pixel-Dungeon against try#d336647335db03a0fc5b24fc5325cd3905c5b8e8 for pr-151146-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FH-Chris233%2FTerminal-Pixel-Dungeon" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-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-3-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/H-Chris233/Terminal-Pixel-Dungeon on toolchain d336647335db03a0fc5b24fc5325cd3905c5b8e8
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d336647335db03a0fc5b24fc5325cd3905c5b8e8" "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" "+d336647335db03a0fc5b24fc5325cd3905c5b8e8" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+d336647335db03a0fc5b24fc5325cd3905c5b8e8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] ea4f535414adb55dcbe1a44d306a05ed8c208276b0029356bb6fedb2d4815946
[INFO] running `Command { std: "docker" "start" "-a" "ea4f535414adb55dcbe1a44d306a05ed8c208276b0029356bb6fedb2d4815946", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "ea4f535414adb55dcbe1a44d306a05ed8c208276b0029356bb6fedb2d4815946", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ea4f535414adb55dcbe1a44d306a05ed8c208276b0029356bb6fedb2d4815946", kill_on_drop: false }`
[INFO] [stdout] ea4f535414adb55dcbe1a44d306a05ed8c208276b0029356bb6fedb2d4815946
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+d336647335db03a0fc5b24fc5325cd3905c5b8e8" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5b83a1df266e9285428c42191814542def18f0a1f896b3a7878f12a05ee981f7
[INFO] running `Command { std: "docker" "start" "-a" "5b83a1df266e9285428c42191814542def18f0a1f896b3a7878f12a05ee981f7", 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]     Checking cfg-if v1.0.0
[INFO] [stderr]    Compiling autocfg v1.4.0
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling getrandom v0.3.2
[INFO] [stderr]    Compiling zerocopy v0.8.24
[INFO] [stderr]     Checking bitflags v2.9.0
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]     Checking ryu v1.0.20
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking itoa v1.0.15
[INFO] [stderr]    Compiling virtue v0.0.18
[INFO] [stderr]     Checking unty v0.0.4
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling signal-hook v0.3.17
[INFO] [stderr]    Compiling fnv v1.0.7
[INFO] [stderr]     Checking scopeguard v1.2.0
[INFO] [stderr]     Checking smallvec v1.15.0
[INFO] [stderr]    Compiling ident_case v1.0.1
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]     Checking log v0.4.27
[INFO] [stderr]    Compiling heck v0.5.0
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]     Checking allocator-api2 v0.2.21
[INFO] [stderr]     Checking equivalent v1.0.2
[INFO] [stderr]     Checking linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling paste v1.0.15
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]     Checking foldhash v0.1.5
[INFO] [stderr]     Checking itertools v0.13.0
[INFO] [stderr]    Compiling indoc v2.0.6
[INFO] [stderr]     Checking unicode-segmentation v1.12.0
[INFO] [stderr]     Checking static_assertions v1.1.0
[INFO] [stderr]     Checking unicode-width v0.1.14
[INFO] [stderr]     Checking cassowary v0.3.0
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]    Compiling anyhow v1.0.97
[INFO] [stderr]     Checking hashbrown v0.15.5
[INFO] [stderr]     Checking seahash v4.1.0
[INFO] [stderr]    Compiling thiserror v2.0.12
[INFO] [stderr]     Checking once_cell v1.21.3
[INFO] [stderr]    Compiling rustix v1.0.5
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling version_check v0.9.5
[INFO] [stderr]    Compiling bincode_derive v2.0.1
[INFO] [stderr]     Checking memchr v2.7.4
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]     Checking linux-raw-sys v0.9.3
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking castaway v0.2.4
[INFO] [stderr]     Checking fastrand v2.3.0
[INFO] [stderr]     Checking compact_str v0.8.1
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling litrs v0.4.1
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]     Checking regex-syntax v0.8.8
[INFO] [stderr]    Compiling syn v2.0.100
[INFO] [stderr]     Checking signal-hook-registry v1.4.2
[INFO] [stderr]     Checking mio v1.0.3
[INFO] [stderr]     Checking lru v0.12.5
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]    Compiling convert_case v0.7.1
[INFO] [stderr]     Checking half v2.6.0
[INFO] [stderr]     Checking rand_core v0.9.3
[INFO] [stderr]     Checking spin v0.9.8
[INFO] [stderr]    Compiling document-features v0.2.11
[INFO] [stderr]     Checking anstyle v1.0.13
[INFO] [stderr]     Checking crossbeam-epoch v0.9.18
[INFO] [stderr]     Checking plotters-backend v0.3.7
[INFO] [stderr]     Checking clap_lex v0.7.6
[INFO] [stderr]     Checking ciborium-io v0.2.2
[INFO] [stderr]     Checking wait-timeout v0.2.1
[INFO] [stderr]     Checking itertools v0.10.5
[INFO] [stderr]     Checking ciborium-ll v0.2.2
[INFO] [stderr]     Checking bit-vec v0.8.0
[INFO] [stderr]     Checking signal-hook-mio v0.2.4
[INFO] [stderr]     Checking cast v0.3.0
[INFO] [stderr]     Checking same-file v1.0.6
[INFO] [stderr]     Checking crossterm v0.28.1
[INFO] [stderr]     Checking plotters-svg v0.3.7
[INFO] [stderr]     Checking quick-error v1.2.3
[INFO] [stderr]     Checking clap_builder v4.5.50
[INFO] [stderr]     Checking walkdir v2.5.0
[INFO] [stderr]     Checking bit-set v0.8.0
[INFO] [stderr]     Checking rand_xorshift v0.4.0
[INFO] [stderr]     Checking crossbeam-deque v0.8.6
[INFO] [stderr]     Checking is-terminal v0.4.17
[INFO] [stderr]     Checking anes v0.1.6
[INFO] [stderr]     Checking yansi v1.0.1
[INFO] [stderr]     Checking diff v0.1.13
[INFO] [stderr]     Checking lazy_static v1.5.0
[INFO] [stderr]     Checking oorandom v11.1.5
[INFO] [stderr]     Checking unarray v0.1.4
[INFO] [stderr]     Checking unicode-truncate v1.1.0
[INFO] [stderr]     Checking pretty_assertions v1.4.1
[INFO] [stderr]     Checking plotters v0.3.7
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking rayon v1.11.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking rand_chacha v0.9.0
[INFO] [stderr]     Checking rand v0.9.0
[INFO] [stderr]     Checking criterion-plot v0.5.0
[INFO] [stderr]     Checking hecs v0.10.5
[INFO] [stderr]     Checking clap v4.5.50
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]     Checking tempfile v3.19.1
[INFO] [stderr]     Checking rusty-fork v0.3.1
[INFO] [stderr]     Checking proptest v1.8.0
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]     Checking regex v1.12.2
[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]     Checking derive_more v2.0.1
[INFO] [stderr]     Checking crossterm v0.29.0
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]     Checking strum v0.27.2
[INFO] [stderr]     Checking ratatui v0.28.1
[INFO] [stderr]     Checking bincode v2.0.1
[INFO] [stderr]     Checking rand_pcg v0.9.0
[INFO] [stderr]     Checking ciborium v0.2.2
[INFO] [stderr]     Checking items v0.1.0 (/opt/rustwide/workdir/src/items)
[INFO] [stderr]     Checking error v0.1.0 (/opt/rustwide/workdir/src/error)
[INFO] [stderr]     Checking achievements v0.1.0 (/opt/rustwide/workdir/src/achievements)
[INFO] [stderr]     Checking tinytemplate v1.2.1
[INFO] [stderr]     Checking criterion v0.5.1
[INFO] [stderr]     Checking combat v0.1.0 (/opt/rustwide/workdir/src/combat)
[INFO] [stdout] warning: unused import: `crate::enemy::EnemyKind`
[INFO] [stdout]    --> src/combat/src/status_effect.rs:137:9
[INFO] [stdout]     |
[INFO] [stdout] 137 |     use crate::enemy::EnemyKind;
[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: `super::*`
[INFO] [stdout]  --> src/combat/src/tests.rs:3:9
[INFO] [stdout]   |
[INFO] [stdout] 3 |     use super::*;
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking dungeon v0.1.0 (/opt/rustwide/workdir/src/dungeon)
[INFO] [stdout] warning: unused variable: `normal_result`
[INFO] [stdout]    --> src/combat/src/tests.rs:206:13
[INFO] [stdout]     |
[INFO] [stdout] 206 |         let normal_result = crate::Combat::engage(&mut attacker, &mut defender, false);
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_normal_result`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `fov_range` is never read
[INFO] [stdout]    --> src/combat/src/vision.rs:142:9
[INFO] [stdout]     |
[INFO] [stdout] 140 |     struct MockCombatant {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] 141 |         name: String,
[INFO] [stdout] 142 |         fov_range: u32,
[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: `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] [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]     Checking hero v0.1.0 (/opt/rustwide/workdir/src/hero)
[INFO] [stdout] warning: unused imports: `Decode` and `Encode`
[INFO] [stdout]    --> src/hero/src/rng.rs:139:19
[INFO] [stdout]     |
[INFO] [stdout] 139 |     use bincode::{Decode, Encode, config};
[INFO] [stdout]     |                   ^^^^^^  ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/hero/src/rng.rs:169:13
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut rng = HeroRng::new(123456);
[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] [stderr]     Checking save v0.1.0 (/opt/rustwide/workdir/src/save)
[INFO] [stderr]     Checking 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] error: 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]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #107880 <https://github.com/rust-lang/rust/issues/107880>
[INFO] [stdout]    = note: `#[deny(ambiguous_glob_reexports)]` (part of `#[deny(future_incompatible)]`) 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] error: 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]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #107880 <https://github.com/rust-lang/rust/issues/107880>
[INFO] [stdout]    = note: `#[deny(ambiguous_glob_reexports)]` (part of `#[deny(future_incompatible)]`) 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: 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: 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: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: 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: `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: `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: 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: 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: `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: `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: `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: `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: 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: 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: 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] [stderr] error: could not compile `terminal_pixel_dungeon` (lib) due to 2 previous errors; 54 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error: could not compile `terminal_pixel_dungeon` (lib test) due to 2 previous errors; 65 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "5b83a1df266e9285428c42191814542def18f0a1f896b3a7878f12a05ee981f7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5b83a1df266e9285428c42191814542def18f0a1f896b3a7878f12a05ee981f7", kill_on_drop: false }`
[INFO] [stdout] 5b83a1df266e9285428c42191814542def18f0a1f896b3a7878f12a05ee981f7
