[INFO] cloning repository https://github.com/petterssonjonas/Spelman
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/petterssonjonas/Spelman" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpetterssonjonas%2FSpelman", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpetterssonjonas%2FSpelman'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] fdc4235b64e7802da76d63598412069fde722b2c
[INFO] checking petterssonjonas/Spelman against master#57f772f25c5ce2bd870d6f8c3ab318eaee5a3326 for pr-133502-22
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpetterssonjonas%2FSpelman" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/petterssonjonas/Spelman
[INFO] finished tweaking git repo https://github.com/petterssonjonas/Spelman
[INFO] tweaked toml for git repo https://github.com/petterssonjonas/Spelman written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/petterssonjonas/Spelman on toolchain 57f772f25c5ce2bd870d6f8c3ab318eaee5a3326
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/petterssonjonas/Spelman 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" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating git repository `https://github.com/yuri-xyz/chroma`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded utf8-zero v0.8.1
[INFO] [stderr]   Downloaded ureq-proto v0.6.0
[INFO] [stderr]   Downloaded ureq v3.3.0
[INFO] [stderr]   Downloaded rtrb v0.3.3
[INFO] [stderr]   Downloaded lofty_attr v0.11.1
[INFO] [stderr]   Downloaded lofty v0.22.4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 8218beac3348d3d64f2baec019ff9678097cd40721323b12ccc6e52825749f53
[INFO] running `Command { std: "docker" "start" "-a" "8218beac3348d3d64f2baec019ff9678097cd40721323b12ccc6e52825749f53", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "8218beac3348d3d64f2baec019ff9678097cd40721323b12ccc6e52825749f53", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8218beac3348d3d64f2baec019ff9678097cd40721323b12ccc6e52825749f53", kill_on_drop: false }`
[INFO] [stdout] 8218beac3348d3d64f2baec019ff9678097cd40721323b12ccc6e52825749f53
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1c4da1ebe503fa06021be8486b03f321b296c18ee06eacf6b9519fefe3ac730f
[INFO] running `Command { std: "docker" "start" "-a" "1c4da1ebe503fa06021be8486b03f321b296c18ee06eacf6b9519fefe3ac730f", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]     Checking simd-adler32 v0.3.8
[INFO] [stderr]     Checking getrandom v0.2.17
[INFO] [stderr]    Compiling zerocopy v0.8.47
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking errno v0.3.14
[INFO] [stderr]    Compiling naga v22.1.0
[INFO] [stderr]     Checking bit-vec v0.7.0
[INFO] [stderr]    Compiling ash v0.38.0+1.3.281
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]    Compiling khronos-egl v6.0.0
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking bit-set v0.6.0
[INFO] [stderr]     Checking as-slice v0.2.1
[INFO] [stderr]     Checking signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling wgpu-hal v22.0.0
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking gpu-descriptor-types v0.2.0
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking spirv v0.3.0+sdk-1.3.268.0
[INFO] [stderr]     Checking unicode-xid v0.2.6
[INFO] [stderr]    Compiling built v0.8.0
[INFO] [stderr]    Compiling av-scenechange v0.14.1
[INFO] [stderr]     Checking hexf-parse v0.2.1
[INFO] [stderr]     Checking gpu-descriptor v0.3.2
[INFO] [stderr]     Checking signal-hook v0.3.18
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking flate2 v1.1.9
[INFO] [stderr]     Checking aligned v0.4.3
[INFO] [stderr]     Checking nom v8.0.0
[INFO] [stderr]     Checking num-rational v0.4.2
[INFO] [stderr]    Compiling rav1e v0.8.1
[INFO] [stderr]     Checking core2 v0.4.0
[INFO] [stderr]     Checking mio v1.1.1
[INFO] [stderr]    Compiling wgpu-core v22.1.0
[INFO] [stderr]     Checking wgpu-types v22.0.0
[INFO] [stderr]    Compiling pastey v0.1.1
[INFO] [stderr]     Checking renderdoc-sys v1.1.0
[INFO] [stderr]     Checking y4m v0.8.0
[INFO] [stderr]     Checking glow v0.13.1
[INFO] [stderr]     Checking futures-core v0.3.32
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]     Checking ring v0.17.14
[INFO] [stderr]     Checking signal-hook-mio v0.2.5
[INFO] [stderr]     Checking rustix v0.38.44
[INFO] [stderr]     Checking bitstream-io v4.9.0
[INFO] [stderr]     Checking maybe-rayon v0.1.1
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]    Compiling wgpu v22.1.0
[INFO] [stderr]    Compiling simd_helpers v0.1.0
[INFO] [stderr]     Checking winnow v0.7.15
[INFO] [stderr]    Compiling rustls v0.23.37
[INFO] [stderr]     Checking weezl v0.1.12
[INFO] [stderr]     Checking imgref v1.12.0
[INFO] [stderr]     Checking zune-core v0.5.1
[INFO] [stderr]     Checking zune-jpeg v0.5.13
[INFO] [stderr]     Checking loop9 v0.1.5
[INFO] [stderr]     Checking http v1.4.0
[INFO] [stderr]     Checking rustls-webpki v0.103.10
[INFO] [stderr]     Checking inotify v0.9.6
[INFO] [stderr]     Checking crossterm v0.28.1
[INFO] [stderr]     Checking alsa-sys v0.3.1
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]     Checking fdeflate v0.3.7
[INFO] [stderr]     Checking zune-inflate v0.2.54
[INFO] [stderr]     Checking nanorand v0.7.0
[INFO] [stderr]     Checking filetime v0.2.27
[INFO] [stderr]     Checking mio v0.8.11
[INFO] [stderr]     Checking avif-serialize v0.8.8
[INFO] [stderr]     Checking strength_reduce v0.2.4
[INFO] [stderr]     Checking bit_field v0.10.3
[INFO] [stderr]    Compiling chroma v0.1.0 (https://github.com/yuri-xyz/chroma?branch=develop#99daac71)
[INFO] [stderr]     Checking pxfm v0.1.28
[INFO] [stderr]     Checking extended v0.1.0
[INFO] [stderr]     Checking lebe v0.5.3
[INFO] [stderr]     Checking rgb v0.8.53
[INFO] [stderr]     Checking compact_str v0.8.1
[INFO] [stderr]     Checking dirs-sys v0.5.0
[INFO] [stderr]     Checking notify v6.1.1
[INFO] [stderr]     Checking transpose v0.2.3
[INFO] [stderr]     Checking image-webp v0.2.4
[INFO] [stderr]     Checking gif v0.14.1
[INFO] [stderr]     Checking ureq-proto v0.6.0
[INFO] [stderr]     Checking unicode-truncate v1.1.0
[INFO] [stderr]     Checking flume v0.11.1
[INFO] [stderr]     Checking ogg_pager v0.7.1
[INFO] [stderr]     Checking png v0.18.1
[INFO] [stderr]    Compiling bytemuck_derive v1.10.2
[INFO] [stderr]    Compiling zerocopy-derive v0.8.47
[INFO] [stderr]    Compiling profiling-procmacros v1.0.17
[INFO] [stderr]    Compiling equator-macro v0.4.2
[INFO] [stderr]     Checking profiling v1.0.17
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]     Checking bytemuck v1.25.0
[INFO] [stderr]     Checking equator v0.4.2
[INFO] [stderr]     Checking aligned-vec v0.6.4
[INFO] [stderr]     Checking symphonia-core v0.5.5
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]     Checking v_frame v0.3.9
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling arg_enum_proc_macro v0.3.4
[INFO] [stderr]     Checking av1-grain v0.2.5
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]     Checking symphonia-metadata v0.5.5
[INFO] [stderr]    Compiling fax_derive v0.2.0
[INFO] [stderr]     Checking symphonia-utils-xiph v0.5.5
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]     Checking thiserror v2.0.18
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]     Checking fax v0.2.6
[INFO] [stderr]    Compiling clap_derive v4.6.0
[INFO] [stderr]    Compiling instability v0.3.12
[INFO] [stderr]     Checking symphonia-codec-vorbis v0.5.5
[INFO] [stderr]     Checking symphonia-format-ogg v0.5.5
[INFO] [stderr]     Checking symphonia-bundle-flac v0.5.5
[INFO] [stderr]     Checking symphonia-format-isomp4 v0.5.5
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking symphonia-format-mkv v0.5.5
[INFO] [stderr]     Checking clap v4.6.0
[INFO] [stderr]     Checking symphonia-format-riff v0.5.5
[INFO] [stderr]     Checking symphonia-bundle-mp3 v0.5.5
[INFO] [stderr]     Checking symphonia-codec-aac v0.5.5
[INFO] [stderr]     Checking symphonia-codec-pcm v0.5.5
[INFO] [stderr]     Checking symphonia-codec-adpcm v0.5.5
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]     Checking moxcms v0.8.1
[INFO] [stderr]     Checking qoi v0.4.1
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]    Compiling lofty_attr v0.11.1
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]     Checking half v2.7.1
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking exr v1.74.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking tiff v0.11.3
[INFO] [stderr]     Checking alsa v0.9.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking primal-check v0.3.4
[INFO] [stderr]     Checking num-complex v0.4.6
[INFO] [stderr]     Checking utf8-zero v0.8.1
[INFO] [stderr]     Checking pollster v0.3.0
[INFO] [stderr]     Checking ratatui v0.29.0
[INFO] [stderr]     Checking ureq v3.3.0
[INFO] [stderr]     Checking cpal v0.15.3
[INFO] [stderr]     Checking rustfft v6.4.1
[INFO] [stderr]     Checking lofty v0.22.4
[INFO] [stderr]     Checking ravif v0.13.0
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]     Checking tracing-subscriber v0.3.23
[INFO] [stderr]     Checking serde_json v1.0.149
[INFO] [stderr]     Checking symphonia v0.5.5
[INFO] [stderr]     Checking directories v6.0.0
[INFO] [stderr]     Checking rtrb v0.3.3
[INFO] [stderr]     Checking pollster v0.4.0
[INFO] [stderr]     Checking image v0.25.10
[INFO] [stderr]     Checking spelman v0.5.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `compute_art_rows`
[INFO] [stdout]   --> src/app.rs:25:59
[INFO] [stdout]    |
[INFO] [stdout] 25 | use crate::ui::tabs::playing::{PlaybackState, PlayingTab, compute_art_rows, compute_art_rect, compute_effective_art_rows};
[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: `compute_art_rows`
[INFO] [stdout]   --> src/app.rs:25:59
[INFO] [stdout]    |
[INFO] [stdout] 25 | use crate::ui::tabs::playing::{PlaybackState, PlayingTab, compute_art_rows, compute_art_rect, compute_effective_art_rows};
[INFO] [stdout]    |                                                           ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Queue` is never constructed
[INFO] [stdout]    --> src/app.rs:147:5
[INFO] [stdout]     |
[INFO] [stdout] 145 | enum PlaylistSource {
[INFO] [stdout]     |      -------------- variant in this enum
[INFO] [stdout] 146 |     /// From the current play queue.
[INFO] [stdout] 147 |     Queue,
[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 `volume` is never read
[INFO] [stdout]    --> src/audio/pipeline.rs:155:9
[INFO] [stdout]     |
[INFO] [stdout] 154 | pub struct DspChain {
[INFO] [stdout]     |            -------- field in this struct
[INFO] [stdout] 155 |     pub volume: VolumeControl,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `target`, `current`, and `ramp_rate` are never read
[INFO] [stdout]  --> src/audio/volume.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub struct VolumeControl {
[INFO] [stdout]   |            ------------- fields in this struct
[INFO] [stdout] 3 |     /// Target volume (0.0 to 1.0).
[INFO] [stdout] 4 |     target: f32,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 5 |     /// Current volume (smoothly approaches target).
[INFO] [stdout] 6 |     current: f32,
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 7 |     /// Ramp speed per sample (depends on sample rate).
[INFO] [stdout] 8 |     ramp_rate: f32,
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_volume`, `volume`, and `apply` are never used
[INFO] [stdout]   --> src/audio/volume.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl VolumeControl {
[INFO] [stdout]    | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub fn set_volume(&mut self, vol: f32) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     pub fn volume(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn apply(&mut self, samples: &mut [f32]) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `bg`, `error`, and `hover` are never used
[INFO] [stdout]   --> src/config/settings.rs:56:12
[INFO] [stdout]    |
[INFO] [stdout] 52 | impl ThemeColors {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 56 |     pub fn bg(&self) -> Color { parse_color(&self.background) }
[INFO] [stdout]    |            ^^
[INFO] [stdout] 57 |     pub fn highlight(&self) -> Color { parse_color(&self.highlight) }
[INFO] [stdout] 58 |     pub fn error(&self) -> Color { parse_color(&self.error) }
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 59 |     pub fn selection(&self) -> Color { parse_color(&self.selection) }
[INFO] [stdout] 60 |     pub fn hover(&self) -> Color { parse_color(&self.hover) }
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `add_key` is never used
[INFO] [stdout]    --> src/config/settings.rs:398:12
[INFO] [stdout]     |
[INFO] [stdout] 319 | impl KeyBindings {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 398 |     pub fn add_key(&mut self, action: BindableAction, key: String) {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `stop` is never used
[INFO] [stdout]    --> src/coordinator/player.rs:158:12
[INFO] [stdout]     |
[INFO] [stdout]  44 | impl PlayerCoordinator {
[INFO] [stdout]     | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 158 |     pub fn stop(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `found` is never read
[INFO] [stdout]   --> src/library/scanner.rs:17:16
[INFO] [stdout]    |
[INFO] [stdout] 17 |     Progress { found: usize },
[INFO] [stdout]    |     --------   ^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ScanEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `artist` is never read
[INFO] [stdout]   --> src/library/types.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct Album {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] 19 |     pub name: String,
[INFO] [stdout] 20 |     pub artist: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Album` 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 `next` and `remove` are never used
[INFO] [stdout]    --> src/playlist/queue.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout]  19 | impl Queue {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn next(&mut self) -> Option<&PathBuf> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 180 |     pub fn remove(&mut self, index: usize) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_cover` is never used
[INFO] [stdout]  --> src/ui/albumart.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub fn extract_cover(path: &Path) -> Option<Vec<u8>> {
[INFO] [stdout]   |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `selected_playlist` is never used
[INFO] [stdout]    --> src/ui/tabs/home.rs:176:12
[INFO] [stdout]     |
[INFO] [stdout] 120 | impl HomeState {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 176 |     pub fn selected_playlist<'a>(&self, playlists: &'a [Playlist]) -> Option<&'a Playlist> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `selected_album_tracks` and `is_checked` are never used
[INFO] [stdout]    --> src/ui/tabs/library.rs:232:12
[INFO] [stdout]     |
[INFO] [stdout]  81 | impl LibraryState {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 232 |     pub fn selected_album_tracks(&self) -> Vec<std::path::PathBuf> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 335 |     pub fn is_checked(&self, path: &std::path::Path) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `selected`, `viewing`, `track_selected`, `scroll_offset`, and `status` are never read
[INFO] [stdout]   --> src/ui/tabs/playlists.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct PlaylistsState {
[INFO] [stdout]    |            -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 15 |     pub selected: usize,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 16 |     /// If Some, we're viewing tracks inside a playlist.
[INFO] [stdout] 17 |     pub viewing: Option<usize>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 18 |     /// Selected track index when viewing a playlist.
[INFO] [stdout] 19 |     pub track_selected: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 20 |     /// Scroll offset.
[INFO] [stdout] 21 |     pub scroll_offset: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 22 |     /// Status message (e.g. "Playlist deleted").
[INFO] [stdout] 23 |     pub status: Option<String>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PlaylistsState` 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: multiple methods are never used
[INFO] [stdout]   --> src/ui/tabs/playlists.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 26 | impl PlaylistsState {
[INFO] [stdout]    | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub fn move_down(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn move_up(&mut self) {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub fn enter(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub fn back(&mut self) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 75 |     pub fn selected_track_path(&self) -> Option<PathBuf> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 84 |     pub fn selected_playlist_tracks(&self) -> Vec<PathBuf> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 93 |     pub fn delete_selected(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlaylistsTab` is never constructed
[INFO] [stdout]    --> src/ui/tabs/playlists.rs:109:12
[INFO] [stdout]     |
[INFO] [stdout] 109 | pub struct PlaylistsTab<'a> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `result_count` is never used
[INFO] [stdout]    --> src/ui/tabs/search.rs:117:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | impl SearchState {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] 116 |     /// Number of results.
[INFO] [stdout] 117 |     pub fn result_count(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `gap` is never read
[INFO] [stdout]   --> src/ui/widgets/visualizer.rs:92:9
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub struct BarLayout {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 92 |     pub gap: usize,
[INFO] [stdout]    |         ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BarLayout` 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 `bar_center` is never used
[INFO] [stdout]    --> src/ui/widgets/visualizer.rs:126:12
[INFO] [stdout]     |
[INFO] [stdout]  98 | impl BarLayout {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 126 |     pub fn bar_center(&self, i: usize) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `width` and `height` are never read
[INFO] [stdout]   --> src/ui/widgets/chroma.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct ChromaFrame {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 35 |     pub cells: Vec<Vec<(char, crossterm::style::Color)>>,
[INFO] [stdout] 36 |     pub width: u32,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 37 |     pub height: u32,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `gpu_failed` is never read
[INFO] [stdout]   --> src/ui/widgets/chroma.rs:54:9
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct ChromaState {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub gpu_failed: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Audio`, `UnsupportedFormat`, `Device`, and `Metadata` are never constructed
[INFO] [stdout]   --> src/util/error.rs:6:5
[INFO] [stdout]    |
[INFO] [stdout]  4 | pub enum SpelmanError {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout]  5 |     #[error("Audio error: {0}")]
[INFO] [stdout]  6 |     Audio(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 15 |     UnsupportedFormat,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     Device(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     Metadata(String),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SpelmanError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Queue` is never constructed
[INFO] [stdout]    --> src/app.rs:147:5
[INFO] [stdout]     |
[INFO] [stdout] 145 | enum PlaylistSource {
[INFO] [stdout]     |      -------------- variant in this enum
[INFO] [stdout] 146 |     /// From the current play queue.
[INFO] [stdout] 147 |     Queue,
[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 `gains` is never used
[INFO] [stdout]    --> src/audio/eq.rs:254:12
[INFO] [stdout]     |
[INFO] [stdout] 196 | impl Equalizer {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 254 |     pub fn gains(&self) -> &[f32; NUM_EQ_BANDS] {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `volume` is never read
[INFO] [stdout]    --> src/audio/pipeline.rs:155:9
[INFO] [stdout]     |
[INFO] [stdout] 154 | pub struct DspChain {
[INFO] [stdout]     |            -------- field in this struct
[INFO] [stdout] 155 |     pub volume: VolumeControl,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `target`, `current`, and `ramp_rate` are never read
[INFO] [stdout]  --> src/audio/volume.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub struct VolumeControl {
[INFO] [stdout]   |            ------------- fields in this struct
[INFO] [stdout] 3 |     /// Target volume (0.0 to 1.0).
[INFO] [stdout] 4 |     target: f32,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 5 |     /// Current volume (smoothly approaches target).
[INFO] [stdout] 6 |     current: f32,
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 7 |     /// Ramp speed per sample (depends on sample rate).
[INFO] [stdout] 8 |     ramp_rate: f32,
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_volume`, `volume`, and `apply` are never used
[INFO] [stdout]   --> src/audio/volume.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl VolumeControl {
[INFO] [stdout]    | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub fn set_volume(&mut self, vol: f32) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     pub fn volume(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn apply(&mut self, samples: &mut [f32]) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `bg`, `error`, and `hover` are never used
[INFO] [stdout]   --> src/config/settings.rs:56:12
[INFO] [stdout]    |
[INFO] [stdout] 52 | impl ThemeColors {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 56 |     pub fn bg(&self) -> Color { parse_color(&self.background) }
[INFO] [stdout]    |            ^^
[INFO] [stdout] 57 |     pub fn highlight(&self) -> Color { parse_color(&self.highlight) }
[INFO] [stdout] 58 |     pub fn error(&self) -> Color { parse_color(&self.error) }
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 59 |     pub fn selection(&self) -> Color { parse_color(&self.selection) }
[INFO] [stdout] 60 |     pub fn hover(&self) -> Color { parse_color(&self.hover) }
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `add_key` is never used
[INFO] [stdout]    --> src/config/settings.rs:398:12
[INFO] [stdout]     |
[INFO] [stdout] 319 | impl KeyBindings {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 398 |     pub fn add_key(&mut self, action: BindableAction, key: String) {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `stop` is never used
[INFO] [stdout]    --> src/coordinator/player.rs:158:12
[INFO] [stdout]     |
[INFO] [stdout]  44 | impl PlayerCoordinator {
[INFO] [stdout]     | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 158 |     pub fn stop(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `found` is never read
[INFO] [stdout]   --> src/library/scanner.rs:17:16
[INFO] [stdout]    |
[INFO] [stdout] 17 |     Progress { found: usize },
[INFO] [stdout]    |     --------   ^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ScanEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `artist` is never read
[INFO] [stdout]   --> src/library/types.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct Album {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] 19 |     pub name: String,
[INFO] [stdout] 20 |     pub artist: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Album` 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 `next` and `remove` are never used
[INFO] [stdout]    --> src/playlist/queue.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout]  19 | impl Queue {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn next(&mut self) -> Option<&PathBuf> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 180 |     pub fn remove(&mut self, index: usize) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_cover` is never used
[INFO] [stdout]  --> src/ui/albumart.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub fn extract_cover(path: &Path) -> Option<Vec<u8>> {
[INFO] [stdout]   |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `selected_playlist` is never used
[INFO] [stdout]    --> src/ui/tabs/home.rs:176:12
[INFO] [stdout]     |
[INFO] [stdout] 120 | impl HomeState {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 176 |     pub fn selected_playlist<'a>(&self, playlists: &'a [Playlist]) -> Option<&'a Playlist> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `selected_album_tracks` and `is_checked` are never used
[INFO] [stdout]    --> src/ui/tabs/library.rs:232:12
[INFO] [stdout]     |
[INFO] [stdout]  81 | impl LibraryState {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 232 |     pub fn selected_album_tracks(&self) -> Vec<std::path::PathBuf> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 335 |     pub fn is_checked(&self, path: &std::path::Path) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `selected`, `viewing`, `track_selected`, `scroll_offset`, and `status` are never read
[INFO] [stdout]   --> src/ui/tabs/playlists.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct PlaylistsState {
[INFO] [stdout]    |            -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 15 |     pub selected: usize,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 16 |     /// If Some, we're viewing tracks inside a playlist.
[INFO] [stdout] 17 |     pub viewing: Option<usize>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 18 |     /// Selected track index when viewing a playlist.
[INFO] [stdout] 19 |     pub track_selected: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 20 |     /// Scroll offset.
[INFO] [stdout] 21 |     pub scroll_offset: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 22 |     /// Status message (e.g. "Playlist deleted").
[INFO] [stdout] 23 |     pub status: Option<String>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PlaylistsState` 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: multiple methods are never used
[INFO] [stdout]   --> src/ui/tabs/playlists.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 26 | impl PlaylistsState {
[INFO] [stdout]    | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub fn move_down(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn move_up(&mut self) {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub fn enter(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub fn back(&mut self) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 75 |     pub fn selected_track_path(&self) -> Option<PathBuf> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 84 |     pub fn selected_playlist_tracks(&self) -> Vec<PathBuf> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 93 |     pub fn delete_selected(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlaylistsTab` is never constructed
[INFO] [stdout]    --> src/ui/tabs/playlists.rs:109:12
[INFO] [stdout]     |
[INFO] [stdout] 109 | pub struct PlaylistsTab<'a> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `result_count` is never used
[INFO] [stdout]    --> src/ui/tabs/search.rs:117:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | impl SearchState {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] 116 |     /// Number of results.
[INFO] [stdout] 117 |     pub fn result_count(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `gap` is never read
[INFO] [stdout]   --> src/ui/widgets/visualizer.rs:92:9
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub struct BarLayout {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 92 |     pub gap: usize,
[INFO] [stdout]    |         ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BarLayout` 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 `bar_center` is never used
[INFO] [stdout]    --> src/ui/widgets/visualizer.rs:126:12
[INFO] [stdout]     |
[INFO] [stdout]  98 | impl BarLayout {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 126 |     pub fn bar_center(&self, i: usize) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `width` and `height` are never read
[INFO] [stdout]   --> src/ui/widgets/chroma.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct ChromaFrame {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 35 |     pub cells: Vec<Vec<(char, crossterm::style::Color)>>,
[INFO] [stdout] 36 |     pub width: u32,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 37 |     pub height: u32,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `gpu_failed` is never read
[INFO] [stdout]   --> src/ui/widgets/chroma.rs:54:9
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct ChromaState {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub gpu_failed: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Audio`, `UnsupportedFormat`, `Device`, and `Metadata` are never constructed
[INFO] [stdout]   --> src/util/error.rs:6:5
[INFO] [stdout]    |
[INFO] [stdout]  4 | pub enum SpelmanError {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout]  5 |     #[error("Audio error: {0}")]
[INFO] [stdout]  6 |     Audio(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 15 |     UnsupportedFormat,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     Device(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     Metadata(String),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SpelmanError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 18s
[INFO] running `Command { std: "docker" "inspect" "1c4da1ebe503fa06021be8486b03f321b296c18ee06eacf6b9519fefe3ac730f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1c4da1ebe503fa06021be8486b03f321b296c18ee06eacf6b9519fefe3ac730f", kill_on_drop: false }`
[INFO] [stdout] 1c4da1ebe503fa06021be8486b03f321b296c18ee06eacf6b9519fefe3ac730f
