[INFO] cloning repository https://github.com/eoncheole/vessel
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/eoncheole/vessel" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Feoncheole%2Fvessel", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Feoncheole%2Fvessel'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 4d24b9e10ac9789e5e21377740f87e28aff5e6fa
[INFO] checking eoncheole/vessel against try#6284d7b4bd27983dba388146648ab844ca7d032f for pr-152971
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Feoncheole%2Fvessel" "/workspace/builds/worker-4-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/eoncheole/vessel
[INFO] finished tweaking git repo https://github.com/eoncheole/vessel
[INFO] tweaked toml for git repo https://github.com/eoncheole/vessel written to /workspace/builds/worker-4-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/eoncheole/vessel on toolchain 6284d7b4bd27983dba388146648ab844ca7d032f
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+6284d7b4bd27983dba388146648ab844ca7d032f" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/eoncheole/vessel 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" "+6284d7b4bd27983dba388146648ab844ca7d032f" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:61361fe0aef631f17e9d025a70c5a647956f8c671dd02950a60ad3f5cc5526d7" "/opt/rustwide/cargo-home/bin/cargo" "+6284d7b4bd27983dba388146648ab844ca7d032f" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2bd5d893f7fe6c66fd1fa917c3a860c5f4479700947dfb21767cec7b5ff169ee
[INFO] running `Command { std: "docker" "start" "-a" "2bd5d893f7fe6c66fd1fa917c3a860c5f4479700947dfb21767cec7b5ff169ee", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2bd5d893f7fe6c66fd1fa917c3a860c5f4479700947dfb21767cec7b5ff169ee", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2bd5d893f7fe6c66fd1fa917c3a860c5f4479700947dfb21767cec7b5ff169ee", kill_on_drop: false }`
[INFO] [stdout] 2bd5d893f7fe6c66fd1fa917c3a860c5f4479700947dfb21767cec7b5ff169ee
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:61361fe0aef631f17e9d025a70c5a647956f8c671dd02950a60ad3f5cc5526d7" "/opt/rustwide/cargo-home/bin/cargo" "+6284d7b4bd27983dba388146648ab844ca7d032f" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 514dcf0bc03fba5cc09244f462acd79f63ce094c384a3ebb0ce94006c77a1113
[INFO] running `Command { std: "docker" "start" "-a" "514dcf0bc03fba5cc09244f462acd79f63ce094c384a3ebb0ce94006c77a1113", kill_on_drop: false }`
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]     Checking linux-raw-sys v0.11.0
[INFO] [stderr]    Compiling wayland-sys v0.31.8
[INFO] [stderr]     Checking libloading v0.8.9
[INFO] [stderr]    Compiling libc v0.2.180
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]     Checking simd-adler32 v0.3.8
[INFO] [stderr]    Compiling quick-xml v0.38.4
[INFO] [stderr]    Compiling wayland-client v0.31.12
[INFO] [stderr]     Checking aho-corasick v1.1.4
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking lock_api v0.4.14
[INFO] [stderr]     Checking mio v1.1.1
[INFO] [stderr]     Checking as-slice v0.2.1
[INFO] [stderr]    Compiling built v0.8.0
[INFO] [stderr]     Checking tracing-core v0.1.36
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking dlib v0.5.2
[INFO] [stderr]    Compiling av-scenechange v0.14.1
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]     Checking aligned v0.4.3
[INFO] [stderr]     Checking nom v8.0.0
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking core2 v0.4.0
[INFO] [stderr]     Checking y4m v0.8.0
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking bitstream-io v4.9.0
[INFO] [stderr]     Checking maybe-rayon v0.1.1
[INFO] [stderr]    Compiling simd_helpers v0.1.0
[INFO] [stderr]     Checking memmap2 v0.9.9
[INFO] [stderr]     Checking imgref v1.12.0
[INFO] [stderr]    Compiling rav1e v0.8.1
[INFO] [stderr]     Checking xcursor v0.3.10
[INFO] [stderr]     Checking futures-core v0.3.31
[INFO] [stderr]     Checking flate2 v1.1.9
[INFO] [stderr]    Compiling smithay-client-toolkit v0.20.0
[INFO] [stderr]     Checking linux-raw-sys v0.4.15
[INFO] [stderr]     Checking weezl v0.1.12
[INFO] [stderr]    Compiling zstd-safe v7.2.4
[INFO] [stderr]     Checking time v0.3.47
[INFO] [stderr]     Checking regex-automata v0.4.14
[INFO] [stderr]     Checking loop9 v0.1.5
[INFO] [stderr]     Checking serde_json v1.0.149
[INFO] [stderr]     Checking signal-hook-mio v0.2.5
[INFO] [stderr]     Checking fdeflate v0.3.7
[INFO] [stderr]     Checking zune-inflate v0.2.54
[INFO] [stderr]     Checking avif-serialize v0.8.6
[INFO] [stderr]     Checking inout v0.1.4
[INFO] [stderr]     Checking pxfm v0.1.27
[INFO] [stderr]     Checking percent-encoding v2.3.2
[INFO] [stderr]     Checking bytemuck v1.25.0
[INFO] [stderr]     Checking rgb v0.8.52
[INFO] [stderr]     Checking zune-core v0.5.1
[INFO] [stderr]    Compiling wayland-scanner v0.31.8
[INFO] [stderr]     Checking x11rb-protocol v0.13.2
[INFO] [stderr]     Checking compact_str v0.8.1
[INFO] [stderr]     Checking qoi v0.4.1
[INFO] [stderr]     Checking zune-jpeg v0.5.12
[INFO] [stderr]     Checking form_urlencoded v1.2.2
[INFO] [stderr]     Checking png v0.18.0
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]     Checking num-rational v0.4.2
[INFO] [stderr]     Checking gif v0.14.1
[INFO] [stderr]     Checking cipher v0.4.4
[INFO] [stderr]    Compiling cc v1.2.55
[INFO] [stderr]     Checking lru v0.12.5
[INFO] [stderr]     Checking hmac v0.12.1
[INFO] [stderr]     Checking filetime v0.2.27
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]     Checking is-docker v0.2.0
[INFO] [stderr]     Checking grep-matcher v0.1.8
[INFO] [stderr]     Checking instant v0.1.13
[INFO] [stderr]    Compiling pulldown-cmark v0.12.2
[INFO] [stderr]    Compiling zip v2.4.2
[INFO] [stderr]     Checking dirs-sys v0.5.0
[INFO] [stderr]     Checking notify-types v1.0.1
[INFO] [stderr]     Checking lzma-rs v0.3.0
[INFO] [stderr]     Checking inotify v0.10.2
[INFO] [stderr]     Checking zopfli v0.8.3
[INFO] [stderr]     Checking is-wsl v0.4.0
[INFO] [stderr]     Checking pbkdf2 v0.12.2
[INFO] [stderr]     Checking aes v0.8.4
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking getopts v0.2.24
[INFO] [stderr]     Checking nucleo-matcher v0.3.1
[INFO] [stderr]     Checking socket2 v0.6.2
[INFO] [stderr]     Checking predicates-core v1.0.9
[INFO] [stderr]    Compiling doc-comment v0.3.4
[INFO] [stderr]     Checking clap_lex v0.7.7
[INFO] [stderr]     Checking icy_sixel v0.1.3
[INFO] [stderr]     Checking deflate64 v0.1.10
[INFO] [stderr]     Checking pulldown-cmark-escape v0.11.0
[INFO] [stderr]     Checking futures-lite v2.6.1
[INFO] [stderr]     Checking clap_builder v4.5.57
[INFO] [stderr]     Checking open v5.3.3
[INFO] [stderr]     Checking nucleo v0.5.0
[INFO] [stderr]     Checking notify v7.0.0
[INFO] [stderr]     Checking dirs v6.0.0
[INFO] [stderr]     Checking natord v1.0.9
[INFO] [stderr]     Checking termtree v0.5.1
[INFO] [stderr]     Checking predicates v3.1.3
[INFO] [stderr]     Checking predicates-tree v1.0.12
[INFO] [stderr]     Checking console v0.15.11
[INFO] [stderr]     Checking is-terminal v0.4.17
[INFO] [stderr]     Checking moxcms v0.7.11
[INFO] [stderr]     Checking bstr v1.12.1
[INFO] [stderr]     Checking regex v1.12.3
[INFO] [stderr]     Checking crossterm v0.28.1
[INFO] [stderr]    Compiling wayland-backend v0.3.12
[INFO] [stderr]    Compiling zstd-sys v2.0.16+zstd.1.5.7
[INFO] [stderr]    Compiling libz-sys v1.1.23
[INFO] [stderr]    Compiling lzma-sys v0.1.20
[INFO] [stderr]    Compiling bzip2-sys v0.1.13+1.0.8
[INFO] [stderr]    Compiling onig_sys v69.9.1
[INFO] [stderr]    Compiling libgit2-sys v0.17.0+1.8.1
[INFO] [stderr]     Checking xz2 v0.1.7
[INFO] [stderr]     Checking globset v0.4.18
[INFO] [stderr]     Checking grep-regex v0.1.14
[INFO] [stderr]     Checking grep-searcher v0.1.16
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]     Checking clap v4.5.57
[INFO] [stderr]     Checking ignore v0.4.25
[INFO] [stderr]     Checking bzip2 v0.5.2
[INFO] [stderr]     Checking globwalk v0.9.1
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling zerocopy-derive v0.8.39
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling equator-macro v0.4.2
[INFO] [stderr]     Checking polling v3.11.0
[INFO] [stderr]    Compiling arg_enum_proc_macro v0.3.4
[INFO] [stderr]    Compiling profiling-procmacros v1.0.17
[INFO] [stderr]     Checking calloop v0.14.3
[INFO] [stderr]    Compiling fax_derive v0.2.0
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking profiling v1.0.17
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]     Checking yoke v0.8.1
[INFO] [stderr]     Checking equator v0.4.2
[INFO] [stderr]     Checking gethostname v1.1.0
[INFO] [stderr]     Checking wayland-csd-frame v0.3.0
[INFO] [stderr]     Checking zerovec v0.11.5
[INFO] [stderr]     Checking zerotrie v0.2.3
[INFO] [stderr]     Checking aligned-vec v0.6.4
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]     Checking v_frame v0.3.9
[INFO] [stderr]     Checking x11rb v0.13.2
[INFO] [stderr]     Checking thiserror v2.0.18
[INFO] [stderr]     Checking fax v0.2.6
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]    Compiling zeroize_derive v1.4.3
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]     Checking zerocopy v0.8.39
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]     Checking av1-grain v0.2.5
[INFO] [stderr]    Compiling instability v0.3.11
[INFO] [stderr]     Checking tinystr v0.8.2
[INFO] [stderr]     Checking potential_utf v0.1.4
[INFO] [stderr]     Checking icu_locale_core v2.1.1
[INFO] [stderr]     Checking icu_collections v2.1.1
[INFO] [stderr]     Checking zeroize v1.8.2
[INFO] [stderr]     Checking onig v6.5.1
[INFO] [stderr]     Checking wayland-protocols v0.32.10
[INFO] [stderr]     Checking calloop-wayland-source v0.4.1
[INFO] [stderr]     Checking wayland-cursor v0.31.12
[INFO] [stderr]     Checking xattr v1.6.1
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]     Checking tempfile v3.24.0
[INFO] [stderr]     Checking tar v0.4.44
[INFO] [stderr]     Checking x11-clipboard v0.9.3
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]     Checking assert_fs v1.1.3
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking tokio v1.49.0
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking ratatui v0.29.0
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking icu_properties v2.1.2
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]     Checking zstd v0.13.3
[INFO] [stderr]     Checking chrono v0.4.43
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking plist v1.8.0
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]     Checking tinytemplate v1.2.1
[INFO] [stderr]     Checking insta v1.46.3
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking syntect v5.3.0
[INFO] [stderr]     Checking url v2.5.8
[INFO] [stderr]     Checking half v2.7.1
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking tiff v0.10.3
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking exr v1.74.0
[INFO] [stderr]     Checking ciborium-ll v0.2.2
[INFO] [stderr]     Checking trash v5.2.5
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking ciborium v0.2.2
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking criterion v0.5.1
[INFO] [stderr]     Checking git2 v0.19.0
[INFO] [stderr]     Checking ravif v0.12.0
[INFO] [stderr]     Checking wayland-protocols-experimental v20250721.0.1
[INFO] [stderr]     Checking wayland-protocols-wlr v0.3.10
[INFO] [stderr]     Checking wayland-protocols-misc v0.3.10
[INFO] [stderr]     Checking image v0.25.9
[INFO] [stderr]     Checking smithay-clipboard v0.7.3
[INFO] [stderr]     Checking copypasta v0.10.2
[INFO] [stderr]     Checking ratatui-image v4.2.0
[INFO] [stderr]     Checking vessel v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `ClipboardEntry`
[INFO] [stdout]  --> tests/test_clipboard.rs:2:42
[INFO] [stdout]   |
[INFO] [stdout] 2 | use vessel::core::clipboard::{Clipboard, ClipboardEntry, ClipboardOperation};
[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: `std::path::PathBuf`
[INFO] [stdout]  --> tests/test_file_operations.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `preview`
[INFO] [stdout]   --> tests/test_preview.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 12 |     let preview = ImagePreview;
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_preview`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `preview`
[INFO] [stdout]   --> tests/test_preview.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 39 |     let preview = ArchivePreview;
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_preview`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `preview`
[INFO] [stdout]   --> tests/test_preview.rs:58:9
[INFO] [stdout]    |
[INFO] [stdout] 58 |     let preview = MarkdownPreview;
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_preview`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> benches/directory.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `make_shift_key` is never used
[INFO] [stdout]   --> tests/test_input.rs:17:4
[INFO] [stdout]    |
[INFO] [stdout] 17 | fn make_shift_key(code: KeyCode) -> KeyEvent {
[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 `marks` is never read
[INFO] [stdout]   --> src/app.rs:96:9
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub struct App {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub marks: Marks,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `App` has a derived impl for the trait `Debug`, but this is 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: method `quit` is never used
[INFO] [stdout]    --> src/app.rs:168:12
[INFO] [stdout]     |
[INFO] [stdout] 125 | impl App {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub fn quit(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `save` is never used
[INFO] [stdout]    --> src/config/mod.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout]  66 | impl Config {
[INFO] [stdout]     | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn save(&self, path: &Path) -> anyhow::Result<()> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `icon_dir_open` is never used
[INFO] [stdout]    --> src/config/icons.rs:132:8
[INFO] [stdout]     |
[INFO] [stdout] 132 | pub fn icon_dir_open() -> &'static str {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `icon_dir_closed` is never used
[INFO] [stdout]    --> src/config/icons.rs:137:8
[INFO] [stdout]     |
[INFO] [stdout] 137 | pub fn icon_dir_closed() -> &'static str {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `default_search`, `default_visual`, and `default_command` are never used
[INFO] [stdout]    --> src/config/keymap.rs:192:12
[INFO] [stdout]     |
[INFO] [stdout] 133 | impl KeyMap {
[INFO] [stdout]     | ----------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 192 |     pub fn default_search() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub fn default_visual() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 229 |     pub fn default_command() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_key_sequence` is never used
[INFO] [stdout]    --> src/config/keymap.rs:329:8
[INFO] [stdout]     |
[INFO] [stdout] 329 | pub fn parse_key_sequence(s: &str) -> Vec<KeyBind> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `THEME_NAMES` is never used
[INFO] [stdout]    --> src/config/theme.rs:113:11
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub const THEME_NAMES: &[&str] = &[
[INFO] [stdout]     |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated functions are never used
[INFO] [stdout]    --> src/config/theme.rs:119:12
[INFO] [stdout]     |
[INFO] [stdout] 118 | impl Theme {
[INFO] [stdout]     | ---------- associated functions in this implementation
[INFO] [stdout] 119 |     pub fn by_name(name: &str) -> Self {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 190 |     pub fn tokyo_night() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 247 |     pub fn gruvbox_dark() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 304 |     pub fn nord() -> Self {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 361 |     pub fn dracula() -> Self {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 418 |     pub fn one_dark() -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 475 |     pub fn rose_pine() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 532 |     pub fn kanagawa() -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `cycle_ring`, `is_empty`, and `ring_len` are never used
[INFO] [stdout]   --> src/core/clipboard.rs:52:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl Clipboard {
[INFO] [stdout]    | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn cycle_ring(&mut self) -> Option<&ClipboardEntry> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 68 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     pub fn ring_len(&self) -> usize {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `human_size` and `resolve_icon` are never used
[INFO] [stdout]    --> src/core/entry.rs:124:12
[INFO] [stdout]     |
[INFO] [stdout]  50 | impl FileEntry {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 124 |     pub fn human_size(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn resolve_icon(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/core/filter.rs:16:15
[INFO] [stdout]    |
[INFO] [stdout] 16 |     Extension(String),
[INFO] [stdout]    |     --------- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FilterPredicate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 16 -     Extension(String),
[INFO] [stdout] 16 +     Extension(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/core/filter.rs:18:21
[INFO] [stdout]    |
[INFO] [stdout] 18 |     SizeGreaterThan(u64),
[INFO] [stdout]    |     --------------- ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FilterPredicate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 18 -     SizeGreaterThan(u64),
[INFO] [stdout] 18 +     SizeGreaterThan(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/core/filter.rs:20:18
[INFO] [stdout]    |
[INFO] [stdout] 20 |     SizeLessThan(u64),
[INFO] [stdout]    |     ------------ ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FilterPredicate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 20 -     SizeLessThan(u64),
[INFO] [stdout] 20 +     SizeLessThan(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/core/filter.rs:22:20
[INFO] [stdout]    |
[INFO] [stdout] 22 |     ModifiedWithin(Duration),
[INFO] [stdout]    |     -------------- ^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FilterPredicate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 22 -     ModifiedWithin(Duration),
[INFO] [stdout] 22 +     ModifiedWithin(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/core/filter.rs:24:20
[INFO] [stdout]    |
[INFO] [stdout] 24 |     ModifiedBefore(Duration),
[INFO] [stdout]    |     -------------- ^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FilterPredicate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 24 -     ModifiedBefore(Duration),
[INFO] [stdout] 24 +     ModifiedBefore(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/core/filter.rs:26:17
[INFO] [stdout]    |
[INFO] [stdout] 26 |     GlobPattern(glob::Pattern),
[INFO] [stdout]    |     ----------- ^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FilterPredicate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 26 -     GlobPattern(glob::Pattern),
[INFO] [stdout] 26 +     GlobPattern(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/core/filter.rs:28:18
[INFO] [stdout]    |
[INFO] [stdout] 28 |     NameContains(String),
[INFO] [stdout]    |     ------------ ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FilterPredicate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 28 -     NameContains(String),
[INFO] [stdout] 28 +     NameContains(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `remove`, `clear`, `matches`, and `apply` are never used
[INFO] [stdout]    --> src/core/filter.rs:64:12
[INFO] [stdout]     |
[INFO] [stdout]  63 | impl Filter {
[INFO] [stdout]     | ----------- associated items in this implementation
[INFO] [stdout]  64 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub fn remove(&mut self, index: usize) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 154 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 159 |     pub fn matches(&self, entry: &FileEntry) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 170 |     pub fn apply(&self, entries: &[FileEntry]) -> Vec<usize> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `predicate_matches` is never used
[INFO] [stdout]    --> src/core/filter.rs:180:4
[INFO] [stdout]     |
[INFO] [stdout] 180 | fn predicate_matches(predicate: &FilterPredicate, entry: &FileEntry) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_items` is never used
[INFO] [stdout]    --> src/core/fs.rs:188:14
[INFO] [stdout]     |
[INFO] [stdout] 188 | pub async fn delete_items(paths: &[PathBuf]) -> anyhow::Result<()> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_directory_size` is never used
[INFO] [stdout]    --> src/core/fs.rs:226:14
[INFO] [stdout]     |
[INFO] [stdout] 226 | pub async fn get_directory_size(path: &Path) -> anyhow::Result<u64> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `can_go_back` and `can_go_forward` are never used
[INFO] [stdout]   --> src/core/history.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl NavigationHistory {
[INFO] [stdout]    | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn can_go_back(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub fn can_go_forward(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/core/marks.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl Marks {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub fn set(&mut self, register: char, path: PathBuf) -> anyhow::Result<()> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn get(&self, register: char) -> Option<&PathBuf> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn remove(&mut self, register: char) {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn list(&self) -> Vec<(char, &PathBuf)> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn save(&self, config_path: &Path) -> anyhow::Result<()> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn load(config_path: &Path) -> anyhow::Result<Self> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 68 |     pub fn default_path() -> PathBuf {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchResult` is never constructed
[INFO] [stdout]   --> src/core/search.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct SearchResult {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ContentMatch` is never constructed
[INFO] [stdout]   --> src/core/search.rs:30:12
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub struct ContentMatch {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchEngine` is never constructed
[INFO] [stdout]   --> src/core/search.rs:42:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct SearchEngine {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `search_entries`, `search_recursive`, `search_contents`, and `clear` are never used
[INFO] [stdout]    --> src/core/search.rs:68:12
[INFO] [stdout]     |
[INFO] [stdout]  66 | impl SearchEngine {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout]  67 |     /// Create a new search engine with path-matching configuration.
[INFO] [stdout]  68 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  83 |     pub fn search_entries(&mut self, query: &str, entries: &[FileEntry]) -> Vec<SearchResult> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     pub fn search_recursive(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 180 |     pub fn search_contents(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 243 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_match_range` is never used
[INFO] [stdout]    --> src/core/search.rs:251:4
[INFO] [stdout]     |
[INFO] [stdout] 251 | fn find_match_range(line: &str, query: &str) -> Range<usize> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Descending` is never constructed
[INFO] [stdout]   --> src/core/sort.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub enum SortDirection {
[INFO] [stdout]    |          ------------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 25 |     Descending,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SortDirection` 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 `cycle_method` and `toggle_direction` are never used
[INFO] [stdout]   --> src/core/sort.rs:79:12
[INFO] [stdout]    |
[INFO] [stdout] 46 | impl Sorter {
[INFO] [stdout]    | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 79 |     pub fn cycle_method(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 89 |     pub fn toggle_direction(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TrashRecord` is never constructed
[INFO] [stdout]  --> src/core/trash.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct TrashRecord {
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MAX_HISTORY` is never used
[INFO] [stdout]   --> src/core/trash.rs:15:7
[INFO] [stdout]    |
[INFO] [stdout] 15 | const MAX_HISTORY: usize = 100;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TrashManager` is never constructed
[INFO] [stdout]   --> src/core/trash.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct TrashManager {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `trash_files`, `undo_last`, and `can_undo` are never used
[INFO] [stdout]   --> src/core/trash.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl TrashManager {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 25 |     /// Create a new trash manager.
[INFO] [stdout] 26 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn trash_files(&mut self, paths: &[PathBuf]) -> anyhow::Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60 |     pub fn undo_last(&mut self) -> anyhow::Result<Option<Vec<TrashRecord>>> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn can_undo(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEBOUNCE_MS` is never used
[INFO] [stdout]   --> src/core/watcher.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const DEBOUNCE_MS: u64 = 100;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FsWatcher` is never constructed
[INFO] [stdout]   --> src/core/watcher.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct FsWatcher {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `watch`, `unwatch`, `next_event`, and `current_path` are never used
[INFO] [stdout]    --> src/core/watcher.rs:32:12
[INFO] [stdout]     |
[INFO] [stdout]  29 | impl FsWatcher {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  32 |     pub fn new() -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub fn watch(&mut self, path: &Path) -> anyhow::Result<()> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  88 |     pub fn unwatch(&mut self) -> anyhow::Result<()> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub async fn next_event(&mut self) -> Option<Vec<Event>> {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn current_path(&self) -> Option<&Path> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `FsChange` and `TaskComplete` are never constructed
[INFO] [stdout]   --> src/event.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum AppEvent {
[INFO] [stdout]    |          -------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 18 |     FsChange(Vec<notify::Event>),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     TaskComplete(TaskResult),
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AppEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `id`, `success`, and `message` are never read
[INFO] [stdout]   --> src/event.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct TaskResult {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 28 |     /// Identifier for the task.
[INFO] [stdout] 29 |     pub id: String,
[INFO] [stdout]    |         ^^
[INFO] [stdout] 30 |     /// Whether the task succeeded.
[INFO] [stdout] 31 |     pub success: bool,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 32 |     /// Optional message.
[INFO] [stdout] 33 |     pub message: Option<String>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TaskResult` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `name` is never used
[INFO] [stdout]   --> src/input/mod.rs:16:8
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub trait InputHandler: std::fmt::Debug + Send + Sync {
[INFO] [stdout]    |           ------------ method in this trait
[INFO] [stdout] 15 |     /// Display name of this mode.
[INFO] [stdout] 16 |     fn name(&self) -> &str;
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `open_file_at_line`, `open_files`, `is_inside_nvim`, and `open_in_parent_nvim` are never used
[INFO] [stdout]   --> src/integrations/editor.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl EditorIntegration {
[INFO] [stdout]    | ---------------------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 26 |     pub fn open_file_at_line(path: &Path, line: usize) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn open_files(paths: &[PathBuf]) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn is_inside_nvim() -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 71 |     pub fn open_in_parent_nvim(path: &Path) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_vim_like` is never used
[INFO] [stdout]   --> src/integrations/editor.rs:95:4
[INFO] [stdout]    |
[INFO] [stdout] 95 | fn is_vim_like(editor: &str) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GitInfo` is never constructed
[INFO] [stdout]   --> src/integrations/git.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct GitInfo {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_git_info` is never used
[INFO] [stdout]   --> src/integrations/git.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub fn get_git_info(path: &Path) -> GitInfo {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_file_git_status` is never used
[INFO] [stdout]   --> src/integrations/git.rs:50:8
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub fn get_file_git_status(repo_root: &Path, file_path: &Path) -> Option<GitStatus> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_directory_git_statuses` is never used
[INFO] [stdout]   --> src/integrations/git.rs:61:8
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub fn get_directory_git_statuses(dir: &Path) -> HashMap<PathBuf, GitStatus> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `map_git_status` is never used
[INFO] [stdout]    --> src/integrations/git.rs:107:4
[INFO] [stdout]     |
[INFO] [stdout] 107 | fn map_git_status(status: git2::Status) -> GitStatus {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `fg`, `bg`, and `dim` are never read
[INFO] [stdout]   --> src/preview/mod.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct StyledSpan {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 22 |     pub text: String,
[INFO] [stdout] 23 |     pub fg: Option<(u8, u8, u8)>,
[INFO] [stdout]    |         ^^
[INFO] [stdout] 24 |     pub bg: Option<(u8, u8, u8)>,
[INFO] [stdout]    |         ^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub dim: bool,
[INFO] [stdout]    |         ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `StyledSpan` 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 `0` is never read
[INFO] [stdout]   --> src/preview/mod.rs:90:11
[INFO] [stdout]    |
[INFO] [stdout] 90 |     Image(Vec<u8>),
[INFO] [stdout]    |     ----- ^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PreviewContent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 90 -     Image(Vec<u8>),
[INFO] [stdout] 90 +     Image(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Loading` is never constructed
[INFO] [stdout]   --> src/preview/mod.rs:96:5
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub enum PreviewContent {
[INFO] [stdout]    |          -------------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 96 |     Loading,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PreviewContent` 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 `spans` is never read
[INFO] [stdout]    --> src/preview/mod.rs:112:9
[INFO] [stdout]     |
[INFO] [stdout] 105 | pub struct PreviewLine {
[INFO] [stdout]     |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub spans: Vec<StyledSpan>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `PreviewLine` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Confirm`, `Input`, and `Select` are never constructed
[INFO] [stdout]   --> src/ui/popup.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum PopupKind {
[INFO] [stdout]    |          --------- variants in this enum
[INFO] [stdout] 13 |     Confirm { title: String, message: String },
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 14 |     Input { title: String, prompt: String, value: String },
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 15 |     Select { title: String, items: Vec<String>, selected: usize },
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PopupKind` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `confirm`, `input`, and `select` are never used
[INFO] [stdout]   --> src/ui/popup.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl Popup {
[INFO] [stdout]    | ---------- associated functions in this implementation
[INFO] [stdout] 25 |     pub fn confirm(title: impl Into<String>, message: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn input(title: impl Into<String>, prompt: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn select(title: impl Into<String>, items: Vec<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `scroll_offset` is never read
[INFO] [stdout]   --> src/ui/tab.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Tab {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 19 |     pub scroll_offset: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Tab` 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: struct `Spinner` is never constructed
[INFO] [stdout]   --> src/ui/widgets.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct Spinner {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `tick`, and `current` are never used
[INFO] [stdout]   --> src/ui/widgets.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl Spinner {
[INFO] [stdout]    | ------------ associated items in this implementation
[INFO] [stdout] 26 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     pub fn tick(&mut self) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn current(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `render_spinner` is never used
[INFO] [stdout]   --> src/ui/widgets.rs:46:8
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub fn render_spinner(f: &mut Frame, area: Rect, spinner: &Spinner, label: &str, theme: &Theme) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `render_progress` is never used
[INFO] [stdout]   --> src/ui/widgets.rs:53:8
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub fn render_progress(f: &mut Frame, area: Rect, progress: f64, label: &str, theme: &Theme) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `truncate_to_width` is never used
[INFO] [stdout]    --> src/ui/widgets.rs:132:8
[INFO] [stdout]     |
[INFO] [stdout] 132 | pub fn truncate_to_width(s: &str, max_width: usize) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `marks` is never read
[INFO] [stdout]   --> src/app.rs:96:9
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub struct App {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub marks: Marks,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `App` has a derived impl for the trait `Debug`, but this is 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: method `quit` is never used
[INFO] [stdout]    --> src/app.rs:168:12
[INFO] [stdout]     |
[INFO] [stdout] 125 | impl App {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub fn quit(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `save` is never used
[INFO] [stdout]    --> src/config/mod.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout]  66 | impl Config {
[INFO] [stdout]     | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn save(&self, path: &Path) -> anyhow::Result<()> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `icon_dir_open` is never used
[INFO] [stdout]    --> src/config/icons.rs:132:8
[INFO] [stdout]     |
[INFO] [stdout] 132 | pub fn icon_dir_open() -> &'static str {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `icon_dir_closed` is never used
[INFO] [stdout]    --> src/config/icons.rs:137:8
[INFO] [stdout]     |
[INFO] [stdout] 137 | pub fn icon_dir_closed() -> &'static str {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `default_search`, `default_visual`, and `default_command` are never used
[INFO] [stdout]    --> src/config/keymap.rs:192:12
[INFO] [stdout]     |
[INFO] [stdout] 133 | impl KeyMap {
[INFO] [stdout]     | ----------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 192 |     pub fn default_search() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub fn default_visual() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 229 |     pub fn default_command() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_key_sequence` is never used
[INFO] [stdout]    --> src/config/keymap.rs:329:8
[INFO] [stdout]     |
[INFO] [stdout] 329 | pub fn parse_key_sequence(s: &str) -> Vec<KeyBind> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `THEME_NAMES` is never used
[INFO] [stdout]    --> src/config/theme.rs:113:11
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub const THEME_NAMES: &[&str] = &[
[INFO] [stdout]     |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated functions are never used
[INFO] [stdout]    --> src/config/theme.rs:119:12
[INFO] [stdout]     |
[INFO] [stdout] 118 | impl Theme {
[INFO] [stdout]     | ---------- associated functions in this implementation
[INFO] [stdout] 119 |     pub fn by_name(name: &str) -> Self {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 190 |     pub fn tokyo_night() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 247 |     pub fn gruvbox_dark() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 304 |     pub fn nord() -> Self {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 361 |     pub fn dracula() -> Self {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 418 |     pub fn one_dark() -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 475 |     pub fn rose_pine() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 532 |     pub fn kanagawa() -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `cycle_ring`, `is_empty`, and `ring_len` are never used
[INFO] [stdout]   --> src/core/clipboard.rs:52:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl Clipboard {
[INFO] [stdout]    | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn cycle_ring(&mut self) -> Option<&ClipboardEntry> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 68 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     pub fn ring_len(&self) -> usize {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `human_size` and `resolve_icon` are never used
[INFO] [stdout]    --> src/core/entry.rs:124:12
[INFO] [stdout]     |
[INFO] [stdout]  50 | impl FileEntry {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 124 |     pub fn human_size(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn resolve_icon(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `remove` and `clear` are never used
[INFO] [stdout]    --> src/core/filter.rs:147:12
[INFO] [stdout]     |
[INFO] [stdout]  63 | impl Filter {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub fn remove(&mut self, index: usize) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 154 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_items` is never used
[INFO] [stdout]    --> src/core/fs.rs:188:14
[INFO] [stdout]     |
[INFO] [stdout] 188 | pub async fn delete_items(paths: &[PathBuf]) -> anyhow::Result<()> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_directory_size` is never used
[INFO] [stdout]    --> src/core/fs.rs:226:14
[INFO] [stdout]     |
[INFO] [stdout] 226 | pub async fn get_directory_size(path: &Path) -> anyhow::Result<u64> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `can_go_back` and `can_go_forward` are never used
[INFO] [stdout]   --> src/core/history.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl NavigationHistory {
[INFO] [stdout]    | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn can_go_back(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub fn can_go_forward(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/core/marks.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl Marks {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub fn set(&mut self, register: char, path: PathBuf) -> anyhow::Result<()> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn get(&self, register: char) -> Option<&PathBuf> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn remove(&mut self, register: char) {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn list(&self) -> Vec<(char, &PathBuf)> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn save(&self, config_path: &Path) -> anyhow::Result<()> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn load(config_path: &Path) -> anyhow::Result<Self> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 68 |     pub fn default_path() -> PathBuf {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ContentMatch` is never constructed
[INFO] [stdout]   --> src/core/search.rs:30:12
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub struct ContentMatch {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `search_recursive`, `search_contents`, and `clear` are never used
[INFO] [stdout]    --> src/core/search.rs:119:12
[INFO] [stdout]     |
[INFO] [stdout]  66 | impl SearchEngine {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 119 |     pub fn search_recursive(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 180 |     pub fn search_contents(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 243 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TrashRecord` is never constructed
[INFO] [stdout]  --> src/core/trash.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct TrashRecord {
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MAX_HISTORY` is never used
[INFO] [stdout]   --> src/core/trash.rs:15:7
[INFO] [stdout]    |
[INFO] [stdout] 15 | const MAX_HISTORY: usize = 100;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TrashManager` is never constructed
[INFO] [stdout]   --> src/core/trash.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct TrashManager {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `trash_files`, `undo_last`, and `can_undo` are never used
[INFO] [stdout]   --> src/core/trash.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl TrashManager {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 25 |     /// Create a new trash manager.
[INFO] [stdout] 26 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn trash_files(&mut self, paths: &[PathBuf]) -> anyhow::Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60 |     pub fn undo_last(&mut self) -> anyhow::Result<Option<Vec<TrashRecord>>> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn can_undo(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEBOUNCE_MS` is never used
[INFO] [stdout]   --> src/core/watcher.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const DEBOUNCE_MS: u64 = 100;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FsWatcher` is never constructed
[INFO] [stdout]   --> src/core/watcher.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct FsWatcher {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `watch`, `unwatch`, `next_event`, and `current_path` are never used
[INFO] [stdout]    --> src/core/watcher.rs:32:12
[INFO] [stdout]     |
[INFO] [stdout]  29 | impl FsWatcher {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  32 |     pub fn new() -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub fn watch(&mut self, path: &Path) -> anyhow::Result<()> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  88 |     pub fn unwatch(&mut self) -> anyhow::Result<()> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub async fn next_event(&mut self) -> Option<Vec<Event>> {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn current_path(&self) -> Option<&Path> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `FsChange` and `TaskComplete` are never constructed
[INFO] [stdout]   --> src/event.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum AppEvent {
[INFO] [stdout]    |          -------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 18 |     FsChange(Vec<notify::Event>),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     TaskComplete(TaskResult),
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AppEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `id`, `success`, and `message` are never read
[INFO] [stdout]   --> src/event.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct TaskResult {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 28 |     /// Identifier for the task.
[INFO] [stdout] 29 |     pub id: String,
[INFO] [stdout]    |         ^^
[INFO] [stdout] 30 |     /// Whether the task succeeded.
[INFO] [stdout] 31 |     pub success: bool,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 32 |     /// Optional message.
[INFO] [stdout] 33 |     pub message: Option<String>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TaskResult` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `name` is never used
[INFO] [stdout]   --> src/input/mod.rs:16:8
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub trait InputHandler: std::fmt::Debug + Send + Sync {
[INFO] [stdout]    |           ------------ method in this trait
[INFO] [stdout] 15 |     /// Display name of this mode.
[INFO] [stdout] 16 |     fn name(&self) -> &str;
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `open_file_at_line`, `open_files`, `is_inside_nvim`, and `open_in_parent_nvim` are never used
[INFO] [stdout]   --> src/integrations/editor.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl EditorIntegration {
[INFO] [stdout]    | ---------------------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 26 |     pub fn open_file_at_line(path: &Path, line: usize) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn open_files(paths: &[PathBuf]) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn is_inside_nvim() -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 71 |     pub fn open_in_parent_nvim(path: &Path) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_vim_like` is never used
[INFO] [stdout]   --> src/integrations/editor.rs:95:4
[INFO] [stdout]    |
[INFO] [stdout] 95 | fn is_vim_like(editor: &str) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GitInfo` is never constructed
[INFO] [stdout]   --> src/integrations/git.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct GitInfo {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_git_info` is never used
[INFO] [stdout]   --> src/integrations/git.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub fn get_git_info(path: &Path) -> GitInfo {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_file_git_status` is never used
[INFO] [stdout]   --> src/integrations/git.rs:50:8
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub fn get_file_git_status(repo_root: &Path, file_path: &Path) -> Option<GitStatus> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_directory_git_statuses` is never used
[INFO] [stdout]   --> src/integrations/git.rs:61:8
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub fn get_directory_git_statuses(dir: &Path) -> HashMap<PathBuf, GitStatus> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `map_git_status` is never used
[INFO] [stdout]    --> src/integrations/git.rs:107:4
[INFO] [stdout]     |
[INFO] [stdout] 107 | fn map_git_status(status: git2::Status) -> GitStatus {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `fg`, `bg`, and `dim` are never read
[INFO] [stdout]   --> src/preview/mod.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct StyledSpan {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 22 |     pub text: String,
[INFO] [stdout] 23 |     pub fg: Option<(u8, u8, u8)>,
[INFO] [stdout]    |         ^^
[INFO] [stdout] 24 |     pub bg: Option<(u8, u8, u8)>,
[INFO] [stdout]    |         ^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub dim: bool,
[INFO] [stdout]    |         ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `StyledSpan` 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 `0` is never read
[INFO] [stdout]   --> src/preview/mod.rs:90:11
[INFO] [stdout]    |
[INFO] [stdout] 90 |     Image(Vec<u8>),
[INFO] [stdout]    |     ----- ^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PreviewContent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 90 -     Image(Vec<u8>),
[INFO] [stdout] 90 +     Image(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Loading` is never constructed
[INFO] [stdout]   --> src/preview/mod.rs:96:5
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub enum PreviewContent {
[INFO] [stdout]    |          -------------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 96 |     Loading,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PreviewContent` 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 `spans` is never read
[INFO] [stdout]    --> src/preview/mod.rs:112:9
[INFO] [stdout]     |
[INFO] [stdout] 105 | pub struct PreviewLine {
[INFO] [stdout]     |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub spans: Vec<StyledSpan>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `PreviewLine` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Confirm`, `Input`, and `Select` are never constructed
[INFO] [stdout]   --> src/ui/popup.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum PopupKind {
[INFO] [stdout]    |          --------- variants in this enum
[INFO] [stdout] 13 |     Confirm { title: String, message: String },
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 14 |     Input { title: String, prompt: String, value: String },
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 15 |     Select { title: String, items: Vec<String>, selected: usize },
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PopupKind` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `confirm`, `input`, and `select` are never used
[INFO] [stdout]   --> src/ui/popup.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl Popup {
[INFO] [stdout]    | ---------- associated functions in this implementation
[INFO] [stdout] 25 |     pub fn confirm(title: impl Into<String>, message: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn input(title: impl Into<String>, prompt: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn select(title: impl Into<String>, items: Vec<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `scroll_offset` is never read
[INFO] [stdout]   --> src/ui/tab.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Tab {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 19 |     pub scroll_offset: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Tab` 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: struct `Spinner` is never constructed
[INFO] [stdout]   --> src/ui/widgets.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct Spinner {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `tick`, and `current` are never used
[INFO] [stdout]   --> src/ui/widgets.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl Spinner {
[INFO] [stdout]    | ------------ associated items in this implementation
[INFO] [stdout] 26 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     pub fn tick(&mut self) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn current(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `render_spinner` is never used
[INFO] [stdout]   --> src/ui/widgets.rs:46:8
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub fn render_spinner(f: &mut Frame, area: Rect, spinner: &Spinner, label: &str, theme: &Theme) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `render_progress` is never used
[INFO] [stdout]   --> src/ui/widgets.rs:53:8
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub fn render_progress(f: &mut Frame, area: Rect, progress: f64, label: &str, theme: &Theme) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `truncate_to_width` is never used
[INFO] [stdout]    --> src/ui/widgets.rs:132:8
[INFO] [stdout]     |
[INFO] [stdout] 132 | pub fn truncate_to_width(s: &str, max_width: usize) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 31s
[INFO] running `Command { std: "docker" "inspect" "514dcf0bc03fba5cc09244f462acd79f63ce094c384a3ebb0ce94006c77a1113", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "514dcf0bc03fba5cc09244f462acd79f63ce094c384a3ebb0ce94006c77a1113", kill_on_drop: false }`
[INFO] [stdout] 514dcf0bc03fba5cc09244f462acd79f63ce094c384a3ebb0ce94006c77a1113
