[INFO] cloning repository https://github.com/alexeygrigorev/game-ai-engineer
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/alexeygrigorev/game-ai-engineer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Falexeygrigorev%2Fgame-ai-engineer", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Falexeygrigorev%2Fgame-ai-engineer'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] d27abcd376fa2f3106f52b06f3dac722e1ccf949
[INFO] testing alexeygrigorev/game-ai-engineer against 1.94.0 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Falexeygrigorev%2Fgame-ai-engineer" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/alexeygrigorev/game-ai-engineer
[INFO] finished tweaking git repo https://github.com/alexeygrigorev/game-ai-engineer
[INFO] tweaked toml for git repo https://github.com/alexeygrigorev/game-ai-engineer written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/alexeygrigorev/game-ai-engineer on toolchain 1.94.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.94.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/alexeygrigorev/game-ai-engineer already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.94.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded native-tls v0.2.16
[INFO] [stderr]   Downloaded security-framework-sys v2.16.0
[INFO] [stderr]   Downloaded security-framework v3.6.0
[INFO] [stderr]   Downloaded system-configuration v0.7.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 768dcd83d0a2b7b2286b14cfad55f93da02f5e70eab8843676fd5fa2dc0fd4a7
[INFO] running `Command { std: "docker" "start" "-a" "768dcd83d0a2b7b2286b14cfad55f93da02f5e70eab8843676fd5fa2dc0fd4a7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "768dcd83d0a2b7b2286b14cfad55f93da02f5e70eab8843676fd5fa2dc0fd4a7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "768dcd83d0a2b7b2286b14cfad55f93da02f5e70eab8843676fd5fa2dc0fd4a7", kill_on_drop: false }`
[INFO] [stdout] 768dcd83d0a2b7b2286b14cfad55f93da02f5e70eab8843676fd5fa2dc0fd4a7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 8647ec2b9302078e153c7f28dbceeee749b2daa96ab4672449a5d720a2b7bc70
[INFO] running `Command { std: "docker" "start" "-a" "8647ec2b9302078e153c7f28dbceeee749b2daa96ab4672449a5d720a2b7bc70", kill_on_drop: false }`
[INFO] [stderr]    Compiling quote v1.0.44
[INFO] [stderr]    Compiling unicode-ident v1.0.23
[INFO] [stderr]    Compiling libc v0.2.182
[INFO] [stderr]    Compiling stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling bytes v1.11.1
[INFO] [stderr]    Compiling itoa v1.0.17
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling proc-macro2 v1.0.106
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling percent-encoding v2.3.2
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling futures-task v0.3.31
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling simd-adler32 v0.3.8
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling atomic-waker v1.1.2
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling native-tls v0.2.16
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling tower-service v0.3.3
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling syn v2.0.115
[INFO] [stderr]    Compiling want v0.3.1
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling zmij v1.0.21
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling fdeflate v0.3.7
[INFO] [stderr]    Compiling form_urlencoded v1.2.2
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling tower-layer v0.3.3
[INFO] [stderr]    Compiling flate2 v1.1.9
[INFO] [stderr]    Compiling socket2 v0.6.2
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling miniquad v0.4.8
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling png v0.17.16
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling memchr v2.8.0
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling ttf-parser v0.21.1
[INFO] [stderr]    Compiling bytemuck v1.25.0
[INFO] [stderr]    Compiling color_quant v1.1.0
[INFO] [stderr]    Compiling toml_write v0.1.2
[INFO] [stderr]    Compiling anyhow v1.0.101
[INFO] [stderr]    Compiling ryu v1.0.23
[INFO] [stderr]    Compiling iri-string v0.7.10
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling image v0.24.9
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling rustls-pki-types v1.14.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling quad-rand v0.2.3
[INFO] [stderr]    Compiling fontdue v0.9.3
[INFO] [stderr]    Compiling glam v0.27.0
[INFO] [stderr]    Compiling macroquad_macro v0.1.8
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling dotenvy v0.15.7
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling macroquad v0.4.14
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling ai_career_rpg v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `InputSource`
[INFO] [stdout]  --> src/testing/harness.rs:1:44
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::testing::input::{InputSnapshot, InputSource};
[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: `crate::skills::Proficiency`
[INFO] [stdout]  --> src/testing/harness.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::skills::Proficiency;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_tile_x`
[INFO] [stdout]    --> src/world/map.rs:215:13
[INFO] [stdout]     |
[INFO] [stdout] 215 |         let player_tile_x = (x / TILE_SIZE) as i32;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_x`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_tile_y`
[INFO] [stdout]    --> src/world/map.rs:216:13
[INFO] [stdout]     |
[INFO] [stdout] 216 |         let player_tile_y = (y / TILE_SIZE) as i32;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `current` is never read
[INFO] [stdout]    --> src/testing/harness.rs:101:5
[INFO] [stdout]     |
[INFO] [stdout]  99 | pub struct ScriptedInput {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] 100 |     frames: Vec<InputSnapshot>,
[INFO] [stdout] 101 |     current: usize,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Provider`
[INFO] [stdout]   --> src/bin/test_llm_integration.rs:12:50
[INFO] [stdout]    |
[INFO] [stdout] 12 | use ai_career_rpg::llm::{LlmConfig, LlmProvider, Provider, create_provider, MockProvider};
[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 variable: `config`
[INFO] [stdout]   --> src/bin/test_llm_integration.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let config = match GameConfig::load() {
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ActivityEngine` and `EngineType`
[INFO] [stdout]   --> src/engine/mod.rs:36:18
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub use traits::{ActivityEngine, EngineType};
[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: `config::GameConfig`
[INFO] [stdout]   --> src/engine/mod.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub use config::GameConfig;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `GameContext` and `SkillInfo`
[INFO] [stdout]   --> src/engine/mod.rs:38:19
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub use context::{GameContext, SkillInfo};
[INFO] [stdout]    |                   ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `cache::ResponseCache`
[INFO] [stdout]   --> src/engine/mod.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub use cache::ResponseCache;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NpcEngine`, `NpcInput`, and `NpcOutput`
[INFO] [stdout]   --> src/engine/mod.rs:40:15
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub use npc::{NpcEngine, NpcInput, NpcOutput};
[INFO] [stdout]    |               ^^^^^^^^^  ^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `anthropic::AnthropicProvider`
[INFO] [stdout]   --> src/llm/mod.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub use anthropic::AnthropicProvider;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Tile`
[INFO] [stdout]  --> src/world/mod.rs:8:48
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub use map::{GameMap, Building, BuildingType, Tile, MAP_WIDTH, MAP_HEIGHT};
[INFO] [stdout]   |                                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `NpcType`
[INFO] [stdout]  --> src/world/mod.rs:9:20
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use npc::{Npc, NpcType, get_npcs};
[INFO] [stdout]   |                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/main.rs:260:13
[INFO] [stdout]     |
[INFO] [stdout] 260 |             _ => {}
[INFO] [stdout]     |             ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/main.rs:260:13
[INFO] [stdout]     |
[INFO] [stdout]  91 |             GameScreen::Title => {
[INFO] [stdout]     |             ----------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 111 |             GameScreen::World => {
[INFO] [stdout]     |             ----------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 158 |             GameScreen::Dialog => {
[INFO] [stdout]     |             ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 196 |             GameScreen::Skills => {
[INFO] [stdout]     |             ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 260 |             _ => {}
[INFO] [stdout]     |             ^ ...and 4 other patterns collectively make this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/main.rs:574:13
[INFO] [stdout]     |
[INFO] [stdout] 574 |             _ => {}
[INFO] [stdout]     |             ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/main.rs:574:13
[INFO] [stdout]     |
[INFO] [stdout] 548 |             GameScreen::Title => self.draw_title_screen(),
[INFO] [stdout]     |             ----------------- matches some of the same values
[INFO] [stdout] 549 |             GameScreen::World => self.draw_world(),
[INFO] [stdout]     |             ----------------- matches some of the same values
[INFO] [stdout] 550 |             GameScreen::Dialog => {
[INFO] [stdout]     |             ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 554 |             GameScreen::Skills => {
[INFO] [stdout]     |             ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 574 |             _ => {}
[INFO] [stdout]     |             ^ ...and 4 other patterns collectively make this unreachable
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_tile_x`
[INFO] [stdout]    --> src/world/map.rs:215:13
[INFO] [stdout]     |
[INFO] [stdout] 215 |         let player_tile_x = (x / TILE_SIZE) as i32;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_x`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_tile_y`
[INFO] [stdout]    --> src/world/map.rs:216:13
[INFO] [stdout]     |
[INFO] [stdout] 216 |         let player_tile_y = (y / TILE_SIZE) as i32;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `interview`
[INFO] [stdout]    --> src/main.rs:239:29
[INFO] [stdout]     |
[INFO] [stdout] 239 |                 if let Some(ref interview) = self.interview {
[INFO] [stdout]     |                             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_interview`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `scroll_offset` is never read
[INFO] [stdout]   --> src/main.rs:66:5
[INFO] [stdout]    |
[INFO] [stdout] 54 | struct Game {
[INFO] [stdout]    |        ---- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 66 |     scroll_offset: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `EngineType` is never used
[INFO] [stdout]   --> src/engine/traits.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum EngineType {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ActivityEngine` is never used
[INFO] [stdout]   --> src/engine/traits.rs:86:11
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub trait ActivityEngine: Send + Sync {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LlmConfig` is never constructed
[INFO] [stdout]   --> src/engine/config.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct LlmConfig {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NpcClassConfig` is never constructed
[INFO] [stdout]   --> src/engine/config.rs:40:12
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub struct NpcClassConfig {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NpcConfig` is never constructed
[INFO] [stdout]   --> src/engine/config.rs:53:12
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub struct NpcConfig {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InterviewConfig` is never constructed
[INFO] [stdout]   --> src/engine/config.rs:64:12
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub struct InterviewConfig {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GameConfig` is never constructed
[INFO] [stdout]   --> src/engine/config.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub struct GameConfig {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `load`, `get_npc_engine`, `get_npc_persona`, and `get_npc_fallback_dialog` are never used
[INFO] [stdout]    --> src/engine/config.rs:101:12
[INFO] [stdout]     |
[INFO] [stdout]  97 | impl GameConfig {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn load() -> Result<Self> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub fn get_npc_engine(&self, class_name: &str) -> EngineType {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     pub fn get_npc_persona(&self, class_name: &str) -> Option<&str> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 127 |     pub fn get_npc_fallback_dialog(&self, class_name: &str) -> Option<&Vec<String>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SkillInfo` is never constructed
[INFO] [stdout]   --> src/engine/context.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct SkillInfo {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GameContext` is never constructed
[INFO] [stdout]   --> src/engine/context.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct GameContext {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `empty`, `from_game_state`, and `to_prompt_section` are never used
[INFO] [stdout]   --> src/engine/context.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 46 | impl GameContext {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] 47 |     /// Create an empty context for testing
[INFO] [stdout] 48 |     pub fn empty() -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub fn from_game_state(
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub fn to_prompt_section(&self) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CacheEntry` is never constructed
[INFO] [stdout]   --> src/engine/cache.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | struct CacheEntry {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `is_expired` are never used
[INFO] [stdout]   --> src/engine/cache.rs:31:8
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl CacheEntry {
[INFO] [stdout]    | --------------- associated items in this implementation
[INFO] [stdout] 31 |     fn new(response: String) -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     fn is_expired(&self, ttl: Duration) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ResponseCache` is never constructed
[INFO] [stdout]   --> src/engine/cache.rs:47:12
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub struct ResponseCache {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/engine/cache.rs:62:12
[INFO] [stdout]     |
[INFO] [stdout]  58 | impl ResponseCache {
[INFO] [stdout]     | ------------------ associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  62 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  72 |     pub fn with_settings(ttl: Duration, max_entries: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  87 |     pub fn make_key(activity: &str, input_id: &str, context: &GameContext) -> String {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     fn simple_hash(s: &str) -> u32 {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 122 |     pub fn get(&mut self, key: &str) -> Option<String> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 148 |     pub fn set(&mut self, key: String, response: String) {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 165 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 171 |     pub fn len(&self) -> usize {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 176 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ConversationHistory` is never constructed
[INFO] [stdout]   --> src/engine/npc.rs:40:12
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub struct ConversationHistory {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `MAX_MESSAGES`, `new`, `add_message`, and `clear` are never used
[INFO] [stdout]   --> src/engine/npc.rs:49:11
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl ConversationHistory {
[INFO] [stdout]    | ------------------------ associated items in this implementation
[INFO] [stdout] 48 |     /// Maximum messages to keep in history
[INFO] [stdout] 49 |     const MAX_MESSAGES: usize = 10;
[INFO] [stdout]    |           ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn add_message(&mut self, role: &str, content: String) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn clear(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NpcInput` is never constructed
[INFO] [stdout]   --> src/engine/npc.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub struct NpcInput {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NpcOutput` is never constructed
[INFO] [stdout]   --> src/engine/npc.rs:98:12
[INFO] [stdout]    |
[INFO] [stdout] 98 | pub struct NpcOutput {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NpcEngine` is never constructed
[INFO] [stdout]    --> src/engine/npc.rs:108:12
[INFO] [stdout]     |
[INFO] [stdout] 108 | pub struct NpcEngine {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/engine/npc.rs:127:12
[INFO] [stdout]     |
[INFO] [stdout] 119 | impl NpcEngine {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 127 |     pub fn new(config: GameConfig) -> Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn with_mock(config: GameConfig, response: &str) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 154 |     pub fn get_engine_type(&self, npc_class: &str) -> EngineType {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 166 |     pub async fn get_dialog(
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 188 |     fn rule_dialog(&self, npc_class: &str) -> Result<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 202 |     async fn llm_dialog(
[INFO] [stdout]     |              ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 261 |     pub fn clear_conversation(&mut self, npc_id: usize) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 268 |     pub fn clear_all_conversations(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `paused` is never read
[INFO] [stdout]   --> src/game/state.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct GameState {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 21 |     pub paused: bool,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GameState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_night` is never used
[INFO] [stdout]   --> src/game/state.rs:50:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl GameState {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 50 |     pub fn is_night(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_text_crisp_centered` is never used
[INFO] [stdout]   --> src/graphics/fonts.rs:52:8
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn draw_text_crisp_centered(text: &str, x: f32, y: f32, font_size: f32, color: Color) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `QuestionType` is never used
[INFO] [stdout]  --> src/interview/mod.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub enum QuestionType {
[INFO] [stdout]   |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InterviewQuestion` is never constructed
[INFO] [stdout]   --> src/interview/mod.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct InterviewQuestion {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InterviewRound` is never constructed
[INFO] [stdout]   --> src/interview/mod.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct InterviewRound {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InterviewResult` is never constructed
[INFO] [stdout]   --> src/interview/mod.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct InterviewResult {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Interview` is never constructed
[INFO] [stdout]   --> src/interview/mod.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub struct Interview;
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated functions are never used
[INFO] [stdout]    --> src/interview/mod.rs:41:12
[INFO] [stdout]     |
[INFO] [stdout]  40 | impl Interview {
[INFO] [stdout]     | -------------- associated functions in this implementation
[INFO] [stdout]  41 |     pub fn generate_rounds(job: &Job) -> Vec<InterviewRound> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  61 |     fn screening_round() -> InterviewRound {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  82 |     fn technical_round(skill: &str, proficiency: Proficiency) -> InterviewRound {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 187 |     fn system_design_round() -> InterviewRound {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 208 |     fn behavioral_round() -> InterviewRound {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 229 |     pub fn answer_question(player: &Player, question: &InterviewQuestion) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 246 |     pub fn conduct_round(player: &Player, round: &InterviewRound) -> InterviewResult {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `description` is never read
[INFO] [stdout]   --> src/jobs/mod.rs:62:9
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct Company {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] 61 |     pub name: String,
[INFO] [stdout] 62 |     pub description: String,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Company` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `salary_multiplier` and `difficulty_modifier` are never used
[INFO] [stdout]   --> src/jobs/mod.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 75 | impl CompanyTier {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] 76 |     pub fn salary_multiplier(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 85 |     pub fn difficulty_modifier(&self) -> u8 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LlmMessage` is never constructed
[INFO] [stdout]   --> src/llm/provider.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub struct LlmMessage {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `user`, `assistant`, and `system` are never used
[INFO] [stdout]   --> src/llm/provider.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl LlmMessage {
[INFO] [stdout]    | --------------- associated functions in this implementation
[INFO] [stdout] 43 |     /// Create a user message
[INFO] [stdout] 44 |     pub fn user(content: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn assistant(content: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60 |     pub fn system(content: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `LlmProvider` is never used
[INFO] [stdout]   --> src/llm/provider.rs:71:11
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub trait LlmProvider: Send + Sync {
[INFO] [stdout]    |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Provider` is never used
[INFO] [stdout]   --> src/llm/provider.rs:88:10
[INFO] [stdout]    |
[INFO] [stdout] 88 | pub enum Provider {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LlmConfig` is never constructed
[INFO] [stdout]    --> src/llm/provider.rs:117:12
[INFO] [stdout]     |
[INFO] [stdout] 117 | pub struct LlmConfig {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_provider` is never used
[INFO] [stdout]    --> src/llm/provider.rs:132:8
[INFO] [stdout]     |
[INFO] [stdout] 132 | pub fn create_provider(config: &LlmConfig) -> Result<Provider> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AnthropicProvider` is never constructed
[INFO] [stdout]   --> src/llm/anthropic.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct AnthropicProvider {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/llm/anthropic.rs:47:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | impl AnthropicProvider {
[INFO] [stdout]    | ---------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn new(model: &str) -> Result<Self> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AnthropicMessage` is never constructed
[INFO] [stdout]    --> src/llm/anthropic.rs:134:8
[INFO] [stdout]     |
[INFO] [stdout] 134 | struct AnthropicMessage {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ContentBlock` is never constructed
[INFO] [stdout]    --> src/llm/anthropic.rs:140:8
[INFO] [stdout]     |
[INFO] [stdout] 140 | struct ContentBlock {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ApiResponse` is never constructed
[INFO] [stdout]    --> src/llm/anthropic.rs:147:8
[INFO] [stdout]     |
[INFO] [stdout] 147 | struct ApiResponse {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ApiContent` is never constructed
[INFO] [stdout]    --> src/llm/anthropic.rs:152:8
[INFO] [stdout]     |
[INFO] [stdout] 152 | struct ApiContent {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MockProvider` is never constructed
[INFO] [stdout]   --> src/llm/mock.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct MockProvider {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `with_name`, `set_response`, `get_requests`, and `clear_requests` are never used
[INFO] [stdout]   --> src/llm/mock.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 36 | impl MockProvider {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 37 |     /// Create a mock that returns a fixed response
[INFO] [stdout] 38 |     pub fn new(response: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn with_name(name: impl Into<String>, response: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 56 |     pub fn set_response(&self, response: impl Into<String>) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn get_requests(&self) -> Vec<(String, Vec<LlmMessage>)> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub fn clear_requests(&self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `name`, `day`, and `reputation` are never read
[INFO] [stdout]   --> src/player/mod.rs:41:9
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub struct Player {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] 41 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub day: u32,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub reputation: u32,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Player` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `study`, `get_skill_proficiency`, and `advance_day` are never used
[INFO] [stdout]    --> src/player/mod.rs:76:12
[INFO] [stdout]     |
[INFO] [stdout]  52 | impl Player {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub fn study(&mut self, skill_name: &str, hours: u32) -> Result<String, String> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn get_skill_proficiency(&self, skill_name: &str) -> Proficiency {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub fn advance_day(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/skills/mod.rs:82:12
[INFO] [stdout]    |
[INFO] [stdout] 81 | impl Skill {
[INFO] [stdout]    | ---------- associated function in this implementation
[INFO] [stdout] 82 |     pub fn new(name: &str, category: SkillCategory, description: &str, difficulty: u8) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `position` and `tile_position` are never used
[INFO] [stdout]   --> src/world/player.rs:84:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl WorldPlayer {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 84 |     pub fn position(&self) -> Vec2 {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88 |     pub fn tile_position(&self) -> (i32, i32) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Building`, `Door`, and `Water` are never constructed
[INFO] [stdout]   --> src/world/map.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub enum Tile {
[INFO] [stdout]    |          ---- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 12 |     Building,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 13 |     Door,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 14 |     Water,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Tile` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `JobCenter` and `Park` are never constructed
[INFO] [stdout]   --> src/world/map.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub enum BuildingType {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 33 |     JobCenter,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 34 |     Park,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BuildingType` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `name` is never used
[INFO] [stdout]   --> src/world/npc.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl NpcType {
[INFO] [stdout]    | ------------ method in this implementation
[INFO] [stdout] 14 |     pub fn name(&self) -> &str {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `draw` is never used
[INFO] [stdout]    --> src/world/npc.rs:100:12
[INFO] [stdout]     |
[INFO] [stdout]  35 | impl Npc {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 100 |     pub fn draw(&self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 49s
[INFO] running `Command { std: "docker" "inspect" "8647ec2b9302078e153c7f28dbceeee749b2daa96ab4672449a5d720a2b7bc70", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8647ec2b9302078e153c7f28dbceeee749b2daa96ab4672449a5d720a2b7bc70", kill_on_drop: false }`
[INFO] [stdout] 8647ec2b9302078e153c7f28dbceeee749b2daa96ab4672449a5d720a2b7bc70
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 95622d8dccf0f3511aa042d25b97253653ee29e613fa7ba2ae58683eea0b3471
[INFO] running `Command { std: "docker" "start" "-a" "95622d8dccf0f3511aa042d25b97253653ee29e613fa7ba2ae58683eea0b3471", kill_on_drop: false }`
[INFO] [stderr]    Compiling ai_career_rpg v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `InputSource`
[INFO] [stdout]  --> src/testing/harness.rs:1:44
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::testing::input::{InputSnapshot, InputSource};
[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: `crate::skills::Proficiency`
[INFO] [stdout]  --> src/testing/harness.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::skills::Proficiency;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_tile_x`
[INFO] [stdout]    --> src/world/map.rs:215:13
[INFO] [stdout]     |
[INFO] [stdout] 215 |         let player_tile_x = (x / TILE_SIZE) as i32;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_x`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_tile_y`
[INFO] [stdout]    --> src/world/map.rs:216:13
[INFO] [stdout]     |
[INFO] [stdout] 216 |         let player_tile_y = (y / TILE_SIZE) as i32;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `current` is never read
[INFO] [stdout]    --> src/testing/harness.rs:101:5
[INFO] [stdout]     |
[INFO] [stdout]  99 | pub struct ScriptedInput {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] 100 |     frames: Vec<InputSnapshot>,
[INFO] [stdout] 101 |     current: usize,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `InputSource`
[INFO] [stdout]  --> src/testing/harness.rs:1:44
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::testing::input::{InputSnapshot, InputSource};
[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: `Provider`
[INFO] [stdout]   --> src/bin/test_llm_integration.rs:12:50
[INFO] [stdout]    |
[INFO] [stdout] 12 | use ai_career_rpg::llm::{LlmConfig, LlmProvider, Provider, create_provider, MockProvider};
[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 variable: `config`
[INFO] [stdout]   --> src/bin/test_llm_integration.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let config = match GameConfig::load() {
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ActivityEngine` and `EngineType`
[INFO] [stdout]   --> src/engine/mod.rs:36:18
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub use traits::{ActivityEngine, EngineType};
[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: `config::GameConfig`
[INFO] [stdout]   --> src/engine/mod.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub use config::GameConfig;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `GameContext` and `SkillInfo`
[INFO] [stdout]   --> src/engine/mod.rs:38:19
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub use context::{GameContext, SkillInfo};
[INFO] [stdout]    |                   ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `cache::ResponseCache`
[INFO] [stdout]   --> src/engine/mod.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub use cache::ResponseCache;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NpcEngine`, `NpcInput`, and `NpcOutput`
[INFO] [stdout]   --> src/engine/mod.rs:40:15
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub use npc::{NpcEngine, NpcInput, NpcOutput};
[INFO] [stdout]    |               ^^^^^^^^^  ^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `anthropic::AnthropicProvider`
[INFO] [stdout]   --> src/llm/mod.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub use anthropic::AnthropicProvider;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Tile`
[INFO] [stdout]  --> src/world/mod.rs:8:48
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub use map::{GameMap, Building, BuildingType, Tile, MAP_WIDTH, MAP_HEIGHT};
[INFO] [stdout]   |                                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `NpcType`
[INFO] [stdout]  --> src/world/mod.rs:9:20
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use npc::{Npc, NpcType, get_npcs};
[INFO] [stdout]   |                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/main.rs:260:13
[INFO] [stdout]     |
[INFO] [stdout] 260 |             _ => {}
[INFO] [stdout]     |             ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/main.rs:260:13
[INFO] [stdout]     |
[INFO] [stdout]  91 |             GameScreen::Title => {
[INFO] [stdout]     |             ----------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 111 |             GameScreen::World => {
[INFO] [stdout]     |             ----------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 158 |             GameScreen::Dialog => {
[INFO] [stdout]     |             ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 196 |             GameScreen::Skills => {
[INFO] [stdout]     |             ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 260 |             _ => {}
[INFO] [stdout]     |             ^ ...and 4 other patterns collectively make this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/main.rs:574:13
[INFO] [stdout]     |
[INFO] [stdout] 574 |             _ => {}
[INFO] [stdout]     |             ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/main.rs:574:13
[INFO] [stdout]     |
[INFO] [stdout] 548 |             GameScreen::Title => self.draw_title_screen(),
[INFO] [stdout]     |             ----------------- matches some of the same values
[INFO] [stdout] 549 |             GameScreen::World => self.draw_world(),
[INFO] [stdout]     |             ----------------- matches some of the same values
[INFO] [stdout] 550 |             GameScreen::Dialog => {
[INFO] [stdout]     |             ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 554 |             GameScreen::Skills => {
[INFO] [stdout]     |             ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 574 |             _ => {}
[INFO] [stdout]     |             ^ ...and 4 other patterns collectively make this unreachable
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ctx`
[INFO] [stdout]    --> src/engine/cache.rs:236:13
[INFO] [stdout]     |
[INFO] [stdout] 236 |         let ctx = GameContext::empty();
[INFO] [stdout]     |             ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ctx`
[INFO] [stdout]    --> src/engine/cache.rs:236:13
[INFO] [stdout]     |
[INFO] [stdout] 236 |         let ctx = GameContext::empty();
[INFO] [stdout]     |             ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_tile_x`
[INFO] [stdout]    --> src/world/map.rs:215:13
[INFO] [stdout]     |
[INFO] [stdout] 215 |         let player_tile_x = (x / TILE_SIZE) as i32;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_tile_y`
[INFO] [stdout]    --> src/world/map.rs:216:13
[INFO] [stdout]     |
[INFO] [stdout] 216 |         let player_tile_y = (y / TILE_SIZE) as i32;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `current` is never read
[INFO] [stdout]    --> src/testing/harness.rs:101:5
[INFO] [stdout]     |
[INFO] [stdout]  99 | pub struct ScriptedInput {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] 100 |     frames: Vec<InputSnapshot>,
[INFO] [stdout] 101 |     current: usize,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_tile_x`
[INFO] [stdout]    --> src/world/map.rs:215:13
[INFO] [stdout]     |
[INFO] [stdout] 215 |         let player_tile_x = (x / TILE_SIZE) as i32;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `player_tile_y`
[INFO] [stdout]    --> src/world/map.rs:216:13
[INFO] [stdout]     |
[INFO] [stdout] 216 |         let player_tile_y = (y / TILE_SIZE) as i32;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `interview`
[INFO] [stdout]    --> src/main.rs:239:29
[INFO] [stdout]     |
[INFO] [stdout] 239 |                 if let Some(ref interview) = self.interview {
[INFO] [stdout]     |                             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_interview`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `scroll_offset` is never read
[INFO] [stdout]   --> src/main.rs:66:5
[INFO] [stdout]    |
[INFO] [stdout] 54 | struct Game {
[INFO] [stdout]    |        ---- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 66 |     scroll_offset: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ActivityEngine` is never used
[INFO] [stdout]   --> src/engine/traits.rs:86:11
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub trait ActivityEngine: Send + Sync {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `model` is never read
[INFO] [stdout]   --> src/engine/config.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct LlmConfig {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub model: String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `LlmConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `engine` is never read
[INFO] [stdout]   --> src/engine/config.rs:67:9
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub struct InterviewConfig {
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 67 |     pub engine: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `InterviewConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `interview` is never read
[INFO] [stdout]   --> src/engine/config.rs:77:9
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub struct GameConfig {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 77 |     pub interview: InterviewConfig,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GameConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_game_state` is never used
[INFO] [stdout]   --> src/engine/context.rs:59:12
[INFO] [stdout]    |
[INFO] [stdout] 46 | impl GameContext {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub fn from_game_state(
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `clear`, `len`, and `is_empty` are never used
[INFO] [stdout]    --> src/engine/cache.rs:165:12
[INFO] [stdout]     |
[INFO] [stdout]  58 | impl ResponseCache {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 165 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 171 |     pub fn len(&self) -> usize {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 176 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `clear` is never used
[INFO] [stdout]   --> src/engine/npc.rs:74:12
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl ConversationHistory {
[INFO] [stdout]    | ------------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn clear(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `text` is never read
[INFO] [stdout]    --> src/engine/npc.rs:100:9
[INFO] [stdout]     |
[INFO] [stdout]  98 | pub struct NpcOutput {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout]  99 |     /// The dialog text to display
[INFO] [stdout] 100 |     pub text: String,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `get_engine_type`, `clear_conversation`, and `clear_all_conversations` are never used
[INFO] [stdout]    --> src/engine/npc.rs:127:12
[INFO] [stdout]     |
[INFO] [stdout] 119 | impl NpcEngine {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 127 |     pub fn new(config: GameConfig) -> Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 154 |     pub fn get_engine_type(&self, npc_class: &str) -> EngineType {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 261 |     pub fn clear_conversation(&mut self, npc_id: usize) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 268 |     pub fn clear_all_conversations(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `paused` is never read
[INFO] [stdout]   --> src/game/state.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct GameState {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 21 |     pub paused: bool,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GameState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_night` is never used
[INFO] [stdout]   --> src/game/state.rs:50:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl GameState {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 50 |     pub fn is_night(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `draw_text_crisp_centered` is never used
[INFO] [stdout]   --> src/graphics/fonts.rs:52:8
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn draw_text_crisp_centered(text: &str, x: f32, y: f32, font_size: f32, color: Color) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `QuestionType` is never used
[INFO] [stdout]  --> src/interview/mod.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub enum QuestionType {
[INFO] [stdout]   |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InterviewQuestion` is never constructed
[INFO] [stdout]   --> src/interview/mod.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct InterviewQuestion {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InterviewRound` is never constructed
[INFO] [stdout]   --> src/interview/mod.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct InterviewRound {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InterviewResult` is never constructed
[INFO] [stdout]   --> src/interview/mod.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct InterviewResult {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Interview` is never constructed
[INFO] [stdout]   --> src/interview/mod.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub struct Interview;
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated functions are never used
[INFO] [stdout]    --> src/interview/mod.rs:41:12
[INFO] [stdout]     |
[INFO] [stdout]  40 | impl Interview {
[INFO] [stdout]     | -------------- associated functions in this implementation
[INFO] [stdout]  41 |     pub fn generate_rounds(job: &Job) -> Vec<InterviewRound> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  61 |     fn screening_round() -> InterviewRound {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  82 |     fn technical_round(skill: &str, proficiency: Proficiency) -> InterviewRound {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 187 |     fn system_design_round() -> InterviewRound {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 208 |     fn behavioral_round() -> InterviewRound {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 229 |     pub fn answer_question(player: &Player, question: &InterviewQuestion) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 246 |     pub fn conduct_round(player: &Player, round: &InterviewRound) -> InterviewResult {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `description` is never read
[INFO] [stdout]   --> src/jobs/mod.rs:62:9
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct Company {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] 61 |     pub name: String,
[INFO] [stdout] 62 |     pub description: String,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Company` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `name` is never used
[INFO] [stdout]   --> src/llm/provider.rs:80:8
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub trait LlmProvider: Send + Sync {
[INFO] [stdout]    |           ----------- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 80 |     fn name(&self) -> &str;
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `with_credentials` is never used
[INFO] [stdout]   --> src/llm/anthropic.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | impl AnthropicProvider {
[INFO] [stdout]    | ---------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn with_credentials(api_key: String, base_url: String, model: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `name` is never read
[INFO] [stdout]   --> src/llm/mock.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct MockProvider {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 28 |     /// Name of this mock provider
[INFO] [stdout] 29 |     name: String,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MockProvider` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `with_name` and `clear_requests` are never used
[INFO] [stdout]   --> src/llm/mock.rs:47:12
[INFO] [stdout]    |
[INFO] [stdout] 36 | impl MockProvider {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn with_name(name: impl Into<String>, response: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub fn clear_requests(&self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `reputation` is never read
[INFO] [stdout]   --> src/player/mod.rs:49:9
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub struct Player {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub reputation: u32,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Player` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_skill_proficiency` is never used
[INFO] [stdout]    --> src/player/mod.rs:105:12
[INFO] [stdout]     |
[INFO] [stdout]  52 | impl Player {
[INFO] [stdout]     | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn get_skill_proficiency(&self, skill_name: &str) -> Proficiency {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `position` and `tile_position` are never used
[INFO] [stdout]   --> src/world/player.rs:84:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl WorldPlayer {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 84 |     pub fn position(&self) -> Vec2 {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88 |     pub fn tile_position(&self) -> (i32, i32) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Building`, `Door`, and `Water` are never constructed
[INFO] [stdout]   --> src/world/map.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub enum Tile {
[INFO] [stdout]    |          ---- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 12 |     Building,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 13 |     Door,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 14 |     Water,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Tile` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `JobCenter` and `Park` are never constructed
[INFO] [stdout]   --> src/world/map.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub enum BuildingType {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 33 |     JobCenter,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 34 |     Park,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BuildingType` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `name` is never used
[INFO] [stdout]   --> src/world/npc.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl NpcType {
[INFO] [stdout]    | ------------ method in this implementation
[INFO] [stdout] 14 |     pub fn name(&self) -> &str {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `draw` is never used
[INFO] [stdout]    --> src/world/npc.rs:100:12
[INFO] [stdout]     |
[INFO] [stdout]  35 | impl Npc {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 100 |     pub fn draw(&self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 7.83s
[INFO] running `Command { std: "docker" "inspect" "95622d8dccf0f3511aa042d25b97253653ee29e613fa7ba2ae58683eea0b3471", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "95622d8dccf0f3511aa042d25b97253653ee29e613fa7ba2ae58683eea0b3471", kill_on_drop: false }`
[INFO] [stdout] 95622d8dccf0f3511aa042d25b97253653ee29e613fa7ba2ae58683eea0b3471
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] fbe848f4840251a26ccead62f193b6dbeb0beb7454cfc764c7d7c15cbe66a21d
[INFO] running `Command { std: "docker" "start" "-a" "fbe848f4840251a26ccead62f193b6dbeb0beb7454cfc764c7d7c15cbe66a21d", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `InputSource`
[INFO] [stderr]  --> src/testing/harness.rs:1:44
[INFO] [stderr]   |
[INFO] [stderr] 1 | use crate::testing::input::{InputSnapshot, InputSource};
[INFO] [stderr]   |                                            ^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::skills::Proficiency`
[INFO] [stderr]  --> src/testing/harness.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use crate::skills::Proficiency;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player_tile_x`
[INFO] [stderr]    --> src/world/map.rs:215:13
[INFO] [stderr]     |
[INFO] [stderr] 215 |         let player_tile_x = (x / TILE_SIZE) as i32;
[INFO] [stderr]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_x`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player_tile_y`
[INFO] [stderr]    --> src/world/map.rs:216:13
[INFO] [stderr]     |
[INFO] [stderr] 216 |         let player_tile_y = (y / TILE_SIZE) as i32;
[INFO] [stderr]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_y`
[INFO] [stderr] 
[INFO] [stderr] warning: field `current` is never read
[INFO] [stderr]    --> src/testing/harness.rs:101:5
[INFO] [stderr]     |
[INFO] [stderr]  99 | pub struct ScriptedInput {
[INFO] [stderr]     |            ------------- field in this struct
[INFO] [stderr] 100 |     frames: Vec<InputSnapshot>,
[INFO] [stderr] 101 |     current: usize,
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `ctx`
[INFO] [stderr]    --> src/engine/cache.rs:236:13
[INFO] [stderr]     |
[INFO] [stderr] 236 |         let ctx = GameContext::empty();
[INFO] [stderr]     |             ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `player_tile_x`
[INFO] [stderr]    --> src/world/map.rs:215:13
[INFO] [stderr]     |
[INFO] [stderr] 215 |         let player_tile_x = (x / TILE_SIZE) as i32;
[INFO] [stderr]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_player_tile_x`
[INFO] [stderr] 
[INFO] [stderr] warning: `ai_career_rpg` (lib) generated 5 warnings (run `cargo fix --lib -p ai_career_rpg` to apply 4 suggestions)
[INFO] [stderr] warning: `ai_career_rpg` (lib test) generated 5 warnings (3 duplicates) (run `cargo fix --lib -p ai_career_rpg --tests` to apply 2 suggestions)
[INFO] [stderr] warning: unused imports: `ActivityEngine` and `EngineType`
[INFO] [stderr]   --> src/engine/mod.rs:36:18
[INFO] [stderr]    |
[INFO] [stderr] 36 | pub use traits::{ActivityEngine, EngineType};
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `config::GameConfig`
[INFO] [stderr]   --> src/engine/mod.rs:37:9
[INFO] [stderr]    |
[INFO] [stderr] 37 | pub use config::GameConfig;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `GameContext` and `SkillInfo`
[INFO] [stderr]   --> src/engine/mod.rs:38:19
[INFO] [stderr]    |
[INFO] [stderr] 38 | pub use context::{GameContext, SkillInfo};
[INFO] [stderr]    |                   ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `cache::ResponseCache`
[INFO] [stderr]   --> src/engine/mod.rs:39:9
[INFO] [stderr]    |
[INFO] [stderr] 39 | pub use cache::ResponseCache;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `NpcEngine`, `NpcInput`, and `NpcOutput`
[INFO] [stderr]   --> src/engine/mod.rs:40:15
[INFO] [stderr]    |
[INFO] [stderr] 40 | pub use npc::{NpcEngine, NpcInput, NpcOutput};
[INFO] [stderr]    |               ^^^^^^^^^  ^^^^^^^^  ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `anthropic::AnthropicProvider`
[INFO] [stderr]   --> src/llm/mod.rs:47:9
[INFO] [stderr]    |
[INFO] [stderr] 47 | pub use anthropic::AnthropicProvider;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Tile`
[INFO] [stderr]  --> src/world/mod.rs:8:48
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub use map::{GameMap, Building, BuildingType, Tile, MAP_WIDTH, MAP_HEIGHT};
[INFO] [stderr]   |                                                ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `NpcType`
[INFO] [stderr]  --> src/world/mod.rs:9:20
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub use npc::{Npc, NpcType, get_npcs};
[INFO] [stderr]   |                    ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]    --> src/main.rs:260:13
[INFO] [stderr]     |
[INFO] [stderr] 260 |             _ => {}
[INFO] [stderr]     |             ^ no value can reach this
[INFO] [stderr]     |
[INFO] [stderr] note: multiple earlier patterns match some of the same values
[INFO] [stderr]    --> src/main.rs:260:13
[INFO] [stderr]     |
[INFO] [stderr]  91 |             GameScreen::Title => {
[INFO] [stderr]     |             ----------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 111 |             GameScreen::World => {
[INFO] [stderr]     |             ----------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 158 |             GameScreen::Dialog => {
[INFO] [stderr]     |             ------------------ matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 196 |             GameScreen::Skills => {
[INFO] [stderr]     |             ------------------ matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 260 |             _ => {}
[INFO] [stderr]     |             ^ ...and 4 other patterns collectively make this unreachable
[INFO] [stderr]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]    --> src/main.rs:574:13
[INFO] [stderr]     |
[INFO] [stderr] 574 |             _ => {}
[INFO] [stderr]     |             ^ no value can reach this
[INFO] [stderr]     |
[INFO] [stderr] note: multiple earlier patterns match some of the same values
[INFO] [stderr]    --> src/main.rs:574:13
[INFO] [stderr]     |
[INFO] [stderr] 548 |             GameScreen::Title => self.draw_title_screen(),
[INFO] [stderr]     |             ----------------- matches some of the same values
[INFO] [stderr] 549 |             GameScreen::World => self.draw_world(),
[INFO] [stderr]     |             ----------------- matches some of the same values
[INFO] [stderr] 550 |             GameScreen::Dialog => {
[INFO] [stderr]     |             ------------------ matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 554 |             GameScreen::Skills => {
[INFO] [stderr]     |             ------------------ matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 574 |             _ => {}
[INFO] [stderr]     |             ^ ...and 4 other patterns collectively make this unreachable
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `interview`
[INFO] [stderr]    --> src/main.rs:239:29
[INFO] [stderr]     |
[INFO] [stderr] 239 |                 if let Some(ref interview) = self.interview {
[INFO] [stderr]     |                             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_interview`
[INFO] [stderr] 
[INFO] [stderr] warning: field `scroll_offset` is never read
[INFO] [stderr]   --> src/main.rs:66:5
[INFO] [stderr]    |
[INFO] [stderr] 54 | struct Game {
[INFO] [stderr]    |        ---- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 66 |     scroll_offset: usize,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait `ActivityEngine` is never used
[INFO] [stderr]   --> src/engine/traits.rs:86:11
[INFO] [stderr]    |
[INFO] [stderr] 86 | pub trait ActivityEngine: Send + Sync {
[INFO] [stderr]    |           ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `model` is never read
[INFO] [stderr]   --> src/engine/config.rs:35:9
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub struct LlmConfig {
[INFO] [stderr]    |            --------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 35 |     pub model: String,
[INFO] [stderr]    |         ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `LlmConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `engine` is never read
[INFO] [stderr]   --> src/engine/config.rs:67:9
[INFO] [stderr]    |
[INFO] [stderr] 64 | pub struct InterviewConfig {
[INFO] [stderr]    |            --------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 67 |     pub engine: String,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `InterviewConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `interview` is never read
[INFO] [stderr]   --> src/engine/config.rs:77:9
[INFO] [stderr]    |
[INFO] [stderr] 72 | pub struct GameConfig {
[INFO] [stderr]    |            ---------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 77 |     pub interview: InterviewConfig,
[INFO] [stderr]    |         ^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `GameConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_game_state` is never used
[INFO] [stderr]   --> src/engine/context.rs:59:12
[INFO] [stderr]    |
[INFO] [stderr] 46 | impl GameContext {
[INFO] [stderr]    | ---------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 59 |     pub fn from_game_state(
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `clear`, `len`, and `is_empty` are never used
[INFO] [stderr]    --> src/engine/cache.rs:165:12
[INFO] [stderr]     |
[INFO] [stderr]  58 | impl ResponseCache {
[INFO] [stderr]     | ------------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 165 |     pub fn clear(&mut self) {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 171 |     pub fn len(&self) -> usize {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 176 |     pub fn is_empty(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `clear` is never used
[INFO] [stderr]   --> src/engine/npc.rs:74:12
[INFO] [stderr]    |
[INFO] [stderr] 47 | impl ConversationHistory {
[INFO] [stderr]    | ------------------------ method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 74 |     pub fn clear(&mut self) {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `text` is never read
[INFO] [stderr]    --> src/engine/npc.rs:100:9
[INFO] [stderr]     |
[INFO] [stderr]  98 | pub struct NpcOutput {
[INFO] [stderr]     |            --------- field in this struct
[INFO] [stderr]  99 |     /// The dialog text to display
[INFO] [stderr] 100 |     pub text: String,
[INFO] [stderr]     |         ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `get_engine_type`, `clear_conversation`, and `clear_all_conversations` are never used
[INFO] [stderr]    --> src/engine/npc.rs:127:12
[INFO] [stderr]     |
[INFO] [stderr] 119 | impl NpcEngine {
[INFO] [stderr]     | -------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 127 |     pub fn new(config: GameConfig) -> Result<Self> {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 154 |     pub fn get_engine_type(&self, npc_class: &str) -> EngineType {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 261 |     pub fn clear_conversation(&mut self, npc_id: usize) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 268 |     pub fn clear_all_conversations(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `paused` is never read
[INFO] [stderr]   --> src/game/state.rs:21:9
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub struct GameState {
[INFO] [stderr]    |            --------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 21 |     pub paused: bool,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `GameState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: method `is_night` is never used
[INFO] [stderr]   --> src/game/state.rs:50:12
[INFO] [stderr]    |
[INFO] [stderr] 24 | impl GameState {
[INFO] [stderr]    | -------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 50 |     pub fn is_night(&self) -> bool {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `draw_text_crisp_centered` is never used
[INFO] [stderr]   --> src/graphics/fonts.rs:52:8
[INFO] [stderr]    |
[INFO] [stderr] 52 | pub fn draw_text_crisp_centered(text: &str, x: f32, y: f32, font_size: f32, color: Color) {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `QuestionType` is never used
[INFO] [stderr]  --> src/interview/mod.rs:8:10
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub enum QuestionType {
[INFO] [stderr]   |          ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `InterviewQuestion` is never constructed
[INFO] [stderr]   --> src/interview/mod.rs:16:12
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub struct InterviewQuestion {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `InterviewRound` is never constructed
[INFO] [stderr]   --> src/interview/mod.rs:24:12
[INFO] [stderr]    |
[INFO] [stderr] 24 | pub struct InterviewRound {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `InterviewResult` is never constructed
[INFO] [stderr]   --> src/interview/mod.rs:31:12
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub struct InterviewResult {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Interview` is never constructed
[INFO] [stderr]   --> src/interview/mod.rs:38:12
[INFO] [stderr]    |
[INFO] [stderr] 38 | pub struct Interview;
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated functions are never used
[INFO] [stderr]    --> src/interview/mod.rs:41:12
[INFO] [stderr]     |
[INFO] [stderr]  40 | impl Interview {
[INFO] [stderr]     | -------------- associated functions in this implementation
[INFO] [stderr]  41 |     pub fn generate_rounds(job: &Job) -> Vec<InterviewRound> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  61 |     fn screening_round() -> InterviewRound {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  82 |     fn technical_round(skill: &str, proficiency: Proficiency) -> InterviewRound {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 187 |     fn system_design_round() -> InterviewRound {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 208 |     fn behavioral_round() -> InterviewRound {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 229 |     pub fn answer_question(player: &Player, question: &InterviewQuestion) -> f32 {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 246 |     pub fn conduct_round(player: &Player, round: &InterviewRound) -> InterviewResult {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `description` is never read
[INFO] [stderr]   --> src/jobs/mod.rs:62:9
[INFO] [stderr]    |
[INFO] [stderr] 60 | pub struct Company {
[INFO] [stderr]    |            ------- field in this struct
[INFO] [stderr] 61 |     pub name: String,
[INFO] [stderr] 62 |     pub description: String,
[INFO] [stderr]    |         ^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Company` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: method `name` is never used
[INFO] [stderr]   --> src/llm/provider.rs:80:8
[INFO] [stderr]    |
[INFO] [stderr] 71 | pub trait LlmProvider: Send + Sync {
[INFO] [stderr]    |           ----------- method in this trait
[INFO] [stderr] ...
[INFO] [stderr] 80 |     fn name(&self) -> &str;
[INFO] [stderr]    |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `with_credentials` is never used
[INFO] [stderr]   --> src/llm/anthropic.rs:65:12
[INFO] [stderr]    |
[INFO] [stderr] 38 | impl AnthropicProvider {
[INFO] [stderr]    | ---------------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 65 |     pub fn with_credentials(api_key: String, base_url: String, model: String) -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `name` is never read
[INFO] [stderr]   --> src/llm/mock.rs:29:5
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub struct MockProvider {
[INFO] [stderr]    |            ------------ field in this struct
[INFO] [stderr] 28 |     /// Name of this mock provider
[INFO] [stderr] 29 |     name: String,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MockProvider` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `with_name` and `clear_requests` are never used
[INFO] [stderr]   --> src/llm/mock.rs:47:12
[INFO] [stderr]    |
[INFO] [stderr] 36 | impl MockProvider {
[INFO] [stderr]    | ----------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 47 |     pub fn with_name(name: impl Into<String>, response: impl Into<String>) -> Self {
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 66 |     pub fn clear_requests(&self) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `reputation` is never read
[INFO] [stderr]   --> src/player/mod.rs:49:9
[INFO] [stderr]    |
[INFO] [stderr] 40 | pub struct Player {
[INFO] [stderr]    |            ------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 49 |     pub reputation: u32,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Player` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: method `get_skill_proficiency` is never used
[INFO] [stderr]    --> src/player/mod.rs:105:12
[INFO] [stderr]     |
[INFO] [stderr]  52 | impl Player {
[INFO] [stderr]     | ----------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 105 |     pub fn get_skill_proficiency(&self, skill_name: &str) -> Proficiency {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `position` and `tile_position` are never used
[INFO] [stderr]   --> src/world/player.rs:84:12
[INFO] [stderr]    |
[INFO] [stderr] 25 | impl WorldPlayer {
[INFO] [stderr]    | ---------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 84 |     pub fn position(&self) -> Vec2 {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 88 |     pub fn tile_position(&self) -> (i32, i32) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Building`, `Door`, and `Water` are never constructed
[INFO] [stderr]   --> src/world/map.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr]  9 | pub enum Tile {
[INFO] [stderr]    |          ---- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 12 |     Building,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 13 |     Door,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 14 |     Water,
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Tile` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variants `JobCenter` and `Park` are never constructed
[INFO] [stderr]   --> src/world/map.rs:33:5
[INFO] [stderr]    |
[INFO] [stderr] 28 | pub enum BuildingType {
[INFO] [stderr]    |          ------------ variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 33 |     JobCenter,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 34 |     Park,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `BuildingType` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: method `name` is never used
[INFO] [stderr]   --> src/world/npc.rs:14:12
[INFO] [stderr]    |
[INFO] [stderr] 13 | impl NpcType {
[INFO] [stderr]    | ------------ method in this implementation
[INFO] [stderr] 14 |     pub fn name(&self) -> &str {
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `draw` is never used
[INFO] [stderr]    --> src/world/npc.rs:100:12
[INFO] [stderr]     |
[INFO] [stderr]  35 | impl Npc {
[INFO] [stderr]     | -------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 100 |     pub fn draw(&self) {
[INFO] [stderr]     |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Provider`
[INFO] [stderr]   --> src/bin/test_llm_integration.rs:12:50
[INFO] [stderr]    |
[INFO] [stderr] 12 | use ai_career_rpg::llm::{LlmConfig, LlmProvider, Provider, create_provider, MockProvider};
[INFO] [stderr]    |                                                  ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `config`
[INFO] [stderr]   --> src/bin/test_llm_integration.rs:20:9
[INFO] [stderr]    |
[INFO] [stderr] 20 |     let config = match GameConfig::load() {
[INFO] [stderr]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `ai_career_rpg` (bin "ai_career_rpg" test) generated 45 warnings (3 duplicates) (run `cargo fix --bin "ai_career_rpg" -p ai_career_rpg --tests` to apply 9 suggestions)
[INFO] [stderr] warning: `ai_career_rpg` (bin "test_llm_integration" test) generated 2 warnings (run `cargo fix --bin "test_llm_integration" -p ai_career_rpg --tests` to apply 2 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.42s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/ai_career_rpg-47eff153c7c725ce)
[INFO] [stdout] 
[INFO] [stdout] running 53 tests
[INFO] [stdout] test engine::cache::tests::test_cache_key_generation ... ok
[INFO] [stdout] test engine::cache::tests::test_cache_lru_eviction ... ok
[INFO] [stdout] test engine::cache::tests::test_cache_set_and_get ... ok
[INFO] [stdout] test engine::context::tests::test_empty_context ... ok
[INFO] [stdout] test engine::config::tests::test_load_config ... ok
[INFO] [stdout] test engine::config::tests::test_get_npc_engine_default ... ok
[INFO] [stdout] test engine::context::tests::test_to_prompt_section ... ok
[INFO] [stdout] test engine::npc::tests::test_conversation_history_limit ... ok
[INFO] [stdout] test engine::traits::tests::test_engine_type_display ... ok
[INFO] [stdout] test jobs::tests::test_company_tier_as_str ... ok
[INFO] [stdout] test engine::traits::tests::test_engine_type_parse ... ok
[INFO] [stdout] test jobs::tests::test_job_display_salary ... ok
[INFO] [stdout] test llm::mock::tests::test_mock_can_update_response ... ok
[INFO] [stdout] test jobs::tests::test_company_tier_ordering ... ok
[INFO] [stdout] test llm::tests::test_message_constructors ... ok
[INFO] [stdout] test llm::tests::test_mock_provider ... ok
[INFO] [stdout] test llm::mock::tests::test_mock_tracks_requests ... ok
[INFO] [stdout] test engine::npc::tests::test_rule_dialog ... ok
[INFO] [stdout] test llm::mock::tests::test_mock_returns_fixed_response ... ok
[INFO] [stdout] test llm::tests::test_provider_enum ... ok
[INFO] [stdout] test player::tests::test_advance_day ... ok
[INFO] [stdout] test player::tests::test_employed_salary ... ok
[INFO] [stdout] test jobs::tests::test_job_match_fresh_player ... ok
[INFO] [stdout] test player::tests::test_skill_level_up ... ok
[INFO] [stdout] test player::tests::test_rest ... ok
[INFO] [stdout] test player::tests::test_skill_partial_xp ... ok
[INFO] [stdout] test engine::cache::tests::test_cache_miss ... ok
[INFO] [stdout] test jobs::tests::test_company_tier_salary_multiplier ... ok
[INFO] [stdout] test skills::tests::test_get_all_skills ... ok
[INFO] [stdout] test player::tests::test_study_unknown_skill ... ok
[INFO] [stdout] test skills::tests::test_proficiency_as_str ... ok
[INFO] [stdout] test skills::tests::test_proficiency_next ... ok
[INFO] [stdout] test skills::tests::test_proficiency_ordering ... ok
[INFO] [stdout] test skills::tests::test_skill_creation ... ok
[INFO] [stdout] test skills::tests::test_skill_categories ... ok
[INFO] [stdout] test testing::harness::tests::test_advance_day_in_harness ... ok
[INFO] [stdout] test player::tests::test_player_creation ... ok
[INFO] [stdout] test testing::harness::tests::test_run_all_frames ... ok
[INFO] [stdout] test testing::harness::tests::test_harness_creation ... ok
[INFO] [stdout] test testing::harness::tests::test_rest_in_harness ... ok
[INFO] [stdout] test player::tests::test_study_reduces_energy ... ok
[INFO] [stdout] test player::tests::test_study_not_enough_energy ... ok
[INFO] [stdout] test testing::harness::tests::test_skill_leveling_in_harness ... ok
[INFO] [stdout] test testing::harness::tests::test_scripted_input ... ok
[INFO] [stdout] test testing::tests::test_input_snapshot_key_down ... ok
[INFO] [stdout] test testing::tests::test_input_snapshot_mouse ... ok
[INFO] [stdout] test testing::tests::test_input_snapshot_key_pressed ... ok
[INFO] [stdout] test testing::harness::tests::test_study_skill_in_harness ... ok
[INFO] [stdout] test testing::tests::test_input_snapshot_clear_pressed ... ok
[INFO] [stdout] test testing::harness::tests::test_employment_in_harness ... ok
[INFO] [stdout] test testing::tests::test_mock_canvas_records_ops ... ok
[INFO] [stdout] test testing::tests::test_mock_canvas_find_text ... ok
[INFO] [stdout] test testing::tests::test_mock_canvas_clear ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 53 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.06s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/ai_career_rpg-f94af95a3e1f86ae)
[INFO] [stdout] 
[INFO] [stdout] running 38 tests
[INFO] [stdout] test engine::cache::tests::test_cache_lru_eviction ... ok
[INFO] [stdout] test engine::config::tests::test_load_config ... ok
[INFO] [stdout] test engine::cache::tests::test_cache_key_generation ... ok
[INFO] [stdout] test engine::context::tests::test_to_prompt_section ... ok
[INFO] [stdout] test engine::npc::tests::test_conversation_history_limit ... ok
[INFO] [stdout] test engine::cache::tests::test_cache_set_and_get ... ok
[INFO] [stdout] test engine::context::tests::test_empty_context ... ok
[INFO] [stdout] test engine::cache::tests::test_cache_miss ... ok
[INFO] [stdout] test engine::config::tests::test_get_npc_engine_default ... ok
[INFO] [stdout] test engine::traits::tests::test_engine_type_parse ... ok
[INFO] [stdout] test jobs::tests::test_company_tier_as_str ... ok
[INFO] [stdout] test jobs::tests::test_company_tier_ordering ... ok
[INFO] [stdout] test jobs::tests::test_company_tier_salary_multiplier ... ok
[INFO] [stdout] test llm::mock::tests::test_mock_tracks_requests ... ok
[INFO] [stdout] test llm::mock::tests::test_mock_can_update_response ... ok
[INFO] [stdout] test llm::tests::test_message_constructors ... ok
[INFO] [stdout] test llm::mock::tests::test_mock_returns_fixed_response ... ok
[INFO] [stdout] test engine::traits::tests::test_engine_type_display ... ok
[INFO] [stdout] test llm::tests::test_mock_provider ... ok
[INFO] [stdout] test llm::tests::test_provider_enum ... ok
[INFO] [stdout] test engine::npc::tests::test_rule_dialog ... ok
[INFO] [stdout] test jobs::tests::test_job_display_salary ... ok
[INFO] [stdout] test player::tests::test_employed_salary ... ok
[INFO] [stdout] test player::tests::test_player_creation ... ok
[INFO] [stdout] test player::tests::test_rest ... ok
[INFO] [stdout] test jobs::tests::test_job_match_fresh_player ... ok
[INFO] [stdout] test player::tests::test_advance_day ... ok
[INFO] [stdout] test player::tests::test_skill_partial_xp ... ok
[INFO] [stdout] test skills::tests::test_get_all_skills ... ok
[INFO] [stdout] test skills::tests::test_proficiency_as_str ... ok
[INFO] [stdout] test skills::tests::test_proficiency_next ... ok
[INFO] [stdout] test skills::tests::test_proficiency_ordering ... ok
[INFO] [stdout] test player::tests::test_skill_level_up ... ok
[INFO] [stdout] test player::tests::test_study_reduces_energy ... ok
[INFO] [stdout] test player::tests::test_study_not_enough_energy ... ok
[INFO] [stdout] test player::tests::test_study_unknown_skill ... ok
[INFO] [stdout] test skills::tests::test_skill_creation ... ok
[INFO] [stderr]      Running unittests src/bin/test_llm_integration.rs (/opt/rustwide/target/debug/deps/test_llm_integration-9b3c65ef99ba639a)
[INFO] [stdout] test skills::tests::test_skill_categories ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 38 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.06s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests ai_career_rpg
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test src/llm/anthropic.rs - llm::anthropic (line 12) ... FAILED
[INFO] [stdout] test src/engine/traits.rs - engine::traits::ActivityEngine (line 60) ... FAILED
[INFO] [stdout] test src/llm/mock.rs - llm::mock (line 7) ... FAILED
[INFO] [stdout] test src/llm/mod.rs - llm (line 28) ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/llm/anthropic.rs - llm::anthropic (line 12) stdout ----
[INFO] [stdout] error[E0433]: failed to resolve: unresolved import
[INFO] [stdout]   --> src/llm/anthropic.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | use crate::llm::anthropic::AnthropicProvider;
[INFO] [stdout]    |            ^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            unresolved import
[INFO] [stdout]    |            help: a similar path exists: `ai_career_rpg::llm`
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::llm`
[INFO] [stdout]   --> src/llm/anthropic.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::llm::{LlmProvider, LlmMessage};
[INFO] [stdout]    |            ^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            unresolved import
[INFO] [stdout]    |            help: a similar path exists: `ai_career_rpg::llm`
[INFO] [stdout] 
[INFO] [stdout] error[E0728]: `await` is only allowed inside `async` functions and blocks
[INFO] [stdout]   --> src/llm/anthropic.rs:17:86
[INFO] [stdout]    |
[INFO] [stdout] 12 | fn main() { #[allow(non_snake_case)] fn _doctest_main_src_llm_anthropic_rs_12_0() {
[INFO] [stdout]    |                                      -------------------------------------------- this is not `async`
[INFO] [stdout] ...
[INFO] [stdout] 17 | let response = provider.complete("You are helpful", vec![LlmMessage::user("Hello")]).await?;
[INFO] [stdout]    |                                                                                      ^^^^^ only allowed inside `async` functions and blocks
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0432, E0433, E0728.
[INFO] [stdout] For more information about an error, try `rustc --explain E0432`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/engine/traits.rs - engine::traits::ActivityEngine (line 60) stdout ----
[INFO] [stdout] error[E0425]: cannot find type `EngineType` in this scope
[INFO] [stdout]   --> src/engine/traits.rs:62:18
[INFO] [stdout]    |
[INFO] [stdout] 62 |     engine_type: EngineType,
[INFO] [stdout]    |                  ^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this enum
[INFO] [stdout]    |
[INFO] [stdout] 60 + use ai_career_rpg::engine::EngineType;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find type `Arc` in this scope
[INFO] [stdout]   --> src/engine/traits.rs:63:15
[INFO] [stdout]    |
[INFO] [stdout] 63 |     provider: Arc<dyn LlmProvider>,
[INFO] [stdout]    |               ^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 60 + use std::sync::Arc;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0405]: cannot find trait `LlmProvider` in this scope
[INFO] [stdout]   --> src/engine/traits.rs:63:23
[INFO] [stdout]    |
[INFO] [stdout] 63 |     provider: Arc<dyn LlmProvider>,
[INFO] [stdout]    |                       ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this trait
[INFO] [stdout]    |
[INFO] [stdout] 60 + use ai_career_rpg::llm::LlmProvider;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0405]: cannot find trait `ActivityEngine` in this scope
[INFO] [stdout]   --> src/engine/traits.rs:66:6
[INFO] [stdout]    |
[INFO] [stdout] 66 | impl ActivityEngine for MyActivity {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this trait
[INFO] [stdout]    |
[INFO] [stdout] 60 + use ai_career_rpg::engine::ActivityEngine;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find type `GameContext` in this scope
[INFO] [stdout]   --> src/engine/traits.rs:70:59
[INFO] [stdout]    |
[INFO] [stdout] 70 |     async fn execute(&self, input: Self::Input, context: &GameContext) -> Result<Self::Output> {
[INFO] [stdout]    |                                                           ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 60 + use ai_career_rpg::engine::GameContext;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `EngineType`
[INFO] [stdout]   --> src/engine/traits.rs:72:13
[INFO] [stdout]    |
[INFO] [stdout] 72 |             EngineType::Rule => self.rule_logic(&input),
[INFO] [stdout]    |             ^^^^^^^^^^ use of undeclared type `EngineType`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this enum
[INFO] [stdout]    |
[INFO] [stdout] 60 + use ai_career_rpg::engine::EngineType;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `EngineType`
[INFO] [stdout]   --> src/engine/traits.rs:73:13
[INFO] [stdout]    |
[INFO] [stdout] 73 |             EngineType::Llm => self.llm_logic(&input, context).await,
[INFO] [stdout]    |             ^^^^^^^^^^ use of undeclared type `EngineType`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this enum
[INFO] [stdout]    |
[INFO] [stdout] 60 + use ai_career_rpg::engine::EngineType;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `EngineType`
[INFO] [stdout]   --> src/engine/traits.rs:74:13
[INFO] [stdout]    |
[INFO] [stdout] 74 |             EngineType::Hybrid => {
[INFO] [stdout]    |             ^^^^^^^^^^ use of undeclared type `EngineType`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this enum
[INFO] [stdout]    |
[INFO] [stdout] 60 + use ai_career_rpg::engine::EngineType;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find type `EngineType` in this scope
[INFO] [stdout]   --> src/engine/traits.rs:81:30
[INFO] [stdout]    |
[INFO] [stdout] 81 |     fn engine_type(&self) -> EngineType {
[INFO] [stdout]    |                              ^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this enum
[INFO] [stdout]    |
[INFO] [stdout] 60 + use ai_career_rpg::engine::EngineType;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 9 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0405, E0425, E0433.
[INFO] [stdout] For more information about an error, try `rustc --explain E0405`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/llm/mock.rs - llm::mock (line 7) stdout ----
[INFO] [stdout] error[E0433]: failed to resolve: unresolved import
[INFO] [stdout]  --> src/llm/mock.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::llm::mock::MockProvider;
[INFO] [stdout]   |            ^^^
[INFO] [stdout]   |            |
[INFO] [stdout]   |            unresolved import
[INFO] [stdout]   |            help: a similar path exists: `ai_career_rpg::llm`
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::llm`
[INFO] [stdout]  --> src/llm/mock.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::llm::{LlmProvider, LlmMessage};
[INFO] [stdout]   |            ^^^
[INFO] [stdout]   |            |
[INFO] [stdout]   |            unresolved import
[INFO] [stdout]   |            help: a similar path exists: `ai_career_rpg::llm`
[INFO] [stdout] 
[INFO] [stdout] error[E0728]: `await` is only allowed inside `async` functions and blocks
[INFO] [stdout]   --> src/llm/mock.rs:12:73
[INFO] [stdout]    |
[INFO] [stdout]  7 | fn main() { #[allow(non_snake_case)] fn _doctest_main_src_llm_mock_rs_7_0() {
[INFO] [stdout]    |                                      -------------------------------------- this is not `async`
[INFO] [stdout] ...
[INFO] [stdout] 12 | let response = mock.complete("system", vec![LlmMessage::user("Hello")]).await?;
[INFO] [stdout]    |                                                                         ^^^^^ only allowed inside `async` functions and blocks
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0432, E0433, E0728.
[INFO] [stdout] For more information about an error, try `rustc --explain E0432`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/llm/mod.rs - llm (line 28) stdout ----
[INFO] [stdout] error[E0432]: unresolved import `crate::llm`
[INFO] [stdout]   --> src/llm/mod.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 29 | use crate::llm::{LlmProvider, LlmMessage, create_provider, LlmConfig};
[INFO] [stdout]    |            ^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            unresolved import
[INFO] [stdout]    |            help: a similar path exists: `ai_career_rpg::llm`
[INFO] [stdout] 
[INFO] [stdout] error[E0728]: `await` is only allowed inside `async` functions and blocks
[INFO] [stdout]   --> src/llm/mod.rs:39:3
[INFO] [stdout]    |
[INFO] [stdout] 28 | fn main() { #[allow(non_snake_case)] fn _doctest_main_src_llm_mod_rs_28_0() {
[INFO] [stdout]    |                                      -------------------------------------- this is not `async`
[INFO] [stdout] ...
[INFO] [stdout] 39 | ).await?;
[INFO] [stdout]    |   ^^^^^ only allowed inside `async` functions and blocks
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 2 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0432, E0728.
[INFO] [stdout] For more information about an error, try `rustc --explain E0432`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/engine/traits.rs - engine::traits::ActivityEngine (line 60)
[INFO] [stdout]     src/llm/anthropic.rs - llm::anthropic (line 12)
[INFO] [stdout]     src/llm/mock.rs - llm::mock (line 7)
[INFO] [stdout]     src/llm/mod.rs - llm (line 28)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 4 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.41s
[INFO] [stdout] 
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] running `Command { std: "docker" "inspect" "fbe848f4840251a26ccead62f193b6dbeb0beb7454cfc764c7d7c15cbe66a21d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fbe848f4840251a26ccead62f193b6dbeb0beb7454cfc764c7d7c15cbe66a21d", kill_on_drop: false }`
[INFO] [stdout] fbe848f4840251a26ccead62f193b6dbeb0beb7454cfc764c7d7c15cbe66a21d
