[INFO] cloning repository https://github.com/VEETS5/vitobar
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/VEETS5/vitobar" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FVEETS5%2Fvitobar", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FVEETS5%2Fvitobar'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 3715db27ea3c2db83c6870ddfea37dbcebb4794b
[INFO] testing VEETS5/vitobar against master#ec6f9a5b4413f74386267ef8efc93712c2ce6db6 for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FVEETS5%2Fvitobar" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/VEETS5/vitobar
[INFO] finished tweaking git repo https://github.com/VEETS5/vitobar
[INFO] tweaked toml for git repo https://github.com/VEETS5/vitobar written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/VEETS5/vitobar on toolchain ec6f9a5b4413f74386267ef8efc93712c2ce6db6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/VEETS5/vitobar 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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded wayland-protocols-wlr v0.3.11
[INFO] [stderr]   Downloaded uds_windows v1.2.1
[INFO] [stderr]   Downloaded wayland-scanner v0.31.9
[INFO] [stderr]   Downloaded toml_parser v1.1.1+spec-1.1.0
[INFO] [stderr]   Downloaded wayland-sys v0.31.10
[INFO] [stderr]   Downloaded toml_edit v0.25.9+spec-1.1.0
[INFO] [stderr]   Downloaded wayland-cursor v0.31.13
[INFO] [stderr]   Downloaded env_filter v1.0.1
[INFO] [stderr]   Downloaded niri-ipc v25.11.0
[INFO] [stderr]   Downloaded env_logger v0.11.10
[INFO] [stderr]   Downloaded wayland-backend v0.3.14
[INFO] [stderr]   Downloaded wayland-protocols v0.32.11
[INFO] [stderr]   Downloaded wayland-client v0.31.13
[INFO] [stderr]   Downloaded jiff-static v0.2.23
[INFO] [stderr]   Downloaded jiff v0.2.23
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] bfc5b579c18b137cca223d8324c1c83e56f0a9173e24fbc92722f16a8a62d0c5
[INFO] running `Command { std: "docker" "start" "-a" "bfc5b579c18b137cca223d8324c1c83e56f0a9173e24fbc92722f16a8a62d0c5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "bfc5b579c18b137cca223d8324c1c83e56f0a9173e24fbc92722f16a8a62d0c5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "bfc5b579c18b137cca223d8324c1c83e56f0a9173e24fbc92722f16a8a62d0c5", kill_on_drop: false }`
[INFO] [stdout] bfc5b579c18b137cca223d8324c1c83e56f0a9173e24fbc92722f16a8a62d0c5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2ce19e7fc9abfd2993efd9f03203983b0574cd0c3692f8a5c1f37f16010d0b1e
[INFO] running `Command { std: "docker" "start" "-a" "2ce19e7fc9abfd2993efd9f03203983b0574cd0c3692f8a5c1f37f16010d0b1e", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.106
[INFO] [stderr]    Compiling unicode-ident v1.0.24
[INFO] [stderr]    Compiling libc v0.2.183
[INFO] [stderr]    Compiling bitflags v2.11.0
[INFO] [stderr]    Compiling rustix v1.1.4
[INFO] [stderr]    Compiling linux-raw-sys v0.12.1
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling quote v1.0.45
[INFO] [stderr]    Compiling wayland-sys v0.31.10
[INFO] [stderr]    Compiling cc v1.2.58
[INFO] [stderr]    Compiling winnow v1.0.1
[INFO] [stderr]    Compiling toml_datetime v1.1.1+spec-1.1.0
[INFO] [stderr]    Compiling memchr v2.8.0
[INFO] [stderr]    Compiling wayland-client v0.31.13
[INFO] [stderr]    Compiling log v0.4.29
[INFO] [stderr]    Compiling endi v1.1.1
[INFO] [stderr]    Compiling simd-adler32 v0.3.9
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling regex-syntax v0.8.10
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling event-listener v5.4.1
[INFO] [stderr]    Compiling fdeflate v0.3.7
[INFO] [stderr]    Compiling smithay-client-toolkit v0.19.2
[INFO] [stderr]    Compiling event-listener-strategy v0.5.4
[INFO] [stderr]    Compiling futures-io v0.3.32
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling strict-num v0.1.1
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling quick-xml v0.39.2
[INFO] [stderr]    Compiling flate2 v1.1.9
[INFO] [stderr]    Compiling xcursor v0.3.10
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling cursor-icon v1.2.0
[INFO] [stderr]    Compiling anstream v1.0.0
[INFO] [stderr]    Compiling rayon v1.11.0
[INFO] [stderr]    Compiling png v0.17.16
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling wayland-backend v0.3.14
[INFO] [stderr]    Compiling memmap2 v0.8.0
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling mio v1.2.0
[INFO] [stderr]    Compiling socket2 v0.6.3
[INFO] [stderr]    Compiling memmap2 v0.9.10
[INFO] [stderr]    Compiling futures-lite v2.6.1
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling async-broadcast v0.7.2
[INFO] [stderr]    Compiling toml_parser v1.1.1+spec-1.1.0
[INFO] [stderr]    Compiling wayland-scanner v0.31.9
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling tokio v1.50.0
[INFO] [stderr]    Compiling ordered-stream v0.2.0
[INFO] [stderr]    Compiling uuid v1.23.0
[INFO] [stderr]    Compiling ttf-parser v0.21.1
[INFO] [stderr]    Compiling toml_edit v0.25.9+spec-1.1.0
[INFO] [stderr]    Compiling jiff v0.2.23
[INFO] [stderr]    Compiling iana-time-zone v0.1.65
[INFO] [stderr]    Compiling proc-macro-crate v3.5.0
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling sysinfo v0.30.13
[INFO] [stderr]    Compiling fontdue v0.9.3
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling enumflags2_derive v0.7.12
[INFO] [stderr]    Compiling bytemuck_derive v1.10.2
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling async-recursion v1.1.1
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling serde_repr v0.1.20
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling env_filter v1.0.1
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling bytemuck v1.25.0
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling xkeysym v0.2.1
[INFO] [stderr]    Compiling tiny-skia-path v0.11.4
[INFO] [stderr]    Compiling xkbcommon v0.7.0
[INFO] [stderr]    Compiling tiny-skia v0.11.4
[INFO] [stderr]    Compiling env_logger v0.11.10
[INFO] [stderr]    Compiling polling v3.11.0
[INFO] [stderr]    Compiling calloop v0.13.0
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling wayland-csd-frame v0.3.0
[INFO] [stderr]    Compiling zvariant_utils v3.3.0
[INFO] [stderr]    Compiling enumflags2 v0.7.12
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling niri-ipc v25.11.0
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling zvariant_derive v5.10.0
[INFO] [stderr]    Compiling zvariant v5.10.0
[INFO] [stderr]    Compiling wayland-protocols v0.32.11
[INFO] [stderr]    Compiling calloop-wayland-source v0.3.0
[INFO] [stderr]    Compiling wayland-cursor v0.31.13
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling zbus_names v4.3.1
[INFO] [stderr]    Compiling zbus_macros v5.14.0
[INFO] [stderr]    Compiling zbus v5.14.0
[INFO] [stderr]    Compiling wayland-protocols-wlr v0.3.11
[INFO] [stderr]    Compiling vitobar v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: fields `compositor` and `qh` are never read
[INFO] [stdout]    --> src/greeter/main.rs:148:5
[INFO] [stdout]     |
[INFO] [stdout] 145 | struct GreeterApp {
[INFO] [stdout]     |        ---------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 148 |     compositor:     CompositorState,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 155 |     qh:             QueueHandle<Self>,
[INFO] [stdout]     |     ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `clip_text`, `draw_icon`, and `truncate_text` are never used
[INFO] [stdout]    --> src/greeter/../render.rs:156:12
[INFO] [stdout]     |
[INFO] [stdout]  43 | impl Renderer {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn clip_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 170 |     pub fn draw_icon(&mut self, x: u32, y: u32, phys_size: u32, rgba: &[u8]) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/greeter/../config.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct Colors {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout]  9 |     pub base02: String, // border inactive
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub base06: String, // light fg
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 14 |     pub base07: String, // bright fg
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 15 |     pub base08: String, // red
[INFO] [stdout] 16 |     pub base09: String, // orange
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 17 |     pub base0a: String, // yellow
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 18 |     pub base0b: String, // green
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 19 |     pub base0c: String, // cyan
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 20 |     pub base0d: String, // blue (accent)
[INFO] [stdout] 21 |     pub base0e: String, // purple
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 22 |     pub base0f: String, // brown
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Colors` 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: function `save_bar_settings` is never used
[INFO] [stdout]    --> src/greeter/../config.rs:145:8
[INFO] [stdout]     |
[INFO] [stdout] 145 | pub fn save_bar_settings(bar_height: Option<u32>, taskbar_height: Option<u32>, font_size: Option<f32>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `compositor`, `layer_shell`, and `qh` are never read
[INFO] [stdout]   --> src/launcher/main.rs:52:5
[INFO] [stdout]    |
[INFO] [stdout] 49 | struct LauncherApp {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 52 |     compositor:     CompositorState,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 53 |     layer_shell:    LayerShell,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     qh:             QueueHandle<Self>,
[INFO] [stdout]    |     ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `clear` and `truncate_text` are never used
[INFO] [stdout]    --> src/launcher/../render.rs:50:12
[INFO] [stdout]     |
[INFO] [stdout]  43 | impl Renderer {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  50 |     pub fn clear(&mut self, hex: &str) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/launcher/../config.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct Colors {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 11 |     pub base04: String, // subtle text
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 12 |     pub base05: String, // foreground
[INFO] [stdout] 13 |     pub base06: String, // light fg
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 14 |     pub base07: String, // bright fg
[INFO] [stdout] 15 |     pub base08: String, // red
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 16 |     pub base09: String, // orange
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 17 |     pub base0a: String, // yellow
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 18 |     pub base0b: String, // green
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 19 |     pub base0c: String, // cyan
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 20 |     pub base0d: String, // blue (accent)
[INFO] [stdout] 21 |     pub base0e: String, // purple
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 22 |     pub base0f: String, // brown
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Colors` 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: function `save_bar_settings` is never used
[INFO] [stdout]    --> src/launcher/../config.rs:145:8
[INFO] [stdout]     |
[INFO] [stdout] 145 | pub fn save_bar_settings(bar_height: Option<u32>, taskbar_height: Option<u32>, font_size: Option<f32>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `icon` is never read
[INFO] [stdout]  --> src/launcher/desktop.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct DesktopEntry {
[INFO] [stdout]   |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 7 |     pub icon:   Option<String>,
[INFO] [stdout]   |         ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `DesktopEntry` 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: fields `compositor`, `layer_shell`, and `qh` are never read
[INFO] [stdout]   --> src/settings/main.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | struct SettingsApp {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 51 |     compositor:      CompositorState,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 52 |     layer_shell:     LayerShell,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     qh:              QueueHandle<Self>,
[INFO] [stdout]    |     ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `draw_icon` and `truncate_text` are never used
[INFO] [stdout]    --> src/settings/../render.rs:170:12
[INFO] [stdout]     |
[INFO] [stdout]  43 | impl Renderer {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 170 |     pub fn draw_icon(&mut self, x: u32, y: u32, phys_size: u32, rgba: &[u8]) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `base06`, `base09`, `base0a`, `base0c`, `base0e`, and `base0f` are never read
[INFO] [stdout]   --> src/settings/../config.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct Colors {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub base06: String, // light fg
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     pub base09: String, // orange
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 17 |     pub base0a: String, // yellow
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 18 |     pub base0b: String, // green
[INFO] [stdout] 19 |     pub base0c: String, // cyan
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 20 |     pub base0d: String, // blue (accent)
[INFO] [stdout] 21 |     pub base0e: String, // purple
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 22 |     pub base0f: String, // brown
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Colors` 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: static `CACHE` is never used
[INFO] [stdout]  --> src/settings/../icons.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static CACHE: OnceLock<Mutex<HashMap<String, Option<Vec<u8>>>>> = OnceLock::new();
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cache` is never used
[INFO] [stdout]   --> src/settings/../icons.rs:11:4
[INFO] [stdout]    |
[INFO] [stdout] 11 | fn cache() -> &'static Mutex<HashMap<String, Option<Vec<u8>>>> {
[INFO] [stdout]    |    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load` is never used
[INFO] [stdout]   --> src/settings/../icons.rs:17:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub fn load(app_id: &str, size: u32) -> Option<Vec<u8>> {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `data_dirs` is never used
[INFO] [stdout]   --> src/settings/../icons.rs:32:4
[INFO] [stdout]    |
[INFO] [stdout] 32 | fn data_dirs() -> Vec<PathBuf> {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `desktop_icon_name` is never used
[INFO] [stdout]   --> src/settings/../icons.rs:56:4
[INFO] [stdout]    |
[INFO] [stdout] 56 | fn desktop_icon_name(app_id: &str) -> Option<String> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_png_path` is never used
[INFO] [stdout]   --> src/settings/../icons.rs:77:4
[INFO] [stdout]    |
[INFO] [stdout] 77 | fn find_png_path(icon_name: &str) -> Option<PathBuf> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `lookup` is never used
[INFO] [stdout]    --> src/settings/../icons.rs:116:4
[INFO] [stdout]     |
[INFO] [stdout] 116 | fn lookup(app_id: &str, size: u32) -> Option<Vec<u8>> {
[INFO] [stdout]     |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `decode_and_scale` is never used
[INFO] [stdout]    --> src/settings/../icons.rs:122:4
[INFO] [stdout]     |
[INFO] [stdout] 122 | fn decode_and_scale(path: &std::path::Path, target: u32) -> Option<Vec<u8>> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ti`
[INFO] [stdout]    --> src/main.rs:431:10
[INFO] [stdout]     |
[INFO] [stdout] 431 |     for (ti, tray_item) in tray_items.iter().enumerate() {
[INFO] [stdout]     |          ^^ help: if this is intentional, prefix it with an underscore: `_ti`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `tray_idx` is never read
[INFO] [stdout]   --> src/main.rs:62:24
[INFO] [stdout]    |
[INFO] [stdout] 62 |     TrayMenuItem     { tray_idx: usize, menu_id: i32 },
[INFO] [stdout]    |     ------------       ^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BarAction` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `TrayShowMenu` is never constructed
[INFO] [stdout]   --> src/main.rs:61:5
[INFO] [stdout]    |
[INFO] [stdout] 49 | enum BarAction {
[INFO] [stdout]    |      --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 61 |     TrayShowMenu    { tray_idx: usize },
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BarAction` 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: constant `POPUP_HEIGHT` is never used
[INFO] [stdout]    --> src/main.rs:171:7
[INFO] [stdout]     |
[INFO] [stdout] 171 | const POPUP_HEIGHT:   u32 = POPUP_ITEM_H * POPUP_ITEMS;
[INFO] [stdout]     |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `top_tray_hits` is never read
[INFO] [stdout]    --> src/main.rs:214:5
[INFO] [stdout]     |
[INFO] [stdout] 199 | struct PerOutput {
[INFO] [stdout]     |        --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 214 |     top_tray_hits:   Vec<(usize, HitRegion)>,  // (tray_idx, region) for right-click
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `base06` and `base0f` are never read
[INFO] [stdout]   --> src/config.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct Colors {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub base06: String, // light fg
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub base0f: String, // brown
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Colors` 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: function `save_bar_settings` is never used
[INFO] [stdout]    --> src/config.rs:145:8
[INFO] [stdout]     |
[INFO] [stdout] 145 | pub fn save_bar_settings(bar_height: Option<u32>, taskbar_height: Option<u32>, font_size: Option<f32>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `truncate_text` is never used
[INFO] [stdout]    --> src/render.rs:194:12
[INFO] [stdout]     |
[INFO] [stdout]  43 | impl Renderer {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `title` is never read
[INFO] [stdout]   --> src/modules/tray.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct TrayItem {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 14 |     pub id:         String,
[INFO] [stdout] 15 |     pub title:      String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TrayItem` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `enabled` is never read
[INFO] [stdout]   --> src/modules/tray.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct MenuItem {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub enabled: bool,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MenuItem` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 53s
[INFO] running `Command { std: "docker" "inspect" "2ce19e7fc9abfd2993efd9f03203983b0574cd0c3692f8a5c1f37f16010d0b1e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2ce19e7fc9abfd2993efd9f03203983b0574cd0c3692f8a5c1f37f16010d0b1e", kill_on_drop: false }`
[INFO] [stdout] 2ce19e7fc9abfd2993efd9f03203983b0574cd0c3692f8a5c1f37f16010d0b1e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 62b209beaa9d399c5a906a1364d2ced40a37cde84b85b819089ba28fbd1c31bd
[INFO] running `Command { std: "docker" "start" "-a" "62b209beaa9d399c5a906a1364d2ced40a37cde84b85b819089ba28fbd1c31bd", kill_on_drop: false }`
[INFO] [stderr]    Compiling vitobar v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: fields `compositor` and `qh` are never read
[INFO] [stdout]    --> src/greeter/main.rs:148:5
[INFO] [stdout]     |
[INFO] [stdout] 145 | struct GreeterApp {
[INFO] [stdout]     |        ---------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 148 |     compositor:     CompositorState,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 155 |     qh:             QueueHandle<Self>,
[INFO] [stdout]     |     ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `clip_text`, `draw_icon`, and `truncate_text` are never used
[INFO] [stdout]    --> src/greeter/../render.rs:156:12
[INFO] [stdout]     |
[INFO] [stdout]  43 | impl Renderer {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn clip_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 170 |     pub fn draw_icon(&mut self, x: u32, y: u32, phys_size: u32, rgba: &[u8]) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/greeter/../config.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct Colors {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout]  9 |     pub base02: String, // border inactive
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub base06: String, // light fg
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 14 |     pub base07: String, // bright fg
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 15 |     pub base08: String, // red
[INFO] [stdout] 16 |     pub base09: String, // orange
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 17 |     pub base0a: String, // yellow
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 18 |     pub base0b: String, // green
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 19 |     pub base0c: String, // cyan
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 20 |     pub base0d: String, // blue (accent)
[INFO] [stdout] 21 |     pub base0e: String, // purple
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 22 |     pub base0f: String, // brown
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Colors` 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: function `save_bar_settings` is never used
[INFO] [stdout]    --> src/greeter/../config.rs:145:8
[INFO] [stdout]     |
[INFO] [stdout] 145 | pub fn save_bar_settings(bar_height: Option<u32>, taskbar_height: Option<u32>, font_size: Option<f32>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `compositor`, `layer_shell`, and `qh` are never read
[INFO] [stdout]   --> src/launcher/main.rs:52:5
[INFO] [stdout]    |
[INFO] [stdout] 49 | struct LauncherApp {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 52 |     compositor:     CompositorState,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 53 |     layer_shell:    LayerShell,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     qh:             QueueHandle<Self>,
[INFO] [stdout]    |     ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `clear` and `truncate_text` are never used
[INFO] [stdout]    --> src/launcher/../render.rs:50:12
[INFO] [stdout]     |
[INFO] [stdout]  43 | impl Renderer {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  50 |     pub fn clear(&mut self, hex: &str) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/launcher/../config.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct Colors {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 11 |     pub base04: String, // subtle text
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 12 |     pub base05: String, // foreground
[INFO] [stdout] 13 |     pub base06: String, // light fg
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 14 |     pub base07: String, // bright fg
[INFO] [stdout] 15 |     pub base08: String, // red
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 16 |     pub base09: String, // orange
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 17 |     pub base0a: String, // yellow
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 18 |     pub base0b: String, // green
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 19 |     pub base0c: String, // cyan
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 20 |     pub base0d: String, // blue (accent)
[INFO] [stdout] 21 |     pub base0e: String, // purple
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 22 |     pub base0f: String, // brown
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Colors` 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: function `save_bar_settings` is never used
[INFO] [stdout]    --> src/launcher/../config.rs:145:8
[INFO] [stdout]     |
[INFO] [stdout] 145 | pub fn save_bar_settings(bar_height: Option<u32>, taskbar_height: Option<u32>, font_size: Option<f32>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `icon` is never read
[INFO] [stdout]  --> src/launcher/desktop.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct DesktopEntry {
[INFO] [stdout]   |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 7 |     pub icon:   Option<String>,
[INFO] [stdout]   |         ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `DesktopEntry` 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: fields `compositor`, `layer_shell`, and `qh` are never read
[INFO] [stdout]   --> src/settings/main.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | struct SettingsApp {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 51 |     compositor:      CompositorState,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 52 |     layer_shell:     LayerShell,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     qh:              QueueHandle<Self>,
[INFO] [stdout]    |     ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `draw_icon` and `truncate_text` are never used
[INFO] [stdout]    --> src/settings/../render.rs:170:12
[INFO] [stdout]     |
[INFO] [stdout]  43 | impl Renderer {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 170 |     pub fn draw_icon(&mut self, x: u32, y: u32, phys_size: u32, rgba: &[u8]) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `base06`, `base09`, `base0a`, `base0c`, `base0e`, and `base0f` are never read
[INFO] [stdout]   --> src/settings/../config.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct Colors {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub base06: String, // light fg
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     pub base09: String, // orange
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 17 |     pub base0a: String, // yellow
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 18 |     pub base0b: String, // green
[INFO] [stdout] 19 |     pub base0c: String, // cyan
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 20 |     pub base0d: String, // blue (accent)
[INFO] [stdout] 21 |     pub base0e: String, // purple
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 22 |     pub base0f: String, // brown
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Colors` 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: static `CACHE` is never used
[INFO] [stdout]  --> src/settings/../icons.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static CACHE: OnceLock<Mutex<HashMap<String, Option<Vec<u8>>>>> = OnceLock::new();
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cache` is never used
[INFO] [stdout]   --> src/settings/../icons.rs:11:4
[INFO] [stdout]    |
[INFO] [stdout] 11 | fn cache() -> &'static Mutex<HashMap<String, Option<Vec<u8>>>> {
[INFO] [stdout]    |    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load` is never used
[INFO] [stdout]   --> src/settings/../icons.rs:17:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub fn load(app_id: &str, size: u32) -> Option<Vec<u8>> {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `data_dirs` is never used
[INFO] [stdout]   --> src/settings/../icons.rs:32:4
[INFO] [stdout]    |
[INFO] [stdout] 32 | fn data_dirs() -> Vec<PathBuf> {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `desktop_icon_name` is never used
[INFO] [stdout]   --> src/settings/../icons.rs:56:4
[INFO] [stdout]    |
[INFO] [stdout] 56 | fn desktop_icon_name(app_id: &str) -> Option<String> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_png_path` is never used
[INFO] [stdout]   --> src/settings/../icons.rs:77:4
[INFO] [stdout]    |
[INFO] [stdout] 77 | fn find_png_path(icon_name: &str) -> Option<PathBuf> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `lookup` is never used
[INFO] [stdout]    --> src/settings/../icons.rs:116:4
[INFO] [stdout]     |
[INFO] [stdout] 116 | fn lookup(app_id: &str, size: u32) -> Option<Vec<u8>> {
[INFO] [stdout]     |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `decode_and_scale` is never used
[INFO] [stdout]    --> src/settings/../icons.rs:122:4
[INFO] [stdout]     |
[INFO] [stdout] 122 | fn decode_and_scale(path: &std::path::Path, target: u32) -> Option<Vec<u8>> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ti`
[INFO] [stdout]    --> src/main.rs:431:10
[INFO] [stdout]     |
[INFO] [stdout] 431 |     for (ti, tray_item) in tray_items.iter().enumerate() {
[INFO] [stdout]     |          ^^ help: if this is intentional, prefix it with an underscore: `_ti`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `tray_idx` is never read
[INFO] [stdout]   --> src/main.rs:62:24
[INFO] [stdout]    |
[INFO] [stdout] 62 |     TrayMenuItem     { tray_idx: usize, menu_id: i32 },
[INFO] [stdout]    |     ------------       ^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BarAction` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `TrayShowMenu` is never constructed
[INFO] [stdout]   --> src/main.rs:61:5
[INFO] [stdout]    |
[INFO] [stdout] 49 | enum BarAction {
[INFO] [stdout]    |      --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 61 |     TrayShowMenu    { tray_idx: usize },
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BarAction` 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: constant `POPUP_HEIGHT` is never used
[INFO] [stdout]    --> src/main.rs:171:7
[INFO] [stdout]     |
[INFO] [stdout] 171 | const POPUP_HEIGHT:   u32 = POPUP_ITEM_H * POPUP_ITEMS;
[INFO] [stdout]     |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `top_tray_hits` is never read
[INFO] [stdout]    --> src/main.rs:214:5
[INFO] [stdout]     |
[INFO] [stdout] 199 | struct PerOutput {
[INFO] [stdout]     |        --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 214 |     top_tray_hits:   Vec<(usize, HitRegion)>,  // (tray_idx, region) for right-click
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `base06` and `base0f` are never read
[INFO] [stdout]   --> src/config.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct Colors {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub base06: String, // light fg
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub base0f: String, // brown
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Colors` 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: function `save_bar_settings` is never used
[INFO] [stdout]    --> src/config.rs:145:8
[INFO] [stdout]     |
[INFO] [stdout] 145 | pub fn save_bar_settings(bar_height: Option<u32>, taskbar_height: Option<u32>, font_size: Option<f32>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `truncate_text` is never used
[INFO] [stdout]    --> src/render.rs:194:12
[INFO] [stdout]     |
[INFO] [stdout]  43 | impl Renderer {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `title` is never read
[INFO] [stdout]   --> src/modules/tray.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct TrayItem {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 14 |     pub id:         String,
[INFO] [stdout] 15 |     pub title:      String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TrayItem` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `enabled` is never read
[INFO] [stdout]   --> src/modules/tray.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct MenuItem {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub enabled: bool,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MenuItem` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 2.98s
[INFO] running `Command { std: "docker" "inspect" "62b209beaa9d399c5a906a1364d2ced40a37cde84b85b819089ba28fbd1c31bd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "62b209beaa9d399c5a906a1364d2ced40a37cde84b85b819089ba28fbd1c31bd", kill_on_drop: false }`
[INFO] [stdout] 62b209beaa9d399c5a906a1364d2ced40a37cde84b85b819089ba28fbd1c31bd
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 575b3924a812adf3377cf159eee2178846c03758716aede8d07117bd3049392b
[INFO] running `Command { std: "docker" "start" "-a" "575b3924a812adf3377cf159eee2178846c03758716aede8d07117bd3049392b", kill_on_drop: false }`
[INFO] [stderr] warning: fields `compositor` and `qh` are never read
[INFO] [stderr]    --> src/greeter/main.rs:148:5
[INFO] [stderr]     |
[INFO] [stderr] 145 | struct GreeterApp {
[INFO] [stderr]     |        ---------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 148 |     compositor:     CompositorState,
[INFO] [stderr]     |     ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 155 |     qh:             QueueHandle<Self>,
[INFO] [stderr]     |     ^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: methods `clip_text`, `draw_icon`, and `truncate_text` are never used
[INFO] [stderr]    --> src/greeter/../render.rs:156:12
[INFO] [stderr]     |
[INFO] [stderr]  43 | impl Renderer {
[INFO] [stderr]     | ------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 156 |     pub fn clip_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 170 |     pub fn draw_icon(&mut self, x: u32, y: u32, phys_size: u32, rgba: &[u8]) {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple fields are never read
[INFO] [stderr]   --> src/greeter/../config.rs:9:9
[INFO] [stderr]    |
[INFO] [stderr]  6 | pub struct Colors {
[INFO] [stderr]    |            ------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr]  9 |     pub base02: String, // border inactive
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 13 |     pub base06: String, // light fg
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 14 |     pub base07: String, // bright fg
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 15 |     pub base08: String, // red
[INFO] [stderr] 16 |     pub base09: String, // orange
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 17 |     pub base0a: String, // yellow
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 18 |     pub base0b: String, // green
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 19 |     pub base0c: String, // cyan
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 20 |     pub base0d: String, // blue (accent)
[INFO] [stderr] 21 |     pub base0e: String, // purple
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 22 |     pub base0f: String, // brown
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Colors` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: function `save_bar_settings` is never used
[INFO] [stderr]    --> src/greeter/../config.rs:145:8
[INFO] [stderr]     |
[INFO] [stderr] 145 | pub fn save_bar_settings(bar_height: Option<u32>, taskbar_height: Option<u32>, font_size: Option<f32>) {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `ti`
[INFO] [stderr]    --> src/main.rs:431:10
[INFO] [stderr]     |
[INFO] [stderr] 431 |     for (ti, tray_item) in tray_items.iter().enumerate() {
[INFO] [stderr]     |          ^^ help: if this is intentional, prefix it with an underscore: `_ti`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `tray_idx` is never read
[INFO] [stderr]   --> src/main.rs:62:24
[INFO] [stderr]    |
[INFO] [stderr] 62 |     TrayMenuItem     { tray_idx: usize, menu_id: i32 },
[INFO] [stderr]    |     ------------       ^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `BarAction` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variant `TrayShowMenu` is never constructed
[INFO] [stderr]   --> src/main.rs:61:5
[INFO] [stderr]    |
[INFO] [stderr] 49 | enum BarAction {
[INFO] [stderr]    |      --------- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 61 |     TrayShowMenu    { tray_idx: usize },
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `BarAction` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: constant `POPUP_HEIGHT` is never used
[INFO] [stderr]    --> src/main.rs:171:7
[INFO] [stderr]     |
[INFO] [stderr] 171 | const POPUP_HEIGHT:   u32 = POPUP_ITEM_H * POPUP_ITEMS;
[INFO] [stderr]     |       ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `top_tray_hits` is never read
[INFO] [stderr]    --> src/main.rs:214:5
[INFO] [stderr]     |
[INFO] [stderr] 199 | struct PerOutput {
[INFO] [stderr]     |        --------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 214 |     top_tray_hits:   Vec<(usize, HitRegion)>,  // (tray_idx, region) for right-click
[INFO] [stderr]     |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `base06` and `base0f` are never read
[INFO] [stderr]   --> src/config.rs:13:9
[INFO] [stderr]    |
[INFO] [stderr]  6 | pub struct Colors {
[INFO] [stderr]    |            ------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 13 |     pub base06: String, // light fg
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 22 |     pub base0f: String, // brown
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Colors` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: function `save_bar_settings` is never used
[INFO] [stderr]    --> src/config.rs:145:8
[INFO] [stderr]     |
[INFO] [stderr] 145 | pub fn save_bar_settings(bar_height: Option<u32>, taskbar_height: Option<u32>, font_size: Option<f32>) {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `truncate_text` is never used
[INFO] [stderr]    --> src/render.rs:194:12
[INFO] [stderr]     |
[INFO] [stderr]  43 | impl Renderer {
[INFO] [stderr]     | ------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `title` is never read
[INFO] [stderr]   --> src/modules/tray.rs:15:9
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub struct TrayItem {
[INFO] [stderr]    |            -------- field in this struct
[INFO] [stderr] 14 |     pub id:         String,
[INFO] [stderr] 15 |     pub title:      String,
[INFO] [stderr]    |         ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `TrayItem` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `enabled` is never read
[INFO] [stderr]   --> src/modules/tray.rs:28:9
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub struct MenuItem {
[INFO] [stderr]    |            -------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 28 |     pub enabled: bool,
[INFO] [stderr]    |         ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MenuItem` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `compositor`, `layer_shell`, and `qh` are never read
[INFO] [stderr]   --> src/launcher/main.rs:52:5
[INFO] [stderr]    |
[INFO] [stderr] 49 | struct LauncherApp {
[INFO] [stderr]    |        ----------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 52 |     compositor:     CompositorState,
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] 53 |     layer_shell:    LayerShell,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 59 |     qh:             QueueHandle<Self>,
[INFO] [stderr]    |     ^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: methods `clear` and `truncate_text` are never used
[INFO] [stderr]    --> src/launcher/../render.rs:50:12
[INFO] [stderr]     |
[INFO] [stderr]  43 | impl Renderer {
[INFO] [stderr]     | ------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  50 |     pub fn clear(&mut self, hex: &str) {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple fields are never read
[INFO] [stderr]   --> src/launcher/../config.rs:11:9
[INFO] [stderr]    |
[INFO] [stderr]  6 | pub struct Colors {
[INFO] [stderr]    |            ------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 11 |     pub base04: String, // subtle text
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 12 |     pub base05: String, // foreground
[INFO] [stderr] 13 |     pub base06: String, // light fg
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 14 |     pub base07: String, // bright fg
[INFO] [stderr] 15 |     pub base08: String, // red
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 16 |     pub base09: String, // orange
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 17 |     pub base0a: String, // yellow
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 18 |     pub base0b: String, // green
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 19 |     pub base0c: String, // cyan
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 20 |     pub base0d: String, // blue (accent)
[INFO] [stderr] 21 |     pub base0e: String, // purple
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 22 |     pub base0f: String, // brown
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Colors` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: function `save_bar_settings` is never used
[INFO] [stderr]    --> src/launcher/../config.rs:145:8
[INFO] [stderr]     |
[INFO] [stderr] 145 | pub fn save_bar_settings(bar_height: Option<u32>, taskbar_height: Option<u32>, font_size: Option<f32>) {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `icon` is never read
[INFO] [stderr]  --> src/launcher/desktop.rs:7:9
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub struct DesktopEntry {
[INFO] [stderr]   |            ------------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 7 |     pub icon:   Option<String>,
[INFO] [stderr]   |         ^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `DesktopEntry` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `compositor`, `layer_shell`, and `qh` are never read
[INFO] [stderr]   --> src/settings/main.rs:51:5
[INFO] [stderr]    |
[INFO] [stderr] 48 | struct SettingsApp {
[INFO] [stderr]    |        ----------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 51 |     compositor:      CompositorState,
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] 52 |     layer_shell:     LayerShell,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 58 |     qh:              QueueHandle<Self>,
[INFO] [stderr]    |     ^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: methods `draw_icon` and `truncate_text` are never used
[INFO] [stderr]    --> src/settings/../render.rs:170:12
[INFO] [stderr]     |
[INFO] [stderr]  43 | impl Renderer {
[INFO] [stderr]     | ------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 170 |     pub fn draw_icon(&mut self, x: u32, y: u32, phys_size: u32, rgba: &[u8]) {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 194 |     pub fn truncate_text(&self, text: &str, max_width: f32, size: f32) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `base06`, `base09`, `base0a`, `base0c`, `base0e`, and `base0f` are never read
[INFO] [stderr]   --> src/settings/../config.rs:13:9
[INFO] [stderr]    |
[INFO] [stderr]  6 | pub struct Colors {
[INFO] [stderr]    |            ------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 13 |     pub base06: String, // light fg
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 16 |     pub base09: String, // orange
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 17 |     pub base0a: String, // yellow
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 18 |     pub base0b: String, // green
[INFO] [stderr] 19 |     pub base0c: String, // cyan
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 20 |     pub base0d: String, // blue (accent)
[INFO] [stderr] 21 |     pub base0e: String, // purple
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 22 |     pub base0f: String, // brown
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Colors` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: static `CACHE` is never used
[INFO] [stderr]  --> src/settings/../icons.rs:9:8
[INFO] [stderr]   |
[INFO] [stderr] 9 | static CACHE: OnceLock<Mutex<HashMap<String, Option<Vec<u8>>>>> = OnceLock::new();
[INFO] [stderr]   |        ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `cache` is never used
[INFO] [stderr]   --> src/settings/../icons.rs:11:4
[INFO] [stderr]    |
[INFO] [stderr] 11 | fn cache() -> &'static Mutex<HashMap<String, Option<Vec<u8>>>> {
[INFO] [stderr]    |    ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `load` is never used
[INFO] [stderr]   --> src/settings/../icons.rs:17:8
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub fn load(app_id: &str, size: u32) -> Option<Vec<u8>> {
[INFO] [stderr]    |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `data_dirs` is never used
[INFO] [stderr]   --> src/settings/../icons.rs:32:4
[INFO] [stderr]    |
[INFO] [stderr] 32 | fn data_dirs() -> Vec<PathBuf> {
[INFO] [stderr]    |    ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `desktop_icon_name` is never used
[INFO] [stderr]   --> src/settings/../icons.rs:56:4
[INFO] [stderr]    |
[INFO] [stderr] 56 | fn desktop_icon_name(app_id: &str) -> Option<String> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `find_png_path` is never used
[INFO] [stderr]   --> src/settings/../icons.rs:77:4
[INFO] [stderr]    |
[INFO] [stderr] 77 | fn find_png_path(icon_name: &str) -> Option<PathBuf> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `lookup` is never used
[INFO] [stderr]    --> src/settings/../icons.rs:116:4
[INFO] [stderr]     |
[INFO] [stderr] 116 | fn lookup(app_id: &str, size: u32) -> Option<Vec<u8>> {
[INFO] [stderr]     |    ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `decode_and_scale` is never used
[INFO] [stderr]    --> src/settings/../icons.rs:122:4
[INFO] [stderr]     |
[INFO] [stderr] 122 | fn decode_and_scale(path: &std::path::Path, target: u32) -> Option<Vec<u8>> {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `vitobar` (bin "vitogreeter" test) generated 4 warnings
[INFO] [stderr] warning: `vitobar` (bin "vitobar" test) generated 10 warnings (run `cargo fix --bin "vitobar" -p vitobar --tests` to apply 1 suggestion)
[INFO] [stderr] warning: `vitobar` (bin "vitolauncher" test) generated 5 warnings
[INFO] [stderr] warning: `vitobar` (bin "vitosettings" test) generated 11 warnings
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.24s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/vitobar-d2cb68417178e53d)
[INFO] [stderr]      Running unittests src/greeter/main.rs (/opt/rustwide/target/debug/deps/vitogreeter-beac9b8c8b56d802)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/launcher/main.rs (/opt/rustwide/target/debug/deps/vitolauncher-ba17be7a3687f96f)
[INFO] [stderr]      Running unittests src/settings/main.rs (/opt/rustwide/target/debug/deps/vitosettings-55756c09e3fb7795)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "575b3924a812adf3377cf159eee2178846c03758716aede8d07117bd3049392b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "575b3924a812adf3377cf159eee2178846c03758716aede8d07117bd3049392b", kill_on_drop: false }`
[INFO] [stdout] 575b3924a812adf3377cf159eee2178846c03758716aede8d07117bd3049392b
