[INFO] cloning repository https://github.com/Myrmecology/RAM-Eating-Pet-Simulator
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Myrmecology/RAM-Eating-Pet-Simulator" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMyrmecology%2FRAM-Eating-Pet-Simulator", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMyrmecology%2FRAM-Eating-Pet-Simulator'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 6de4e734a607b26423d07aca9205016c3f905f01
[INFO] building Myrmecology/RAM-Eating-Pet-Simulator against try#d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6 for pr-146237-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMyrmecology%2FRAM-Eating-Pet-Simulator" "/workspace/builds/worker-4-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Myrmecology/RAM-Eating-Pet-Simulator
[INFO] finished tweaking git repo https://github.com/Myrmecology/RAM-Eating-Pet-Simulator
[INFO] tweaked toml for git repo https://github.com/Myrmecology/RAM-Eating-Pet-Simulator written to /workspace/builds/worker-4-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Myrmecology/RAM-Eating-Pet-Simulator on toolchain d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Myrmecology/RAM-Eating-Pet-Simulator 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" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 54a193a11fdcbe914d2da82fc670781ecd2df451c1c9527ccfa859d844ce4cd3
[INFO] running `Command { std: "docker" "start" "-a" "54a193a11fdcbe914d2da82fc670781ecd2df451c1c9527ccfa859d844ce4cd3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "54a193a11fdcbe914d2da82fc670781ecd2df451c1c9527ccfa859d844ce4cd3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "54a193a11fdcbe914d2da82fc670781ecd2df451c1c9527ccfa859d844ce4cd3", kill_on_drop: false }`
[INFO] [stdout] 54a193a11fdcbe914d2da82fc670781ecd2df451c1c9527ccfa859d844ce4cd3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5daca26cd02a70f1604b205d6ee4bf55538f241afa66db3a0a686e9c59904bdf
[INFO] running `Command { std: "docker" "start" "-a" "5daca26cd02a70f1604b205d6ee4bf55538f241afa66db3a0a686e9c59904bdf", kill_on_drop: false }`
[INFO] [stderr]    Compiling memchr v2.7.5
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling indexmap v2.11.0
[INFO] [stderr]    Compiling mio v0.8.11
[INFO] [stderr]    Compiling serde_json v1.0.143
[INFO] [stderr]    Compiling toml_write v0.1.2
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling anyhow v1.0.99
[INFO] [stderr]    Compiling anstream v0.6.20
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling jiff v0.2.15
[INFO] [stderr]    Compiling bitflags v2.9.3
[INFO] [stderr]    Compiling unicode-width v0.1.14
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling parking_lot v0.12.4
[INFO] [stderr]    Compiling signal-hook-mio v0.2.4
[INFO] [stderr]    Compiling rayon v1.11.0
[INFO] [stderr]    Compiling crossterm v0.27.0
[INFO] [stderr]    Compiling chrono v0.4.41
[INFO] [stderr]    Compiling regex-automata v0.4.10
[INFO] [stderr]    Compiling sysinfo v0.30.13
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling regex v1.11.2
[INFO] [stderr]    Compiling env_filter v0.1.3
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling ram_eating_pet_simulator v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `ClearType`, `cursor`, `execute`, and `self`
[INFO] [stdout]  --> src/game.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 |     cursor,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 8 |     execute,
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 9 |     terminal::{self, ClearType},
[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: `center_text`
[INFO] [stdout]   --> src/graphics/renderer.rs:12:72
[INFO] [stdout]    |
[INFO] [stdout] 12 | use super::{ROUNDED_BORDER, create_meter, create_box, format_duration, center_text};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `use_colors`, `last_render`, and `frame_count` are never read
[INFO] [stdout]   --> src/graphics/renderer.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Renderer {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 16 |     use_colors: bool,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 17 |     last_render: Instant,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 18 |     frame_count: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `birth_time` is never read
[INFO] [stdout]   --> src/pet/mod.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct Pet {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 42 |     birth_time: Option<Instant>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pet` 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: unused imports: `ClearType`, `cursor`, `execute`, and `self`
[INFO] [stdout]  --> src/game.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 |     cursor,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 8 |     execute,
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 9 |     terminal::{self, ClearType},
[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: `center_text`
[INFO] [stdout]   --> src/graphics/renderer.rs:12:72
[INFO] [stdout]    |
[INFO] [stdout] 12 | use super::{ROUNDED_BORDER, create_meter, create_box, format_duration, center_text};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `use_colors`, `last_render`, and `frame_count` are never read
[INFO] [stdout]   --> src/graphics/renderer.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Renderer {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 16 |     use_colors: bool,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 17 |     last_render: Instant,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 18 |     frame_count: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `description` is never used
[INFO] [stdout]    --> src/pet/state.rs:228:12
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl PetState {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn description(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/graphics/renderer.rs:34:12
[INFO] [stdout]     |
[INFO] [stdout]  22 | impl Renderer {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  34 |     pub fn full_clear(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 258 |     pub fn draw_header(&self, pet: &Pet) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 262 |     pub fn draw_pet(&self, pet: &Pet) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 266 |     pub fn draw_stats(&mut self, pet: &Pet, monitor: &SystemMonitor, total_eaten: usize, play_time: Duration) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 270 |     pub fn draw_messages(&self, messages: &[(String, Instant, ColoredString)]) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 274 |     pub fn draw_controls(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 278 |     pub fn draw_help(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `birth_time` is never read
[INFO] [stdout]   --> src/pet/mod.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct Pet {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 42 |     birth_time: Option<Instant>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pet` 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 items `from_file`, `save_to_file`, and `with_difficulty` are never used
[INFO] [stdout]    --> src/config.rs:116:12
[INFO] [stdout]     |
[INFO] [stdout] 114 | impl Config {
[INFO] [stdout]     | ----------- associated items in this implementation
[INFO] [stdout] 115 |     /// Load configuration from file
[INFO] [stdout] 116 |     pub fn from_file(path: &str) -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub fn save_to_file(&self, path: &str) -> anyhow::Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 130 |     pub fn with_difficulty(mut self, difficulty: Difficulty) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_personality` is never used
[INFO] [stdout]    --> src/pet/mod.rs:175:12
[INFO] [stdout]     |
[INFO] [stdout]  45 | impl Pet {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 175 |     pub fn get_personality(&self) -> &Personality { &self.personality }
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SystemUtils` is never constructed
[INFO] [stdout]   --> src/system/mod.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct SystemUtils;
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `boost`, `slow`, `reset`, and `get_rate` are never used
[INFO] [stdout]   --> src/pet/metabolism.rs:68:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl Metabolism {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 68 |     pub fn boost(&mut self, multiplier: f32) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     pub fn slow(&mut self, divisor: f32) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 78 |     pub fn reset(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 84 |     pub fn get_rate(&self, size_mb: usize) -> f32 {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_random_comment` is never used
[INFO] [stdout]    --> src/pet/personality.rs:195:12
[INFO] [stdout]     |
[INFO] [stdout]  60 | impl Personality {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 195 |     pub fn get_random_comment(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `check_privileges`, `get_pid`, `get_process_name`, `check_ram_safety`, `format_bytes`, and `get_uptime` are never used
[INFO] [stdout]   --> src/system/mod.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl SystemUtils {
[INFO] [stdout]    | ---------------- associated functions in this implementation
[INFO] [stdout] 13 |     /// Check if we're running with sufficient privileges
[INFO] [stdout] 14 |     pub fn check_privileges() -> Result<bool> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn get_pid() -> u32 {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33 |     pub fn get_process_name() -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn check_ram_safety(required_mb: usize, min_free_mb: usize) -> Result<bool> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn format_bytes(bytes: u64) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn get_uptime() -> Result<std::time::Duration> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SystemHealth` is never constructed
[INFO] [stdout]   --> src/system/mod.rs:85:12
[INFO] [stdout]    |
[INFO] [stdout] 85 | pub struct SystemHealth {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `check` and `get_warning` are never used
[INFO] [stdout]    --> src/system/mod.rs:95:12
[INFO] [stdout]     |
[INFO] [stdout]  93 | impl SystemHealth {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout]  94 |     /// Check current system health
[INFO] [stdout]  95 |     pub fn check() -> Result<Self> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn get_warning(&self) -> Option<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `release`, `get_allocated_mb`, `touch_memory`, and `digest` are never used
[INFO] [stdout]    --> src/system/memory.rs:74:12
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl MemoryManager {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  74 |     pub fn release(&mut self, amount_mb: usize) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn get_allocated_mb(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 100 |     pub fn touch_memory(&mut self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 116 |     pub fn digest(&mut self, amount_mb: usize) -> Result<usize> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MemoryStats` is never constructed
[INFO] [stdout]    --> src/system/memory.rs:135:12
[INFO] [stdout]     |
[INFO] [stdout] 135 | pub struct MemoryStats {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `current` and `can_allocate` are never used
[INFO] [stdout]    --> src/system/memory.rs:144:12
[INFO] [stdout]     |
[INFO] [stdout] 142 | impl MemoryStats {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 143 |     /// Get current memory statistics
[INFO] [stdout] 144 |     pub fn current(manager: &MemoryManager) -> Result<Self> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn can_allocate(&self, amount_mb: usize, min_free_mb: usize) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SafeAllocator` is never constructed
[INFO] [stdout]    --> src/system/memory.rs:162:12
[INFO] [stdout]     |
[INFO] [stdout] 162 | pub struct SafeAllocator {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `allocate_safe`, and `manager` are never used
[INFO] [stdout]    --> src/system/memory.rs:170:12
[INFO] [stdout]     |
[INFO] [stdout] 168 | impl SafeAllocator {
[INFO] [stdout]     | ------------------ associated items in this implementation
[INFO] [stdout] 169 |     /// Create a new safe allocator
[INFO] [stdout] 170 |     pub fn new(min_free_ram_mb: usize, max_allocation_mb: usize) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn allocate_safe(&mut self, amount_mb: usize) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub fn manager(&mut self) -> &mut MemoryManager {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_ram_usage_percent`, `get_process_ram_mb`, `get_system_info`, `is_memory_pressure`, `get_top_processes`, and `get_ram_delta` are never used
[INFO] [stdout]    --> src/system/monitor.rs:51:12
[INFO] [stdout]     |
[INFO] [stdout]  13 | impl SystemMonitor {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  51 |     pub fn get_ram_usage_percent(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  64 |     pub fn get_process_ram_mb(&self) -> Result<usize> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  79 |     pub fn get_system_info(&self) -> SystemInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn is_memory_pressure(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 100 |     pub fn get_top_processes(&self, count: usize) -> Vec<ProcessInfo> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn get_ram_delta(&self, previous_free: usize) -> i32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SystemInfo` is never constructed
[INFO] [stdout]    --> src/system/monitor.rs:125:12
[INFO] [stdout]     |
[INFO] [stdout] 125 | pub struct SystemInfo {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `summary` is never used
[INFO] [stdout]    --> src/system/monitor.rs:138:12
[INFO] [stdout]     |
[INFO] [stdout] 136 | impl SystemInfo {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] 137 |     /// Get a formatted summary
[INFO] [stdout] 138 |     pub fn summary(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ProcessInfo` is never constructed
[INFO] [stdout]    --> src/system/monitor.rs:152:12
[INFO] [stdout]     |
[INFO] [stdout] 152 | pub struct ProcessInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RamTracker` is never constructed
[INFO] [stdout]    --> src/system/monitor.rs:159:12
[INFO] [stdout]     |
[INFO] [stdout] 159 | pub struct RamTracker {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `record`, `get_average`, `get_trend`, and `get_peak` are never used
[INFO] [stdout]    --> src/system/monitor.rs:166:12
[INFO] [stdout]     |
[INFO] [stdout] 164 | impl RamTracker {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 165 |     /// Create a new RAM tracker
[INFO] [stdout] 166 |     pub fn new(max_history: usize) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 174 |     pub fn record(&mut self, monitor: &SystemMonitor) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 186 |     pub fn get_average(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 196 |     pub fn get_trend(&self) -> i32 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |     pub fn get_peak(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DOUBLE_BORDER` is never used
[INFO] [stdout]   --> src/graphics/mod.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub const DOUBLE_BORDER: BorderStyle = BorderStyle {
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `center_text` is never used
[INFO] [stdout]   --> src/graphics/mod.rs:68:8
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub fn center_text(text: &str, width: usize) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_sparkline` is never used
[INFO] [stdout]    --> src/graphics/mod.rs:131:8
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub fn create_sparkline(values: &[f32], width: usize) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AnimationFrame` is never constructed
[INFO] [stdout]  --> src/graphics/animations.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct AnimationFrame {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Animation` is never constructed
[INFO] [stdout]   --> src/graphics/animations.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct Animation {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `update`, and `reset` are never used
[INFO] [stdout]   --> src/graphics/animations.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl Animation {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 24 |     /// Create a new animation
[INFO] [stdout] 25 |     pub fn new(frames: Vec<AnimationFrame>, looping: bool) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn update(&mut self) -> Option<&Vec<String>> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn reset(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_eating_animation` is never used
[INFO] [stdout]   --> src/graphics/animations.rs:68:8
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub fn create_eating_animation() -> Animation {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_growth_animation` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:112:8
[INFO] [stdout]     |
[INFO] [stdout] 112 | pub fn create_growth_animation() -> Animation {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_happy_dance_animation` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:154:8
[INFO] [stdout]     |
[INFO] [stdout] 154 | pub fn create_happy_dance_animation() -> Animation {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_starving_animation` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:202:8
[INFO] [stdout]     |
[INFO] [stdout] 202 | pub fn create_starving_animation() -> Animation {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_digesting_animation` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:228:8
[INFO] [stdout]     |
[INFO] [stdout] 228 | pub fn create_digesting_animation() -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_sparkle_effect` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:236:8
[INFO] [stdout]     |
[INFO] [stdout] 236 | pub fn create_sparkle_effect() -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_death_animation` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:245:8
[INFO] [stdout]     |
[INFO] [stdout] 245 | pub fn create_death_animation() -> Animation {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_feeding_particles` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:280:8
[INFO] [stdout]     |
[INFO] [stdout] 280 | pub fn create_feeding_particles(amount: usize) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ColorTheme` is never constructed
[INFO] [stdout]  --> src/graphics/colors.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct ColorTheme {
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `neon_theme` is never used
[INFO] [stdout]   --> src/graphics/colors.rs:36:8
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub fn neon_theme() -> ColorTheme {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `retro_theme` is never used
[INFO] [stdout]   --> src/graphics/colors.rs:50:8
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub fn retro_theme() -> ColorTheme {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gradient_color` is never used
[INFO] [stdout]   --> src/graphics/colors.rs:64:8
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub fn gradient_color(percentage: f32) -> Color {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `ram_usage_color` is never used
[INFO] [stdout]   --> src/graphics/colors.rs:75:8
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub fn ram_usage_color(percentage: f32) -> Color {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mood_color` is never used
[INFO] [stdout]   --> src/graphics/colors.rs:85:8
[INFO] [stdout]    |
[INFO] [stdout] 85 | pub fn mood_color(mood: &str) -> Color {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `rainbow_colors` is never used
[INFO] [stdout]    --> src/graphics/colors.rs:100:8
[INFO] [stdout]     |
[INFO] [stdout] 100 | pub fn rainbow_colors() -> Vec<Color> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_bright_color` is never used
[INFO] [stdout]    --> src/graphics/colors.rs:113:8
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub fn random_bright_color() -> Color {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pulse_color` is never used
[INFO] [stdout]    --> src/graphics/colors.rs:130:8
[INFO] [stdout]     |
[INFO] [stdout] 130 | pub fn pulse_color(base_color: Color, time: f32) -> Color {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `stat_to_emoji` is never used
[INFO] [stdout]    --> src/graphics/colors.rs:146:8
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub fn stat_to_emoji(value: f32, max: f32) -> &'static str {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `MetabolismState` is never used
[INFO] [stdout]   --> src/pet/metabolism.rs:91:10
[INFO] [stdout]    |
[INFO] [stdout] 91 | pub enum MetabolismState {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_modifier` is never used
[INFO] [stdout]    --> src/pet/metabolism.rs:100:12
[INFO] [stdout]     |
[INFO] [stdout]  98 | impl MetabolismState {
[INFO] [stdout]     | -------------------- method in this implementation
[INFO] [stdout]  99 |     /// Get modifier for this state
[INFO] [stdout] 100 |     pub fn get_modifier(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SNACK` is never used
[INFO] [stdout]    --> src/config.rs:156:15
[INFO] [stdout]     |
[INFO] [stdout] 156 |     pub const SNACK: usize = 10;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEAL` is never used
[INFO] [stdout]    --> src/config.rs:157:15
[INFO] [stdout]     |
[INFO] [stdout] 157 |     pub const MEAL: usize = 50;
[INFO] [stdout]     |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FEAST` is never used
[INFO] [stdout]    --> src/config.rs:158:15
[INFO] [stdout]     |
[INFO] [stdout] 158 |     pub const FEAST: usize = 100;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GORGE` is never used
[INFO] [stdout]    --> src/config.rs:159:15
[INFO] [stdout]     |
[INFO] [stdout] 159 |     pub const GORGE: usize = 500;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 32.08s
[INFO] running `Command { std: "docker" "inspect" "5daca26cd02a70f1604b205d6ee4bf55538f241afa66db3a0a686e9c59904bdf", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5daca26cd02a70f1604b205d6ee4bf55538f241afa66db3a0a686e9c59904bdf", kill_on_drop: false }`
[INFO] [stdout] 5daca26cd02a70f1604b205d6ee4bf55538f241afa66db3a0a686e9c59904bdf
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] af13720c9622b5a7a20955142383fcf181fa82578720818f474dd9771c8e725d
[INFO] running `Command { std: "docker" "start" "-a" "af13720c9622b5a7a20955142383fcf181fa82578720818f474dd9771c8e725d", kill_on_drop: false }`
[INFO] [stderr]    Compiling regex-syntax v0.8.6
[INFO] [stderr]    Compiling predicates-core v1.0.9
[INFO] [stderr]    Compiling float-cmp v0.10.0
[INFO] [stderr]    Compiling termtree v0.5.1
[INFO] [stderr]    Compiling difflib v0.4.0
[INFO] [stderr]    Compiling assert_cmd v2.0.17
[INFO] [stderr]    Compiling normalize-line-endings v0.3.0
[INFO] [stderr]    Compiling doc-comment v0.3.3
[INFO] [stderr]    Compiling wait-timeout v0.2.1
[INFO] [stderr]    Compiling predicates-tree v1.0.12
[INFO] [stderr]    Compiling regex-automata v0.4.10
[INFO] [stderr]    Compiling regex v1.11.2
[INFO] [stderr]    Compiling bstr v1.12.0
[INFO] [stderr]    Compiling env_filter v0.1.3
[INFO] [stderr]    Compiling predicates v3.1.3
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling ram_eating_pet_simulator v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `ClearType`, `cursor`, `execute`, and `self`
[INFO] [stdout]  --> src/game.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 |     cursor,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 8 |     execute,
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 9 |     terminal::{self, ClearType},
[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: `center_text`
[INFO] [stdout]   --> src/graphics/renderer.rs:12:72
[INFO] [stdout]    |
[INFO] [stdout] 12 | use super::{ROUNDED_BORDER, create_meter, create_box, format_duration, center_text};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `use_colors`, `last_render`, and `frame_count` are never read
[INFO] [stdout]   --> src/graphics/renderer.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Renderer {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 16 |     use_colors: bool,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 17 |     last_render: Instant,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 18 |     frame_count: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `birth_time` is never read
[INFO] [stdout]   --> src/pet/mod.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct Pet {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 42 |     birth_time: Option<Instant>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pet` 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: unused imports: `ClearType`, `cursor`, `execute`, and `self`
[INFO] [stdout]  --> src/game.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 |     cursor,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 8 |     execute,
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 9 |     terminal::{self, ClearType},
[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: `center_text`
[INFO] [stdout]   --> src/graphics/renderer.rs:12:72
[INFO] [stdout]    |
[INFO] [stdout] 12 | use super::{ROUNDED_BORDER, create_meter, create_box, format_duration, center_text};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::config::Config`
[INFO] [stdout]    --> src/graphics/renderer.rs:349:9
[INFO] [stdout]     |
[INFO] [stdout] 349 |     use crate::config::Config;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `last_render` and `frame_count` are never read
[INFO] [stdout]   --> src/graphics/renderer.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Renderer {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 16 |     use_colors: bool,
[INFO] [stdout] 17 |     last_render: Instant,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 18 |     frame_count: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `birth_time` is never read
[INFO] [stdout]   --> src/pet/mod.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct Pet {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 42 |     birth_time: Option<Instant>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pet` 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: unused imports: `ClearType`, `cursor`, `execute`, and `self`
[INFO] [stdout]  --> src/game.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 |     cursor,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 8 |     execute,
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 9 |     terminal::{self, ClearType},
[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: `center_text`
[INFO] [stdout]   --> src/graphics/renderer.rs:12:72
[INFO] [stdout]    |
[INFO] [stdout] 12 | use super::{ROUNDED_BORDER, create_meter, create_box, format_duration, center_text};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::config::Config`
[INFO] [stdout]    --> src/graphics/renderer.rs:349:9
[INFO] [stdout]     |
[INFO] [stdout] 349 |     use crate::config::Config;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> src/main.rs:196:9
[INFO] [stdout]     |
[INFO] [stdout] 196 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `check_privileges`, `get_process_name`, `check_ram_safety`, and `get_uptime` are never used
[INFO] [stdout]   --> src/system/mod.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl SystemUtils {
[INFO] [stdout]    | ---------------- associated functions in this implementation
[INFO] [stdout] 13 |     /// Check if we're running with sufficient privileges
[INFO] [stdout] 14 |     pub fn check_privileges() -> Result<bool> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33 |     pub fn get_process_name() -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn check_ram_safety(required_mb: usize, min_free_mb: usize) -> Result<bool> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn get_uptime() -> Result<std::time::Duration> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `birth_time` is never read
[INFO] [stdout]   --> src/pet/mod.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct Pet {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 42 |     birth_time: Option<Instant>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pet` 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 `reset` is never used
[INFO] [stdout]   --> src/graphics/animations.rs:61:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl Animation {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn reset(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_growth_animation` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:112:8
[INFO] [stdout]     |
[INFO] [stdout] 112 | pub fn create_growth_animation() -> Animation {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_happy_dance_animation` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:154:8
[INFO] [stdout]     |
[INFO] [stdout] 154 | pub fn create_happy_dance_animation() -> Animation {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_starving_animation` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:202:8
[INFO] [stdout]     |
[INFO] [stdout] 202 | pub fn create_starving_animation() -> Animation {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_digesting_animation` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:228:8
[INFO] [stdout]     |
[INFO] [stdout] 228 | pub fn create_digesting_animation() -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_sparkle_effect` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:236:8
[INFO] [stdout]     |
[INFO] [stdout] 236 | pub fn create_sparkle_effect() -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_death_animation` is never used
[INFO] [stdout]    --> src/graphics/animations.rs:245:8
[INFO] [stdout]     |
[INFO] [stdout] 245 | pub fn create_death_animation() -> Animation {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ColorTheme` is never constructed
[INFO] [stdout]  --> src/graphics/colors.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct ColorTheme {
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `neon_theme` is never used
[INFO] [stdout]   --> src/graphics/colors.rs:36:8
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub fn neon_theme() -> ColorTheme {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `retro_theme` is never used
[INFO] [stdout]   --> src/graphics/colors.rs:50:8
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub fn retro_theme() -> ColorTheme {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `ram_usage_color` is never used
[INFO] [stdout]   --> src/graphics/colors.rs:75:8
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub fn ram_usage_color(percentage: f32) -> Color {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `rainbow_colors` is never used
[INFO] [stdout]    --> src/graphics/colors.rs:100:8
[INFO] [stdout]     |
[INFO] [stdout] 100 | pub fn rainbow_colors() -> Vec<Color> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_bright_color` is never used
[INFO] [stdout]    --> src/graphics/colors.rs:113:8
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub fn random_bright_color() -> Color {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pulse_color` is never used
[INFO] [stdout]    --> src/graphics/colors.rs:130:8
[INFO] [stdout]     |
[INFO] [stdout] 130 | pub fn pulse_color(base_color: Color, time: f32) -> Color {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `boost`, `slow`, and `reset` are never used
[INFO] [stdout]   --> src/pet/metabolism.rs:68:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl Metabolism {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 68 |     pub fn boost(&mut self, multiplier: f32) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     pub fn slow(&mut self, divisor: f32) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 78 |     pub fn reset(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `MetabolismState` is never used
[INFO] [stdout]   --> src/pet/metabolism.rs:91:10
[INFO] [stdout]    |
[INFO] [stdout] 91 | pub enum MetabolismState {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_modifier` is never used
[INFO] [stdout]    --> src/pet/metabolism.rs:100:12
[INFO] [stdout]     |
[INFO] [stdout]  98 | impl MetabolismState {
[INFO] [stdout]     | -------------------- method in this implementation
[INFO] [stdout]  99 |     /// Get modifier for this state
[INFO] [stdout] 100 |     pub fn get_modifier(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `description` is never used
[INFO] [stdout]    --> src/pet/state.rs:228:12
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl PetState {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn description(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SNACK` is never used
[INFO] [stdout]    --> src/config.rs:156:15
[INFO] [stdout]     |
[INFO] [stdout] 156 |     pub const SNACK: usize = 10;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEAL` is never used
[INFO] [stdout]    --> src/config.rs:157:15
[INFO] [stdout]     |
[INFO] [stdout] 157 |     pub const MEAL: usize = 50;
[INFO] [stdout]     |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FEAST` is never used
[INFO] [stdout]    --> src/config.rs:158:15
[INFO] [stdout]     |
[INFO] [stdout] 158 |     pub const FEAST: usize = 100;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GORGE` is never used
[INFO] [stdout]    --> src/config.rs:159:15
[INFO] [stdout]     |
[INFO] [stdout] 159 |     pub const GORGE: usize = 500;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_ram_usage_percent`, `is_memory_pressure`, `get_top_processes`, and `get_ram_delta` are never used
[INFO] [stdout]    --> src/system/monitor.rs:51:12
[INFO] [stdout]     |
[INFO] [stdout]  13 | impl SystemMonitor {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  51 |     pub fn get_ram_usage_percent(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn is_memory_pressure(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 100 |     pub fn get_top_processes(&self, count: usize) -> Vec<ProcessInfo> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn get_ram_delta(&self, previous_free: usize) -> i32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `used_ram_mb`, `free_ram_mb`, `kernel_version`, `os_version`, and `host_name` are never read
[INFO] [stdout]    --> src/system/monitor.rs:127:9
[INFO] [stdout]     |
[INFO] [stdout] 125 | pub struct SystemInfo {
[INFO] [stdout]     |            ---------- fields in this struct
[INFO] [stdout] 126 |     pub total_ram_mb: usize,
[INFO] [stdout] 127 |     pub used_ram_mb: usize,
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout] 128 |     pub free_ram_mb: usize,
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 131 |     pub kernel_version: String,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^
[INFO] [stdout] 132 |     pub os_version: String,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 133 |     pub host_name: String,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `SystemInfo` 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 `summary` is never used
[INFO] [stdout]    --> src/system/monitor.rs:138:12
[INFO] [stdout]     |
[INFO] [stdout] 136 | impl SystemInfo {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] 137 |     /// Get a formatted summary
[INFO] [stdout] 138 |     pub fn summary(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ProcessInfo` is never constructed
[INFO] [stdout]    --> src/system/monitor.rs:152:12
[INFO] [stdout]     |
[INFO] [stdout] 152 | pub struct ProcessInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_trend` and `get_peak` are never used
[INFO] [stdout]    --> src/system/monitor.rs:196:12
[INFO] [stdout]     |
[INFO] [stdout] 164 | impl RamTracker {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 196 |     pub fn get_trend(&self) -> i32 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |     pub fn get_peak(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `touch_memory` and `digest` are never used
[INFO] [stdout]    --> src/system/memory.rs:100:12
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl MemoryManager {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 100 |     pub fn touch_memory(&mut self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 116 |     pub fn digest(&mut self, amount_mb: usize) -> Result<usize> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MemoryStats` is never constructed
[INFO] [stdout]    --> src/system/memory.rs:135:12
[INFO] [stdout]     |
[INFO] [stdout] 135 | pub struct MemoryStats {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `current` and `can_allocate` are never used
[INFO] [stdout]    --> src/system/memory.rs:144:12
[INFO] [stdout]     |
[INFO] [stdout] 142 | impl MemoryStats {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 143 |     /// Get current memory statistics
[INFO] [stdout] 144 |     pub fn current(manager: &MemoryManager) -> Result<Self> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn can_allocate(&self, amount_mb: usize, min_free_mb: usize) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `manager` is never used
[INFO] [stdout]    --> src/system/memory.rs:204:12
[INFO] [stdout]     |
[INFO] [stdout] 168 | impl SafeAllocator {
[INFO] [stdout]     | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub fn manager(&mut self) -> &mut MemoryManager {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_personality` is never used
[INFO] [stdout]    --> src/pet/mod.rs:175:12
[INFO] [stdout]     |
[INFO] [stdout]  45 | impl Pet {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 175 |     pub fn get_personality(&self) -> &Personality { &self.personality }
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DOUBLE_BORDER` is never used
[INFO] [stdout]   --> src/graphics/mod.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub const DOUBLE_BORDER: BorderStyle = BorderStyle {
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_sparkline` is never used
[INFO] [stdout]    --> src/graphics/mod.rs:131:8
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub fn create_sparkline(values: &[f32], width: usize) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `last_render` and `frame_count` are never read
[INFO] [stdout]   --> src/graphics/renderer.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Renderer {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 16 |     use_colors: bool,
[INFO] [stdout] 17 |     last_render: Instant,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 18 |     frame_count: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/graphics/renderer.rs:34:12
[INFO] [stdout]     |
[INFO] [stdout]  22 | impl Renderer {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  34 |     pub fn full_clear(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 258 |     pub fn draw_header(&self, pet: &Pet) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 262 |     pub fn draw_pet(&self, pet: &Pet) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 266 |     pub fn draw_stats(&mut self, pet: &Pet, monitor: &SystemMonitor, total_eaten: usize, play_time: Duration) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 270 |     pub fn draw_messages(&self, messages: &[(String, Instant, ColoredString)]) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 274 |     pub fn draw_controls(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 278 |     pub fn draw_help(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `ram_usage_percent`, `free_ram_mb`, `total_ram_mb`, `process_ram_mb`, and `is_healthy` are never read
[INFO] [stdout]   --> src/system/mod.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 85 | pub struct SystemHealth {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] 86 |     pub ram_usage_percent: f32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 87 |     pub free_ram_mb: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 88 |     pub total_ram_mb: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 89 |     pub process_ram_mb: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 90 |     pub is_healthy: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SystemHealth` 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_warning` is never used
[INFO] [stdout]    --> src/system/mod.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout]  93 | impl SystemHealth {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn get_warning(&self) -> Option<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_random_comment` is never used
[INFO] [stdout]    --> src/pet/personality.rs:195:12
[INFO] [stdout]     |
[INFO] [stdout]  60 | impl Personality {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 195 |     pub fn get_random_comment(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `from_file` and `save_to_file` are never used
[INFO] [stdout]    --> src/config.rs:116:12
[INFO] [stdout]     |
[INFO] [stdout] 114 | impl Config {
[INFO] [stdout]     | ----------- associated items in this implementation
[INFO] [stdout] 115 |     /// Load configuration from file
[INFO] [stdout] 116 |     pub fn from_file(path: &str) -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub fn save_to_file(&self, path: &str) -> anyhow::Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 12.58s
[INFO] running `Command { std: "docker" "inspect" "af13720c9622b5a7a20955142383fcf181fa82578720818f474dd9771c8e725d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "af13720c9622b5a7a20955142383fcf181fa82578720818f474dd9771c8e725d", kill_on_drop: false }`
[INFO] [stdout] af13720c9622b5a7a20955142383fcf181fa82578720818f474dd9771c8e725d
