[INFO] fetching crate pocket-cli 1.0.2...
[INFO] testing pocket-cli-1.0.2 against 1.91.0 for beta-1.92-2
[INFO] extracting crate pocket-cli 1.0.2 into /workspace/builds/worker-0-tc1/source
[INFO] started tweaking crates.io crate pocket-cli 1.0.2
[INFO] finished tweaking crates.io crate pocket-cli 1.0.2
[INFO] tweaked toml for crates.io crate pocket-cli 1.0.2 written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate pocket-cli 1.0.2 on toolchain 1.91.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.91.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate pocket-cli 1.0.2 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.91.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded base64ct v1.7.1
[INFO] [stderr]   Downloaded safetensors v0.3.3
[INFO] [stderr]   Downloaded tempfile v3.18.0
[INFO] [stderr]   Downloaded hostname v0.4.0
[INFO] [stderr]   Downloaded owo-colors v4.2.0
[INFO] [stderr]   Downloaded rstest v0.25.0
[INFO] [stderr]   Downloaded rstest_macros v0.25.0
[INFO] [stderr]   Downloaded unicode-normalization-alignments v0.1.12
[INFO] [stderr]   Downloaded winnow v0.7.3
[INFO] [stderr]   Downloaded rust_tokenizers v8.1.1
[INFO] [stderr]   Downloaded cached-path v0.6.1
[INFO] [stderr]   Downloaded torch-sys v0.13.0
[INFO] [stderr]   Downloaded rustix v1.0.2
[INFO] [stderr]   Downloaded rust-bert v0.21.0
[INFO] [stderr]   Downloaded zstd-sys v2.0.14+zstd.1.5.7
[INFO] [stderr]   Downloaded tokio v1.44.0
[INFO] [stderr]   Downloaded tch v0.13.0
[INFO] [stderr]   Downloaded linux-raw-sys v0.9.2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] d87d00c23f6a80dc4889900251ae07fdad3643ba71024d0ac5a247dcf02346d8
[INFO] running `Command { std: "docker" "start" "-a" "d87d00c23f6a80dc4889900251ae07fdad3643ba71024d0ac5a247dcf02346d8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "d87d00c23f6a80dc4889900251ae07fdad3643ba71024d0ac5a247dcf02346d8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d87d00c23f6a80dc4889900251ae07fdad3643ba71024d0ac5a247dcf02346d8", kill_on_drop: false }`
[INFO] [stdout] d87d00c23f6a80dc4889900251ae07fdad3643ba71024d0ac5a247dcf02346d8
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] e72e9a8e6142630d016781238695e73358ab8ada16b68787a3d1381bf5a74bc3
[INFO] running `Command { std: "docker" "start" "-a" "e72e9a8e6142630d016781238695e73358ab8ada16b68787a3d1381bf5a74bc3", kill_on_drop: false }`
[INFO] [stderr]    Compiling getrandom v0.3.1
[INFO] [stderr]    Compiling smallvec v1.14.0
[INFO] [stderr]    Compiling once_cell v1.21.0
[INFO] [stderr]    Compiling rustix v1.0.2
[INFO] [stderr]    Compiling portable-atomic v1.11.0
[INFO] [stderr]    Compiling linux-raw-sys v0.9.2
[INFO] [stderr]    Compiling bitflags v2.9.0
[INFO] [stderr]    Compiling indexmap v2.8.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling owo-colors v4.2.0
[INFO] [stderr]    Compiling toml_datetime v0.6.8
[INFO] [stderr]    Compiling serde_spanned v0.6.8
[INFO] [stderr]    Compiling winnow v0.7.3
[INFO] [stderr]    Compiling option-ext v0.2.0
[INFO] [stderr]    Compiling percent-encoding v2.3.1
[INFO] [stderr]    Compiling icu_locid_transform v1.5.0
[INFO] [stderr]    Compiling console v0.15.11
[INFO] [stderr]    Compiling clap_builder v4.5.32
[INFO] [stderr]    Compiling dirs-sys v0.5.0
[INFO] [stderr]    Compiling clap_derive v4.5.32
[INFO] [stderr]    Compiling form_urlencoded v1.2.1
[INFO] [stderr]    Compiling is-terminal v0.4.16
[INFO] [stderr]    Compiling shell-words v1.1.0
[INFO] [stderr]    Compiling humantime v2.2.0
[INFO] [stderr]    Compiling log v0.4.26
[INFO] [stderr]    Compiling iana-time-zone v0.1.61
[INFO] [stderr]    Compiling uuid v1.15.1
[INFO] [stderr]    Compiling dirs v6.0.0
[INFO] [stderr]    Compiling walkdir v2.5.0
[INFO] [stderr]    Compiling chrono v0.4.40
[INFO] [stderr]    Compiling env_logger v0.10.2
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling rust-stemmers v1.2.0
[INFO] [stderr]    Compiling hostname v0.4.0
[INFO] [stderr]    Compiling similar v2.7.0
[INFO] [stderr]    Compiling indicatif v0.17.11
[INFO] [stderr]    Compiling icu_properties v1.5.1
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling toml_edit v0.22.24
[INFO] [stderr]    Compiling tempfile v3.18.0
[INFO] [stderr]    Compiling dialoguer v0.11.0
[INFO] [stderr]    Compiling clap v4.5.32
[INFO] [stderr]    Compiling icu_normalizer v1.5.0
[INFO] [stderr]    Compiling idna_adapter v1.2.0
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling toml v0.8.20
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling pocket-cli v1.0.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `crate::storage::StorageManager`
[INFO] [stdout]   --> src/cards/backup.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::storage::StorageManager;
[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: `ContentType`
[INFO] [stdout]  --> src/cards/snippet.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::{Entry, ContentType};
[INFO] [stdout]   |                            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/cards/core.rs:9:14
[INFO] [stdout]   |
[INFO] [stdout] 9 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `colored::Colorize`
[INFO] [stdout]  --> src/cards/blend.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use colored::Colorize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dirs`
[INFO] [stdout]  --> src/cards/blend.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use dirs;
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PathBuf`
[INFO] [stdout]   --> src/cards/mod.rs:12:23
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `File`
[INFO] [stdout]   --> src/cards/mod.rs:13:21
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::fs::{self, File};
[INFO] [stdout]    |                     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Read` and `Write`
[INFO] [stdout]   --> src/cards/mod.rs:14:15
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::io::{Read, Write};
[INFO] [stdout]    |               ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Context`
[INFO] [stdout]   --> src/cards/mod.rs:16:22
[INFO] [stdout]    |
[INFO] [stdout] 16 | use anyhow::{Result, Context, anyhow, bail};
[INFO] [stdout]    |                      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Args`
[INFO] [stdout]  --> src/cli/mod.rs:1:32
[INFO] [stdout]   |
[INFO] [stdout] 1 | use clap::{Parser, Subcommand, Args, ArgAction};
[INFO] [stdout]   |                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> src/cli/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `IntoPocketError`
[INFO] [stdout]  --> src/cli/handler.rs:3:48
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::errors::{PocketError, PocketResult, IntoPocketError};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error`, `info`, and `warn`
[INFO] [stdout]  --> src/cli/handler.rs:5:18
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{debug, info, warn, error, LevelFilter};
[INFO] [stdout]   |                  ^^^^  ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `exact`
[INFO] [stdout]   --> src/cards/core.rs:61:77
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn search(&self, query: &str, limit: usize, backpack: Option<&str>, exact: bool) -> Result<Vec<Entry>> {
[INFO] [stdout]    |                                                                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_exact`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entry`
[INFO] [stdout]   --> src/cards/core.rs:76:14
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let (entry, content) = storage.load_entry(entry_id, None)?;
[INFO] [stdout]    |              ^^^^^ help: if this is intentional, prefix it with an underscore: `_entry`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cmd`
[INFO] [stdout]    --> src/cli/handler.rs:206:32
[INFO] [stdout]     |
[INFO] [stdout] 206 |             } else if let Some(cmd) = command {
[INFO] [stdout]     |                                ^^^ help: if this is intentional, prefix it with an underscore: `_cmd`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `workflow`
[INFO] [stdout]    --> src/cli/handler.rs:217:26
[INFO] [stdout]     |
[INFO] [stdout] 217 |         Commands::Lint { workflow } => {
[INFO] [stdout]     |                          ^^^^^^^^ help: try ignoring the field: `workflow: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/cli/handler.rs:223:36
[INFO] [stdout]     |
[INFO] [stdout] 223 |         Commands::DeleteWorkflow { name } => {
[INFO] [stdout]     |                                    ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/cli/handler.rs:253:29
[INFO] [stdout]     |
[INFO] [stdout] 253 |         Commands::Execute { name, args } => {
[INFO] [stdout]     |                             ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]    --> src/cli/handler.rs:253:35
[INFO] [stdout]     |
[INFO] [stdout] 253 |         Commands::Execute { name, args } => {
[INFO] [stdout]     |                                   ^^^^ help: try ignoring the field: `args: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/utils/clipboard.rs:120:13
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let mut xclip_child = Command::new("xclip")
[INFO] [stdout]     |             ----^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/utils/clipboard.rs:138:13
[INFO] [stdout]     |
[INFO] [stdout] 138 |         let mut wl_copy_child = Command::new("wl-copy")
[INFO] [stdout]     |             ----^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `register_card` is never used
[INFO] [stdout]    --> src/cards/mod.rs:254:8
[INFO] [stdout]     |
[INFO] [stdout]  85 | impl CardManager {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 254 |     fn register_card(&mut self, card: Box<dyn Card>) -> Result<()> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlaceholderCard` is never constructed
[INFO] [stdout]    --> src/cards/mod.rs:772:8
[INFO] [stdout]     |
[INFO] [stdout] 772 | struct PlaceholderCard {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/cards/mod.rs:779:8
[INFO] [stdout]     |
[INFO] [stdout] 778 | impl PlaceholderCard {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] 779 |     fn new(name: String) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_dir` is never read
[INFO] [stdout]   --> src/cards/snippet.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct SnippetCard {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 24 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_dir` is never read
[INFO] [stdout]   --> src/cards/core.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct CoreCard {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 26 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_dir` is never read
[INFO] [stdout]   --> src/cards/blend.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct BlendCard {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 26 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::storage::StorageManager`
[INFO] [stdout]   --> src/cards/backup.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::storage::StorageManager;
[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: `ContentType`
[INFO] [stdout]  --> src/cards/snippet.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::{Entry, ContentType};
[INFO] [stdout]   |                            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/cards/core.rs:9:14
[INFO] [stdout]   |
[INFO] [stdout] 9 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `colored::Colorize`
[INFO] [stdout]  --> src/cards/blend.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use colored::Colorize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dirs`
[INFO] [stdout]  --> src/cards/blend.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use dirs;
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PathBuf`
[INFO] [stdout]   --> src/cards/mod.rs:12:23
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `File`
[INFO] [stdout]   --> src/cards/mod.rs:13:21
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::fs::{self, File};
[INFO] [stdout]    |                     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Read` and `Write`
[INFO] [stdout]   --> src/cards/mod.rs:14:15
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::io::{Read, Write};
[INFO] [stdout]    |               ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Context`
[INFO] [stdout]   --> src/cards/mod.rs:16:22
[INFO] [stdout]    |
[INFO] [stdout] 16 | use anyhow::{Result, Context, anyhow, bail};
[INFO] [stdout]    |                      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Args`
[INFO] [stdout]  --> src/cli/mod.rs:1:32
[INFO] [stdout]   |
[INFO] [stdout] 1 | use clap::{Parser, Subcommand, Args, ArgAction};
[INFO] [stdout]   |                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> src/cli/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `IntoPocketError`
[INFO] [stdout]  --> src/cli/handler.rs:3:48
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::errors::{PocketError, PocketResult, IntoPocketError};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error`, `info`, and `warn`
[INFO] [stdout]  --> src/cli/handler.rs:5:18
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{debug, info, warn, error, LevelFilter};
[INFO] [stdout]   |                  ^^^^  ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `write_clipboard`
[INFO] [stdout]   --> src/utils/mod.rs:21:37
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub use clipboard::{read_clipboard, write_clipboard};
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `IntoAnyhow` and `PocketError`
[INFO] [stdout]   --> src/main.rs:14:14
[INFO] [stdout]    |
[INFO] [stdout] 14 | use errors::{PocketError, PocketResult, IntoAnyhow};
[INFO] [stdout]    |              ^^^^^^^^^^^                ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `exact`
[INFO] [stdout]   --> src/cards/core.rs:61:77
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn search(&self, query: &str, limit: usize, backpack: Option<&str>, exact: bool) -> Result<Vec<Entry>> {
[INFO] [stdout]    |                                                                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_exact`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entry`
[INFO] [stdout]   --> src/cards/core.rs:76:14
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let (entry, content) = storage.load_entry(entry_id, None)?;
[INFO] [stdout]    |              ^^^^^ help: if this is intentional, prefix it with an underscore: `_entry`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cmd`
[INFO] [stdout]    --> src/cli/handler.rs:206:32
[INFO] [stdout]     |
[INFO] [stdout] 206 |             } else if let Some(cmd) = command {
[INFO] [stdout]     |                                ^^^ help: if this is intentional, prefix it with an underscore: `_cmd`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `workflow`
[INFO] [stdout]    --> src/cli/handler.rs:217:26
[INFO] [stdout]     |
[INFO] [stdout] 217 |         Commands::Lint { workflow } => {
[INFO] [stdout]     |                          ^^^^^^^^ help: try ignoring the field: `workflow: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/cli/handler.rs:223:36
[INFO] [stdout]     |
[INFO] [stdout] 223 |         Commands::DeleteWorkflow { name } => {
[INFO] [stdout]     |                                    ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/cli/handler.rs:253:29
[INFO] [stdout]     |
[INFO] [stdout] 253 |         Commands::Execute { name, args } => {
[INFO] [stdout]     |                             ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]    --> src/cli/handler.rs:253:35
[INFO] [stdout]     |
[INFO] [stdout] 253 |         Commands::Execute { name, args } => {
[INFO] [stdout]     |                                   ^^^^ help: try ignoring the field: `args: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/utils/clipboard.rs:120:13
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let mut xclip_child = Command::new("xclip")
[INFO] [stdout]     |             ----^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/utils/clipboard.rs:138:13
[INFO] [stdout]     |
[INFO] [stdout] 138 |         let mut wl_copy_child = Command::new("wl-copy")
[INFO] [stdout]     |             ----^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `description` and `initialize` are never used
[INFO] [stdout]   --> src/cards/mod.rs:28:8
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub trait Card: Send + Sync {
[INFO] [stdout]    |           ---- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 28 |     fn description(&self) -> &str;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     fn initialize(&mut self, config: &CardConfig) -> Result<()>;
[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 `register_card` and `card_exists` are never used
[INFO] [stdout]    --> src/cards/mod.rs:254:8
[INFO] [stdout]     |
[INFO] [stdout]  85 | impl CardManager {
[INFO] [stdout]     | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 254 |     fn register_card(&mut self, card: Box<dyn Card>) -> Result<()> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 376 |     pub fn card_exists(&self, name: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlaceholderCard` is never constructed
[INFO] [stdout]    --> src/cards/mod.rs:772:8
[INFO] [stdout]     |
[INFO] [stdout] 772 | struct PlaceholderCard {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/cards/mod.rs:779:8
[INFO] [stdout]     |
[INFO] [stdout] 778 | impl PlaceholderCard {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] 779 |     fn new(name: String) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `description` is never read
[INFO] [stdout]   --> src/cards/backup.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub struct BackupCard {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 79 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `description` and `data_dir` are never read
[INFO] [stdout]   --> src/cards/snippet.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct SnippetCard {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 18 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `description` and `data_dir` are never read
[INFO] [stdout]   --> src/cards/core.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct CoreCard {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 20 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `description` and `data_dir` are never read
[INFO] [stdout]   --> src/cards/blend.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct BlendCard {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 20 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `CONFIG` is never used
[INFO] [stdout]   --> src/config.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | static CONFIG: OnceCell<Arc<Mutex<ConfigManager>>> = OnceCell::new();
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Config` is never constructed
[INFO] [stdout]   --> src/config.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Config {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_config_version` is never used
[INFO] [stdout]   --> src/config.rs:53:4
[INFO] [stdout]    |
[INFO] [stdout] 53 | fn default_config_version() -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_content_type` is never used
[INFO] [stdout]   --> src/config.rs:57:4
[INFO] [stdout]    |
[INFO] [stdout] 57 | fn default_content_type() -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_log_level` is never used
[INFO] [stdout]   --> src/config.rs:61:4
[INFO] [stdout]    |
[INFO] [stdout] 61 | fn default_log_level() -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_max_search_results` is never used
[INFO] [stdout]   --> src/config.rs:65:4
[INFO] [stdout]    |
[INFO] [stdout] 65 | fn default_max_search_results() -> usize {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_search_algorithm` is never used
[INFO] [stdout]   --> src/config.rs:69:4
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn default_search_algorithm() -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ConfigManager` is never constructed
[INFO] [stdout]   --> src/config.rs:91:12
[INFO] [stdout]    |
[INFO] [stdout] 91 | pub struct ConfigManager {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/config.rs:107:12
[INFO] [stdout]     |
[INFO] [stdout] 105 | impl ConfigManager {
[INFO] [stdout]     | ------------------ associated items in this implementation
[INFO] [stdout] 106 |     /// Create a new configuration manager
[INFO] [stdout] 107 |     pub fn new(data_dir: impl AsRef<Path>) -> PocketResult<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 151 |     pub fn get_config(&self) -> Config {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn update_config(&mut self, config: Config) -> PocketResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 163 |     pub fn get_card_config(&self, card_name: &str) -> Option<serde_json::Value> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub fn set_card_config(&mut self, card_name: &str, config: serde_json::Value) -> PocketResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 175 |     pub fn save(&self) -> PocketResult<()> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn get_data_dir(&self) -> PathBuf {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn get_hooks_dir(&self) -> PathBuf {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |     pub fn get_bin_dir(&self) -> PathBuf {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `init` is never used
[INFO] [stdout]    --> src/config.rs:227:8
[INFO] [stdout]     |
[INFO] [stdout] 227 | pub fn init(data_dir: impl AsRef<Path>) -> PocketResult<()> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get` is never used
[INFO] [stdout]    --> src/config.rs:234:8
[INFO] [stdout]     |
[INFO] [stdout] 234 | pub fn get() -> PocketResult<Arc<Mutex<ConfigManager>>> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_config` is never used
[INFO] [stdout]    --> src/config.rs:242:8
[INFO] [stdout]     |
[INFO] [stdout] 242 | pub fn get_config() -> PocketResult<Config> {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `save` is never used
[INFO] [stdout]    --> src/config.rs:250:8
[INFO] [stdout]     |
[INFO] [stdout] 250 | pub fn save() -> PocketResult<()> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/errors.rs:9:5
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub enum PocketError {
[INFO] [stdout]    |          ----------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout]  9 |     Storage(String),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 13 |     Entry(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 25 |     Hook(String),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |     File {
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     Search(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     Canceled,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     PermissionDenied(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PocketError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `IntoAnyhow` is never used
[INFO] [stdout]   --> src/errors.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub trait IntoAnyhow<T> {
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `IntoPocketError` is never used
[INFO] [stdout]   --> src/errors.rs:71:11
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub trait IntoPocketError<T> {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cmd_text` is never used
[INFO] [stdout]   --> src/logging.rs:78:8
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub fn cmd_text(cmd: &str, args: &[&str]) -> ColoredString {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `value` is never used
[INFO] [stdout]   --> src/logging.rs:93:8
[INFO] [stdout]    |
[INFO] [stdout] 93 | pub fn value(text: &str) -> ColoredString {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `path` is never used
[INFO] [stdout]   --> src/logging.rs:98:8
[INFO] [stdout]    |
[INFO] [stdout] 98 | pub fn path(text: &str) -> ColoredString {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `id` is never used
[INFO] [stdout]    --> src/logging.rs:103:8
[INFO] [stdout]     |
[INFO] [stdout] 103 | pub fn id(text: &str) -> ColoredString {
[INFO] [stdout]     |        ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Workflow` is never constructed
[INFO] [stdout]   --> src/models/mod.rs:60:12
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct Workflow {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WorkflowCommand` is never constructed
[INFO] [stdout]   --> src/models/mod.rs:73:12
[INFO] [stdout]    |
[INFO] [stdout] 73 | pub struct WorkflowCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/models/mod.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 108 | impl Backpack {
[INFO] [stdout]     | ------------- associated function in this implementation
[INFO] [stdout] 109 |     /// Create a new backpack
[INFO] [stdout] 110 |     pub fn new(name: String, description: Option<String>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/models/mod.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout] 119 | impl Workflow {
[INFO] [stdout]     | ------------- associated function in this implementation
[INFO] [stdout] 120 |     /// Create a new workflow
[INFO] [stdout] 121 |     pub fn new(name: String, commands: Vec<WorkflowCommand>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `parse` is never used
[INFO] [stdout]    --> src/models/mod.rs:132:12
[INFO] [stdout]     |
[INFO] [stdout] 130 | impl WorkflowCommand {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] 131 |     /// Parse a command string into a WorkflowCommand
[INFO] [stdout] 132 |     pub fn parse(command_str: &str) -> Result<Self> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchResult` is never constructed
[INFO] [stdout]   --> src/search/mod.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct SearchResult {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchEngine` is never constructed
[INFO] [stdout]   --> src/search/mod.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct SearchEngine {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchIndex` is never constructed
[INFO] [stdout]   --> src/search/mod.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 39 | struct SearchIndex {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/search/mod.rs:70:12
[INFO] [stdout]     |
[INFO] [stdout]  68 | impl SearchEngine {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout]  69 |     /// Create a new search engine
[INFO] [stdout]  70 |     pub fn new(storage: StorageManager) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn search(&self, query: &str, limit: usize, backpack: Option<&str>, algorithm: SearchAlgorithm) -> Result<Vec<SearchResult>> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     fn bm25_search(&self, query: &str, index: &SearchIndex, backpack_filter: Option<&str>) -> Result<Vec<SearchResult>> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 232 |     fn fuzzy_search(&self, query: &str, _index: &SearchIndex, backpack_filter: Option<&str>) -> Result<Vec<SearchResult>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 284 |     fn calculate_fuzzy_similarity(&self, query: &str, content: &str) -> f64 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 305 |     fn generate_ngrams(&self, text: &str, n: usize) -> HashSet<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 324 |     fn tokenize(&self, text: &str) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 334 |     fn preprocess_text(&self, text: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 347 |     fn generate_highlights(&self, results: Vec<SearchResult>, query: &str) -> Result<Vec<SearchResult>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 408 |     fn get_context_snippet(&self, content: &str, position: usize, length: usize) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `new`, `tokenize_content`, and `build` are never used
[INFO] [stdout]    --> src/search/mod.rs:451:8
[INFO] [stdout]     |
[INFO] [stdout] 449 | impl SearchIndex {
[INFO] [stdout]     | ---------------- associated functions in this implementation
[INFO] [stdout] 450 |     /// Create a new empty search index
[INFO] [stdout] 451 |     fn new() -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 466 |     fn tokenize_content(text: &str) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 491 |     fn build(index: Arc<RwLock<SearchIndex>>, storage: StorageManager) -> Result<()> {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/storage/mod.rs:36:12
[INFO] [stdout]     |
[INFO] [stdout]  14 | impl StorageManager {
[INFO] [stdout]     | ------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  36 |     pub fn get_workflows_dir(&self) -> Result<PathBuf> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  71 |     fn get_workflow_path(&self, name: &str) -> PathBuf {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn list_backpacks(&self) -> Result<Vec<Backpack>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn determine_content_type(path: &Path) -> ContentType {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 239 |     pub fn save_workflow(&self, workflow: &Workflow) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 258 |     pub fn load_workflow(&self, name: &str) -> Result<Workflow> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 268 |     pub fn delete_workflow(&self, name: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 279 |     pub fn list_workflows(&self) -> Result<Vec<Workflow>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 335 |     pub fn load_entry_content(&self, id: &str, backpack: Option<&str>) -> Result<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_file_content` is never used
[INFO] [stdout]   --> src/utils/mod.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn read_file_content(path: &Path) -> Result<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_stdin_content` is never used
[INFO] [stdout]   --> src/utils/mod.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub fn read_stdin_content() -> Result<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `open_editor_with_type` is never used
[INFO] [stdout]   --> src/utils/mod.rs:76:8
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub fn open_editor_with_type(content_type: ContentType, initial_content: Option<&str>) -> Result<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `edit_entry` is never used
[INFO] [stdout]    --> src/utils/mod.rs:160:8
[INFO] [stdout]     |
[INFO] [stdout] 160 | pub fn edit_entry(id: &str, content: &str, content_type: ContentType) -> Result<String> {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `select` is never used
[INFO] [stdout]    --> src/utils/mod.rs:321:8
[INFO] [stdout]     |
[INFO] [stdout] 321 | pub fn select<T>(message: &str, options: &[T]) -> Result<usize>
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_with_tag` is never used
[INFO] [stdout]    --> src/utils/mod.rs:333:8
[INFO] [stdout]     |
[INFO] [stdout] 333 | pub fn format_with_tag(tag: &str, content: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `truncate_string` is never used
[INFO] [stdout]    --> src/utils/mod.rs:338:8
[INFO] [stdout]     |
[INFO] [stdout] 338 | pub fn truncate_string(s: &str, max_len: usize) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `first_line` is never used
[INFO] [stdout]    --> src/utils/mod.rs:349:8
[INFO] [stdout]     |
[INFO] [stdout] 349 | pub fn first_line(s: &str) -> &str {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_title_from_content` is never used
[INFO] [stdout]    --> src/utils/mod.rs:354:8
[INFO] [stdout]     |
[INFO] [stdout] 354 | pub fn get_title_from_content(content: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_clipboard` is never used
[INFO] [stdout]   --> src/utils/clipboard.rs:74:8
[INFO] [stdout]    |
[INFO] [stdout] 74 | pub fn write_clipboard(content: &str) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VERSION_LETTER` is never used
[INFO] [stdout]  --> src/version.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub const VERSION_LETTER: &str = "v-pocket-R1";
[INFO] [stdout]   |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VERSION_DATE` is never used
[INFO] [stdout]   --> src/version.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub const VERSION_DATE: &str = "04012025";
[INFO] [stdout]    |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VERSION_STRING` is never used
[INFO] [stdout]   --> src/version.rs:13:11
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub const VERSION_STRING: &str = "Pocket v-pocket-R1 (03172025 - Core Implementations)";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `COMPATIBILITY` is never used
[INFO] [stdout]   --> src/version.rs:16:11
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub const COMPATIBILITY: Option<&str> = Some("");
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `AUTHOR` is never used
[INFO] [stdout]   --> src/version.rs:18:11
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub const AUTHOR: &str = "frgmt0 (j)";
[INFO] [stdout]    |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_version` is never used
[INFO] [stdout]   --> src/version.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub fn get_version() -> Version {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Stability` is never used
[INFO] [stdout]   --> src/version.rs:34:10
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub enum Stability {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Version` is never constructed
[INFO] [stdout]   --> src/version.rs:60:12
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct Version {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 26.31s
[INFO] running `Command { std: "docker" "inspect" "e72e9a8e6142630d016781238695e73358ab8ada16b68787a3d1381bf5a74bc3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e72e9a8e6142630d016781238695e73358ab8ada16b68787a3d1381bf5a74bc3", kill_on_drop: false }`
[INFO] [stdout] e72e9a8e6142630d016781238695e73358ab8ada16b68787a3d1381bf5a74bc3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 276bd2ff8330591200f4bfe24b5f4bd3f74b636839502c8414eb584ff6224f6f
[INFO] running `Command { std: "docker" "start" "-a" "276bd2ff8330591200f4bfe24b5f4bd3f74b636839502c8414eb584ff6224f6f", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.100
[INFO] [stderr]    Compiling zerocopy v0.8.23
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling semver v1.0.26
[INFO] [stderr]    Compiling getrandom v0.3.1
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling bstr v1.11.3
[INFO] [stderr]    Compiling toml_datetime v0.6.8
[INFO] [stderr]    Compiling predicates-core v1.0.9
[INFO] [stderr]    Compiling half v2.4.1
[INFO] [stderr]    Compiling termtree v0.5.1
[INFO] [stderr]    Compiling difflib v0.4.0
[INFO] [stderr]    Compiling ciborium-io v0.2.2
[INFO] [stderr]    Compiling plotters-backend v0.3.7
[INFO] [stderr]    Compiling mockall_derive v0.13.1
[INFO] [stderr]    Compiling normalize-line-endings v0.3.0
[INFO] [stderr]    Compiling tempfile v3.18.0
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling predicates-tree v1.0.12
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling wait-timeout v0.2.1
[INFO] [stderr]    Compiling toml_edit v0.22.24
[INFO] [stderr]    Compiling ciborium-ll v0.2.2
[INFO] [stderr]    Compiling plotters-svg v0.3.7
[INFO] [stderr]    Compiling bit-vec v0.8.0
[INFO] [stderr]    Compiling cast v0.3.0
[INFO] [stderr]    Compiling relative-path v1.9.3
[INFO] [stderr]    Compiling globset v0.4.16
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]    Compiling env_logger v0.10.2
[INFO] [stderr]    Compiling rusty-fork v0.3.0
[INFO] [stderr]    Compiling rand_xorshift v0.3.0
[INFO] [stderr]    Compiling anes v0.1.6
[INFO] [stderr]    Compiling unarray v0.1.4
[INFO] [stderr]    Compiling bit-set v0.8.0
[INFO] [stderr]    Compiling fragile v2.0.0
[INFO] [stderr]    Compiling downcast v0.11.0
[INFO] [stderr]    Compiling oorandom v11.1.5
[INFO] [stderr]    Compiling rstest_macros v0.25.0
[INFO] [stderr]    Compiling ignore v0.4.23
[INFO] [stderr]    Compiling criterion-plot v0.5.0
[INFO] [stderr]    Compiling float-cmp v0.10.0
[INFO] [stderr]    Compiling plotters v0.3.7
[INFO] [stderr]    Compiling predicates v3.1.3
[INFO] [stderr]    Compiling proc-macro-crate v3.3.0
[INFO] [stderr]    Compiling globwalk v0.9.1
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling assert_fs v1.1.2
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling rand v0.9.0
[INFO] [stderr]    Compiling proptest v1.6.0
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling test-case-core v3.3.1
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.7.5
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling zerovec-derive v0.10.3
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling clap_derive v4.5.32
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling test-case-macros v3.3.1
[INFO] [stderr]    Compiling test-case v3.3.1
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling dialoguer v0.11.0
[INFO] [stderr]    Compiling yoke v0.7.5
[INFO] [stderr]    Compiling zerovec v0.10.4
[INFO] [stderr]    Compiling clap v4.5.32
[INFO] [stderr]    Compiling tinystr v0.7.6
[INFO] [stderr]    Compiling icu_collections v1.5.0
[INFO] [stderr]    Compiling icu_locid v1.5.0
[INFO] [stderr]    Compiling mockall v0.13.1
[INFO] [stderr]    Compiling icu_provider v1.5.0
[INFO] [stderr]    Compiling icu_locid_transform v1.5.0
[INFO] [stderr]    Compiling icu_properties v1.5.1
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling rstest v0.25.0
[INFO] [stderr]    Compiling icu_normalizer v1.5.0
[INFO] [stderr]    Compiling idna_adapter v1.2.0
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling serde_spanned v0.6.8
[INFO] [stderr]    Compiling chrono v0.4.40
[INFO] [stderr]    Compiling rust-stemmers v1.2.0
[INFO] [stderr]    Compiling ciborium v0.2.2
[INFO] [stderr]    Compiling uuid v1.15.1
[INFO] [stderr]    Compiling tinytemplate v1.2.1
[INFO] [stderr]    Compiling criterion v0.5.1
[INFO] [stderr]    Compiling toml v0.8.20
[INFO] [stderr]    Compiling pocket-cli v1.0.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `crate::storage::StorageManager`
[INFO] [stdout]   --> src/cards/backup.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::storage::StorageManager;
[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: `ContentType`
[INFO] [stdout]  --> src/cards/snippet.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::{Entry, ContentType};
[INFO] [stdout]   |                            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/cards/core.rs:9:14
[INFO] [stdout]   |
[INFO] [stdout] 9 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `colored::Colorize`
[INFO] [stdout]  --> src/cards/blend.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use colored::Colorize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dirs`
[INFO] [stdout]  --> src/cards/blend.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use dirs;
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PathBuf`
[INFO] [stdout]   --> src/cards/mod.rs:12:23
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `File`
[INFO] [stdout]   --> src/cards/mod.rs:13:21
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::fs::{self, File};
[INFO] [stdout]    |                     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Read` and `Write`
[INFO] [stdout]   --> src/cards/mod.rs:14:15
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::io::{Read, Write};
[INFO] [stdout]    |               ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Context`
[INFO] [stdout]   --> src/cards/mod.rs:16:22
[INFO] [stdout]    |
[INFO] [stdout] 16 | use anyhow::{Result, Context, anyhow, bail};
[INFO] [stdout]    |                      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Args`
[INFO] [stdout]  --> src/cli/mod.rs:1:32
[INFO] [stdout]   |
[INFO] [stdout] 1 | use clap::{Parser, Subcommand, Args, ArgAction};
[INFO] [stdout]   |                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> src/cli/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `IntoPocketError`
[INFO] [stdout]  --> src/cli/handler.rs:3:48
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::errors::{PocketError, PocketResult, IntoPocketError};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error`, `info`, and `warn`
[INFO] [stdout]  --> src/cli/handler.rs:5:18
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{debug, info, warn, error, LevelFilter};
[INFO] [stdout]   |                  ^^^^  ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `exact`
[INFO] [stdout]   --> src/cards/core.rs:61:77
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn search(&self, query: &str, limit: usize, backpack: Option<&str>, exact: bool) -> Result<Vec<Entry>> {
[INFO] [stdout]    |                                                                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_exact`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entry`
[INFO] [stdout]   --> src/cards/core.rs:76:14
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let (entry, content) = storage.load_entry(entry_id, None)?;
[INFO] [stdout]    |              ^^^^^ help: if this is intentional, prefix it with an underscore: `_entry`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cmd`
[INFO] [stdout]    --> src/cli/handler.rs:206:32
[INFO] [stdout]     |
[INFO] [stdout] 206 |             } else if let Some(cmd) = command {
[INFO] [stdout]     |                                ^^^ help: if this is intentional, prefix it with an underscore: `_cmd`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `workflow`
[INFO] [stdout]    --> src/cli/handler.rs:217:26
[INFO] [stdout]     |
[INFO] [stdout] 217 |         Commands::Lint { workflow } => {
[INFO] [stdout]     |                          ^^^^^^^^ help: try ignoring the field: `workflow: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/cli/handler.rs:223:36
[INFO] [stdout]     |
[INFO] [stdout] 223 |         Commands::DeleteWorkflow { name } => {
[INFO] [stdout]     |                                    ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/cli/handler.rs:253:29
[INFO] [stdout]     |
[INFO] [stdout] 253 |         Commands::Execute { name, args } => {
[INFO] [stdout]     |                             ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]    --> src/cli/handler.rs:253:35
[INFO] [stdout]     |
[INFO] [stdout] 253 |         Commands::Execute { name, args } => {
[INFO] [stdout]     |                                   ^^^^ help: try ignoring the field: `args: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/utils/clipboard.rs:120:13
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let mut xclip_child = Command::new("xclip")
[INFO] [stdout]     |             ----^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/utils/clipboard.rs:138:13
[INFO] [stdout]     |
[INFO] [stdout] 138 |         let mut wl_copy_child = Command::new("wl-copy")
[INFO] [stdout]     |             ----^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `register_card` is never used
[INFO] [stdout]    --> src/cards/mod.rs:254:8
[INFO] [stdout]     |
[INFO] [stdout]  85 | impl CardManager {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 254 |     fn register_card(&mut self, card: Box<dyn Card>) -> Result<()> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlaceholderCard` is never constructed
[INFO] [stdout]    --> src/cards/mod.rs:772:8
[INFO] [stdout]     |
[INFO] [stdout] 772 | struct PlaceholderCard {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/cards/mod.rs:779:8
[INFO] [stdout]     |
[INFO] [stdout] 778 | impl PlaceholderCard {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] 779 |     fn new(name: String) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_dir` is never read
[INFO] [stdout]   --> src/cards/snippet.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct SnippetCard {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 24 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_dir` is never read
[INFO] [stdout]   --> src/cards/core.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct CoreCard {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 26 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_dir` is never read
[INFO] [stdout]   --> src/cards/blend.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct BlendCard {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 26 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::storage::StorageManager`
[INFO] [stdout]   --> src/cards/backup.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::storage::StorageManager;
[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: `ContentType`
[INFO] [stdout]  --> src/cards/snippet.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::{Entry, ContentType};
[INFO] [stdout]   |                            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/cards/core.rs:9:14
[INFO] [stdout]   |
[INFO] [stdout] 9 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `colored::Colorize`
[INFO] [stdout]  --> src/cards/blend.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use colored::Colorize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dirs`
[INFO] [stdout]  --> src/cards/blend.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use dirs;
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PathBuf`
[INFO] [stdout]   --> src/cards/mod.rs:12:23
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `File`
[INFO] [stdout]   --> src/cards/mod.rs:13:21
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::fs::{self, File};
[INFO] [stdout]    |                     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Read` and `Write`
[INFO] [stdout]   --> src/cards/mod.rs:14:15
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::io::{Read, Write};
[INFO] [stdout]    |               ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Context`
[INFO] [stdout]   --> src/cards/mod.rs:16:22
[INFO] [stdout]    |
[INFO] [stdout] 16 | use anyhow::{Result, Context, anyhow, bail};
[INFO] [stdout]    |                      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Args`
[INFO] [stdout]  --> src/cli/mod.rs:1:32
[INFO] [stdout]   |
[INFO] [stdout] 1 | use clap::{Parser, Subcommand, Args, ArgAction};
[INFO] [stdout]   |                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> src/cli/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `IntoPocketError`
[INFO] [stdout]  --> src/cli/handler.rs:3:48
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::errors::{PocketError, PocketResult, IntoPocketError};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error`, `info`, and `warn`
[INFO] [stdout]  --> src/cli/handler.rs:5:18
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{debug, info, warn, error, LevelFilter};
[INFO] [stdout]   |                  ^^^^  ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::storage::StorageManager`
[INFO] [stdout]   --> src/cards/backup.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::storage::StorageManager;
[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: `exact`
[INFO] [stdout]   --> src/cards/core.rs:61:77
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn search(&self, query: &str, limit: usize, backpack: Option<&str>, exact: bool) -> Result<Vec<Entry>> {
[INFO] [stdout]    |                                                                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_exact`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ContentType`
[INFO] [stdout]  --> src/cards/snippet.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::{Entry, ContentType};
[INFO] [stdout]   |                            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/cards/core.rs:9:14
[INFO] [stdout]   |
[INFO] [stdout] 9 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entry`
[INFO] [stdout]   --> src/cards/core.rs:76:14
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let (entry, content) = storage.load_entry(entry_id, None)?;
[INFO] [stdout]    |              ^^^^^ help: if this is intentional, prefix it with an underscore: `_entry`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `colored::Colorize`
[INFO] [stdout]  --> src/cards/blend.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use colored::Colorize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dirs`
[INFO] [stdout]  --> src/cards/blend.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use dirs;
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PathBuf`
[INFO] [stdout]   --> src/cards/mod.rs:12:23
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `File`
[INFO] [stdout]   --> src/cards/mod.rs:13:21
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::fs::{self, File};
[INFO] [stdout]    |                     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Read` and `Write`
[INFO] [stdout]   --> src/cards/mod.rs:14:15
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::io::{Read, Write};
[INFO] [stdout]    |               ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Context`
[INFO] [stdout]   --> src/cards/mod.rs:16:22
[INFO] [stdout]    |
[INFO] [stdout] 16 | use anyhow::{Result, Context, anyhow, bail};
[INFO] [stdout]    |                      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Args`
[INFO] [stdout]  --> src/cli/mod.rs:1:32
[INFO] [stdout]   |
[INFO] [stdout] 1 | use clap::{Parser, Subcommand, Args, ArgAction};
[INFO] [stdout]   |                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> src/cli/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `IntoPocketError`
[INFO] [stdout]  --> src/cli/handler.rs:3:48
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::errors::{PocketError, PocketResult, IntoPocketError};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error`, `info`, and `warn`
[INFO] [stdout]  --> src/cli/handler.rs:5:18
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{debug, info, warn, error, LevelFilter};
[INFO] [stdout]   |                  ^^^^  ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `write_clipboard`
[INFO] [stdout]   --> src/utils/mod.rs:21:37
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub use clipboard::{read_clipboard, write_clipboard};
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `IntoAnyhow` and `PocketError`
[INFO] [stdout]   --> src/main.rs:14:14
[INFO] [stdout]    |
[INFO] [stdout] 14 | use errors::{PocketError, PocketResult, IntoAnyhow};
[INFO] [stdout]    |              ^^^^^^^^^^^                ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cmd`
[INFO] [stdout]    --> src/cli/handler.rs:206:32
[INFO] [stdout]     |
[INFO] [stdout] 206 |             } else if let Some(cmd) = command {
[INFO] [stdout]     |                                ^^^ help: if this is intentional, prefix it with an underscore: `_cmd`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `workflow`
[INFO] [stdout]    --> src/cli/handler.rs:217:26
[INFO] [stdout]     |
[INFO] [stdout] 217 |         Commands::Lint { workflow } => {
[INFO] [stdout]     |                          ^^^^^^^^ help: try ignoring the field: `workflow: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/cli/handler.rs:223:36
[INFO] [stdout]     |
[INFO] [stdout] 223 |         Commands::DeleteWorkflow { name } => {
[INFO] [stdout]     |                                    ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/cli/handler.rs:253:29
[INFO] [stdout]     |
[INFO] [stdout] 253 |         Commands::Execute { name, args } => {
[INFO] [stdout]     |                             ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]    --> src/cli/handler.rs:253:35
[INFO] [stdout]     |
[INFO] [stdout] 253 |         Commands::Execute { name, args } => {
[INFO] [stdout]     |                                   ^^^^ help: try ignoring the field: `args: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/utils/clipboard.rs:120:13
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let mut xclip_child = Command::new("xclip")
[INFO] [stdout]     |             ----^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/utils/clipboard.rs:138:13
[INFO] [stdout]     |
[INFO] [stdout] 138 |         let mut wl_copy_child = Command::new("wl-copy")
[INFO] [stdout]     |             ----^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `register_card` is never used
[INFO] [stdout]    --> src/cards/mod.rs:254:8
[INFO] [stdout]     |
[INFO] [stdout]  85 | impl CardManager {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 254 |     fn register_card(&mut self, card: Box<dyn Card>) -> Result<()> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlaceholderCard` is never constructed
[INFO] [stdout]    --> src/cards/mod.rs:772:8
[INFO] [stdout]     |
[INFO] [stdout] 772 | struct PlaceholderCard {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/cards/mod.rs:779:8
[INFO] [stdout]     |
[INFO] [stdout] 778 | impl PlaceholderCard {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] 779 |     fn new(name: String) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_dir` is never read
[INFO] [stdout]   --> src/cards/snippet.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct SnippetCard {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 24 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_dir` is never read
[INFO] [stdout]   --> src/cards/core.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct CoreCard {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 26 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `data_dir` is never read
[INFO] [stdout]   --> src/cards/blend.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct BlendCard {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 26 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `exact`
[INFO] [stdout]   --> src/cards/core.rs:61:77
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn search(&self, query: &str, limit: usize, backpack: Option<&str>, exact: bool) -> Result<Vec<Entry>> {
[INFO] [stdout]    |                                                                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_exact`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entry`
[INFO] [stdout]   --> src/cards/core.rs:76:14
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let (entry, content) = storage.load_entry(entry_id, None)?;
[INFO] [stdout]    |              ^^^^^ help: if this is intentional, prefix it with an underscore: `_entry`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cmd`
[INFO] [stdout]    --> src/cli/handler.rs:206:32
[INFO] [stdout]     |
[INFO] [stdout] 206 |             } else if let Some(cmd) = command {
[INFO] [stdout]     |                                ^^^ help: if this is intentional, prefix it with an underscore: `_cmd`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `workflow`
[INFO] [stdout]    --> src/cli/handler.rs:217:26
[INFO] [stdout]     |
[INFO] [stdout] 217 |         Commands::Lint { workflow } => {
[INFO] [stdout]     |                          ^^^^^^^^ help: try ignoring the field: `workflow: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/cli/handler.rs:223:36
[INFO] [stdout]     |
[INFO] [stdout] 223 |         Commands::DeleteWorkflow { name } => {
[INFO] [stdout]     |                                    ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/cli/handler.rs:253:29
[INFO] [stdout]     |
[INFO] [stdout] 253 |         Commands::Execute { name, args } => {
[INFO] [stdout]     |                             ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]    --> src/cli/handler.rs:253:35
[INFO] [stdout]     |
[INFO] [stdout] 253 |         Commands::Execute { name, args } => {
[INFO] [stdout]     |                                   ^^^^ help: try ignoring the field: `args: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/utils/clipboard.rs:120:13
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let mut xclip_child = Command::new("xclip")
[INFO] [stdout]     |             ----^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/utils/clipboard.rs:138:13
[INFO] [stdout]     |
[INFO] [stdout] 138 |         let mut wl_copy_child = Command::new("wl-copy")
[INFO] [stdout]     |             ----^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `description` and `initialize` are never used
[INFO] [stdout]   --> src/cards/mod.rs:28:8
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub trait Card: Send + Sync {
[INFO] [stdout]    |           ---- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 28 |     fn description(&self) -> &str;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     fn initialize(&mut self, config: &CardConfig) -> Result<()>;
[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 `register_card` and `card_exists` are never used
[INFO] [stdout]    --> src/cards/mod.rs:254:8
[INFO] [stdout]     |
[INFO] [stdout]  85 | impl CardManager {
[INFO] [stdout]     | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 254 |     fn register_card(&mut self, card: Box<dyn Card>) -> Result<()> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 376 |     pub fn card_exists(&self, name: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlaceholderCard` is never constructed
[INFO] [stdout]    --> src/cards/mod.rs:772:8
[INFO] [stdout]     |
[INFO] [stdout] 772 | struct PlaceholderCard {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/cards/mod.rs:779:8
[INFO] [stdout]     |
[INFO] [stdout] 778 | impl PlaceholderCard {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] 779 |     fn new(name: String) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `description` is never read
[INFO] [stdout]   --> src/cards/backup.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub struct BackupCard {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 79 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `description` and `data_dir` are never read
[INFO] [stdout]   --> src/cards/snippet.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct SnippetCard {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 18 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `description` and `data_dir` are never read
[INFO] [stdout]   --> src/cards/core.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct CoreCard {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 20 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `description` and `data_dir` are never read
[INFO] [stdout]   --> src/cards/blend.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct BlendCard {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 20 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     data_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `CONFIG` is never used
[INFO] [stdout]   --> src/config.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | static CONFIG: OnceCell<Arc<Mutex<ConfigManager>>> = OnceCell::new();
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Config` is never constructed
[INFO] [stdout]   --> src/config.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Config {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_config_version` is never used
[INFO] [stdout]   --> src/config.rs:53:4
[INFO] [stdout]    |
[INFO] [stdout] 53 | fn default_config_version() -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_content_type` is never used
[INFO] [stdout]   --> src/config.rs:57:4
[INFO] [stdout]    |
[INFO] [stdout] 57 | fn default_content_type() -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_log_level` is never used
[INFO] [stdout]   --> src/config.rs:61:4
[INFO] [stdout]    |
[INFO] [stdout] 61 | fn default_log_level() -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_max_search_results` is never used
[INFO] [stdout]   --> src/config.rs:65:4
[INFO] [stdout]    |
[INFO] [stdout] 65 | fn default_max_search_results() -> usize {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_search_algorithm` is never used
[INFO] [stdout]   --> src/config.rs:69:4
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn default_search_algorithm() -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ConfigManager` is never constructed
[INFO] [stdout]   --> src/config.rs:91:12
[INFO] [stdout]    |
[INFO] [stdout] 91 | pub struct ConfigManager {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/config.rs:107:12
[INFO] [stdout]     |
[INFO] [stdout] 105 | impl ConfigManager {
[INFO] [stdout]     | ------------------ associated items in this implementation
[INFO] [stdout] 106 |     /// Create a new configuration manager
[INFO] [stdout] 107 |     pub fn new(data_dir: impl AsRef<Path>) -> PocketResult<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 151 |     pub fn get_config(&self) -> Config {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn update_config(&mut self, config: Config) -> PocketResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 163 |     pub fn get_card_config(&self, card_name: &str) -> Option<serde_json::Value> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub fn set_card_config(&mut self, card_name: &str, config: serde_json::Value) -> PocketResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 175 |     pub fn save(&self) -> PocketResult<()> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 194 |     pub fn get_data_dir(&self) -> PathBuf {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn get_hooks_dir(&self) -> PathBuf {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |     pub fn get_bin_dir(&self) -> PathBuf {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `init` is never used
[INFO] [stdout]    --> src/config.rs:227:8
[INFO] [stdout]     |
[INFO] [stdout] 227 | pub fn init(data_dir: impl AsRef<Path>) -> PocketResult<()> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get` is never used
[INFO] [stdout]    --> src/config.rs:234:8
[INFO] [stdout]     |
[INFO] [stdout] 234 | pub fn get() -> PocketResult<Arc<Mutex<ConfigManager>>> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_config` is never used
[INFO] [stdout]    --> src/config.rs:242:8
[INFO] [stdout]     |
[INFO] [stdout] 242 | pub fn get_config() -> PocketResult<Config> {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `save` is never used
[INFO] [stdout]    --> src/config.rs:250:8
[INFO] [stdout]     |
[INFO] [stdout] 250 | pub fn save() -> PocketResult<()> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/errors.rs:9:5
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub enum PocketError {
[INFO] [stdout]    |          ----------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout]  9 |     Storage(String),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 13 |     Entry(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 25 |     Hook(String),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |     File {
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     Search(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     Canceled,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     PermissionDenied(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PocketError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `IntoAnyhow` is never used
[INFO] [stdout]   --> src/errors.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub trait IntoAnyhow<T> {
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `IntoPocketError` is never used
[INFO] [stdout]   --> src/errors.rs:71:11
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub trait IntoPocketError<T> {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cmd_text` is never used
[INFO] [stdout]   --> src/logging.rs:78:8
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub fn cmd_text(cmd: &str, args: &[&str]) -> ColoredString {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `value` is never used
[INFO] [stdout]   --> src/logging.rs:93:8
[INFO] [stdout]    |
[INFO] [stdout] 93 | pub fn value(text: &str) -> ColoredString {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `path` is never used
[INFO] [stdout]   --> src/logging.rs:98:8
[INFO] [stdout]    |
[INFO] [stdout] 98 | pub fn path(text: &str) -> ColoredString {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `id` is never used
[INFO] [stdout]    --> src/logging.rs:103:8
[INFO] [stdout]     |
[INFO] [stdout] 103 | pub fn id(text: &str) -> ColoredString {
[INFO] [stdout]     |        ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Workflow` is never constructed
[INFO] [stdout]   --> src/models/mod.rs:60:12
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct Workflow {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WorkflowCommand` is never constructed
[INFO] [stdout]   --> src/models/mod.rs:73:12
[INFO] [stdout]    |
[INFO] [stdout] 73 | pub struct WorkflowCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/models/mod.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 108 | impl Backpack {
[INFO] [stdout]     | ------------- associated function in this implementation
[INFO] [stdout] 109 |     /// Create a new backpack
[INFO] [stdout] 110 |     pub fn new(name: String, description: Option<String>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/models/mod.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout] 119 | impl Workflow {
[INFO] [stdout]     | ------------- associated function in this implementation
[INFO] [stdout] 120 |     /// Create a new workflow
[INFO] [stdout] 121 |     pub fn new(name: String, commands: Vec<WorkflowCommand>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `parse` is never used
[INFO] [stdout]    --> src/models/mod.rs:132:12
[INFO] [stdout]     |
[INFO] [stdout] 130 | impl WorkflowCommand {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] 131 |     /// Parse a command string into a WorkflowCommand
[INFO] [stdout] 132 |     pub fn parse(command_str: &str) -> Result<Self> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchResult` is never constructed
[INFO] [stdout]   --> src/search/mod.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct SearchResult {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchEngine` is never constructed
[INFO] [stdout]   --> src/search/mod.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct SearchEngine {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchIndex` is never constructed
[INFO] [stdout]   --> src/search/mod.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 39 | struct SearchIndex {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/search/mod.rs:70:12
[INFO] [stdout]     |
[INFO] [stdout]  68 | impl SearchEngine {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout]  69 |     /// Create a new search engine
[INFO] [stdout]  70 |     pub fn new(storage: StorageManager) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn search(&self, query: &str, limit: usize, backpack: Option<&str>, algorithm: SearchAlgorithm) -> Result<Vec<SearchResult>> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     fn bm25_search(&self, query: &str, index: &SearchIndex, backpack_filter: Option<&str>) -> Result<Vec<SearchResult>> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 232 |     fn fuzzy_search(&self, query: &str, _index: &SearchIndex, backpack_filter: Option<&str>) -> Result<Vec<SearchResult>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 284 |     fn calculate_fuzzy_similarity(&self, query: &str, content: &str) -> f64 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 305 |     fn generate_ngrams(&self, text: &str, n: usize) -> HashSet<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 324 |     fn tokenize(&self, text: &str) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 334 |     fn preprocess_text(&self, text: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 347 |     fn generate_highlights(&self, results: Vec<SearchResult>, query: &str) -> Result<Vec<SearchResult>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 408 |     fn get_context_snippet(&self, content: &str, position: usize, length: usize) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `new`, `tokenize_content`, and `build` are never used
[INFO] [stdout]    --> src/search/mod.rs:451:8
[INFO] [stdout]     |
[INFO] [stdout] 449 | impl SearchIndex {
[INFO] [stdout]     | ---------------- associated functions in this implementation
[INFO] [stdout] 450 |     /// Create a new empty search index
[INFO] [stdout] 451 |     fn new() -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 466 |     fn tokenize_content(text: &str) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 491 |     fn build(index: Arc<RwLock<SearchIndex>>, storage: StorageManager) -> Result<()> {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/storage/mod.rs:36:12
[INFO] [stdout]     |
[INFO] [stdout]  14 | impl StorageManager {
[INFO] [stdout]     | ------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  36 |     pub fn get_workflows_dir(&self) -> Result<PathBuf> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  71 |     fn get_workflow_path(&self, name: &str) -> PathBuf {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn list_backpacks(&self) -> Result<Vec<Backpack>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn determine_content_type(path: &Path) -> ContentType {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 239 |     pub fn save_workflow(&self, workflow: &Workflow) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 258 |     pub fn load_workflow(&self, name: &str) -> Result<Workflow> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 268 |     pub fn delete_workflow(&self, name: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 279 |     pub fn list_workflows(&self) -> Result<Vec<Workflow>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 335 |     pub fn load_entry_content(&self, id: &str, backpack: Option<&str>) -> Result<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_file_content` is never used
[INFO] [stdout]   --> src/utils/mod.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn read_file_content(path: &Path) -> Result<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_stdin_content` is never used
[INFO] [stdout]   --> src/utils/mod.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub fn read_stdin_content() -> Result<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `open_editor_with_type` is never used
[INFO] [stdout]   --> src/utils/mod.rs:76:8
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub fn open_editor_with_type(content_type: ContentType, initial_content: Option<&str>) -> Result<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `edit_entry` is never used
[INFO] [stdout]    --> src/utils/mod.rs:160:8
[INFO] [stdout]     |
[INFO] [stdout] 160 | pub fn edit_entry(id: &str, content: &str, content_type: ContentType) -> Result<String> {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `select` is never used
[INFO] [stdout]    --> src/utils/mod.rs:321:8
[INFO] [stdout]     |
[INFO] [stdout] 321 | pub fn select<T>(message: &str, options: &[T]) -> Result<usize>
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_with_tag` is never used
[INFO] [stdout]    --> src/utils/mod.rs:333:8
[INFO] [stdout]     |
[INFO] [stdout] 333 | pub fn format_with_tag(tag: &str, content: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `truncate_string` is never used
[INFO] [stdout]    --> src/utils/mod.rs:338:8
[INFO] [stdout]     |
[INFO] [stdout] 338 | pub fn truncate_string(s: &str, max_len: usize) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `first_line` is never used
[INFO] [stdout]    --> src/utils/mod.rs:349:8
[INFO] [stdout]     |
[INFO] [stdout] 349 | pub fn first_line(s: &str) -> &str {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_title_from_content` is never used
[INFO] [stdout]    --> src/utils/mod.rs:354:8
[INFO] [stdout]     |
[INFO] [stdout] 354 | pub fn get_title_from_content(content: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VERSION_LETTER` is never used
[INFO] [stdout]  --> src/version.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub const VERSION_LETTER: &str = "v-pocket-R1";
[INFO] [stdout]   |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VERSION_DATE` is never used
[INFO] [stdout]   --> src/version.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub const VERSION_DATE: &str = "04012025";
[INFO] [stdout]    |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VERSION_STRING` is never used
[INFO] [stdout]   --> src/version.rs:13:11
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub const VERSION_STRING: &str = "Pocket v-pocket-R1 (03172025 - Core Implementations)";
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `COMPATIBILITY` is never used
[INFO] [stdout]   --> src/version.rs:16:11
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub const COMPATIBILITY: Option<&str> = Some("");
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `AUTHOR` is never used
[INFO] [stdout]   --> src/version.rs:18:11
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub const AUTHOR: &str = "frgmt0 (j)";
[INFO] [stdout]    |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_version` is never used
[INFO] [stdout]   --> src/version.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub fn get_version() -> Version {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Stability` is never used
[INFO] [stdout]   --> src/version.rs:34:10
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub enum Stability {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Version` is never constructed
[INFO] [stdout]   --> src/version.rs:60:12
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct Version {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 57.63s
[INFO] running `Command { std: "docker" "inspect" "276bd2ff8330591200f4bfe24b5f4bd3f74b636839502c8414eb584ff6224f6f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "276bd2ff8330591200f4bfe24b5f4bd3f74b636839502c8414eb584ff6224f6f", kill_on_drop: false }`
[INFO] [stdout] 276bd2ff8330591200f4bfe24b5f4bd3f74b636839502c8414eb584ff6224f6f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] e0e8486842c97fcf99ca843dbbb7e738b4aaf573143ad6502e71c4d07497e81c
[INFO] running `Command { std: "docker" "start" "-a" "e0e8486842c97fcf99ca843dbbb7e738b4aaf573143ad6502e71c4d07497e81c", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `crate::storage::StorageManager`
[INFO] [stderr]   --> src/cards/backup.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | use crate::storage::StorageManager;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ContentType`
[INFO] [stderr]  --> src/cards/snippet.rs:3:28
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::models::{Entry, ContentType};
[INFO] [stderr]   |                            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `DateTime` and `Utc`
[INFO] [stderr]  --> src/cards/core.rs:9:14
[INFO] [stderr]   |
[INFO] [stderr] 9 | use chrono::{DateTime, Utc};
[INFO] [stderr]   |              ^^^^^^^^  ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `colored::Colorize`
[INFO] [stderr]  --> src/cards/blend.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use colored::Colorize;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `dirs`
[INFO] [stderr]  --> src/cards/blend.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 | use dirs;
[INFO] [stderr]   |     ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `PathBuf`
[INFO] [stderr]   --> src/cards/mod.rs:12:23
[INFO] [stderr]    |
[INFO] [stderr] 12 | use std::path::{Path, PathBuf};
[INFO] [stderr]    |                       ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `File`
[INFO] [stderr]   --> src/cards/mod.rs:13:21
[INFO] [stderr]    |
[INFO] [stderr] 13 | use std::fs::{self, File};
[INFO] [stderr]    |                     ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Read` and `Write`
[INFO] [stderr]   --> src/cards/mod.rs:14:15
[INFO] [stderr]    |
[INFO] [stderr] 14 | use std::io::{Read, Write};
[INFO] [stderr]    |               ^^^^  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Context`
[INFO] [stderr]   --> src/cards/mod.rs:16:22
[INFO] [stderr]    |
[INFO] [stderr] 16 | use anyhow::{Result, Context, anyhow, bail};
[INFO] [stderr]    |                      ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Args`
[INFO] [stderr]  --> src/cli/mod.rs:1:32
[INFO] [stderr]   |
[INFO] [stderr] 1 | use clap::{Parser, Subcommand, Args, ArgAction};
[INFO] [stderr]   |                                ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::path::PathBuf`
[INFO] [stderr]  --> src/cli/mod.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::path::PathBuf;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `IntoPocketError`
[INFO] [stderr]  --> src/cli/handler.rs:3:48
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::errors::{PocketError, PocketResult, IntoPocketError};
[INFO] [stderr]   |                                                ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `error`, `info`, and `warn`
[INFO] [stderr]  --> src/cli/handler.rs:5:18
[INFO] [stderr]   |
[INFO] [stderr] 5 | use log::{debug, info, warn, error, LevelFilter};
[INFO] [stderr]   |                  ^^^^  ^^^^  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `exact`
[INFO] [stderr]   --> src/cards/core.rs:61:77
[INFO] [stderr]    |
[INFO] [stderr] 61 |     pub fn search(&self, query: &str, limit: usize, backpack: Option<&str>, exact: bool) -> Result<Vec<Entry>> {
[INFO] [stderr]    |                                                                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_exact`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `entry`
[INFO] [stderr]   --> src/cards/core.rs:76:14
[INFO] [stderr]    |
[INFO] [stderr] 76 |         let (entry, content) = storage.load_entry(entry_id, None)?;
[INFO] [stderr]    |              ^^^^^ help: if this is intentional, prefix it with an underscore: `_entry`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `cmd`
[INFO] [stderr]    --> src/cli/handler.rs:206:32
[INFO] [stderr]     |
[INFO] [stderr] 206 |             } else if let Some(cmd) = command {
[INFO] [stderr]     |                                ^^^ help: if this is intentional, prefix it with an underscore: `_cmd`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `workflow`
[INFO] [stderr]    --> src/cli/handler.rs:217:26
[INFO] [stderr]     |
[INFO] [stderr] 217 |         Commands::Lint { workflow } => {
[INFO] [stderr]     |                          ^^^^^^^^ help: try ignoring the field: `workflow: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `name`
[INFO] [stderr]    --> src/cli/handler.rs:223:36
[INFO] [stderr]     |
[INFO] [stderr] 223 |         Commands::DeleteWorkflow { name } => {
[INFO] [stderr]     |                                    ^^^^ help: try ignoring the field: `name: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `name`
[INFO] [stderr]    --> src/cli/handler.rs:253:29
[INFO] [stderr]     |
[INFO] [stderr] 253 |         Commands::Execute { name, args } => {
[INFO] [stderr]     |                             ^^^^ help: try ignoring the field: `name: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `args`
[INFO] [stderr]    --> src/cli/handler.rs:253:35
[INFO] [stderr]     |
[INFO] [stderr] 253 |         Commands::Execute { name, args } => {
[INFO] [stderr]     |                                   ^^^^ help: try ignoring the field: `args: _`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/utils/clipboard.rs:120:13
[INFO] [stderr]     |
[INFO] [stderr] 120 |         let mut xclip_child = Command::new("xclip")
[INFO] [stderr]     |             ----^^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/utils/clipboard.rs:138:13
[INFO] [stderr]     |
[INFO] [stderr] 138 |         let mut wl_copy_child = Command::new("wl-copy")
[INFO] [stderr]     |             ----^^^^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: method `register_card` is never used
[INFO] [stderr]    --> src/cards/mod.rs:254:8
[INFO] [stderr]     |
[INFO] [stderr]  85 | impl CardManager {
[INFO] [stderr]     | ---------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 254 |     fn register_card(&mut self, card: Box<dyn Card>) -> Result<()> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PlaceholderCard` is never constructed
[INFO] [stderr]    --> src/cards/mod.rs:772:8
[INFO] [stderr]     |
[INFO] [stderr] 772 | struct PlaceholderCard {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]    --> src/cards/mod.rs:779:8
[INFO] [stderr]     |
[INFO] [stderr] 778 | impl PlaceholderCard {
[INFO] [stderr]     | -------------------- associated function in this implementation
[INFO] [stderr] 779 |     fn new(name: String) -> Self {
[INFO] [stderr]     |        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `data_dir` is never read
[INFO] [stderr]   --> src/cards/snippet.rs:24:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub struct SnippetCard {
[INFO] [stderr]    |            ----------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 24 |     data_dir: PathBuf,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `data_dir` is never read
[INFO] [stderr]   --> src/cards/core.rs:26:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct CoreCard {
[INFO] [stderr]    |            -------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 26 |     data_dir: PathBuf,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `data_dir` is never read
[INFO] [stderr]   --> src/cards/blend.rs:26:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct BlendCard {
[INFO] [stderr]    |            --------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 26 |     data_dir: PathBuf,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `pocket-cli` (lib) generated 28 warnings (run `cargo fix --lib -p pocket-cli` to apply 15 suggestions)
[INFO] [stderr] warning: unused import: `write_clipboard`
[INFO] [stderr]   --> src/utils/mod.rs:21:37
[INFO] [stderr]    |
[INFO] [stderr] 21 | pub use clipboard::{read_clipboard, write_clipboard};
[INFO] [stderr]    |                                     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `IntoAnyhow` and `PocketError`
[INFO] [stderr]   --> src/main.rs:14:14
[INFO] [stderr]    |
[INFO] [stderr] 14 | use errors::{PocketError, PocketResult, IntoAnyhow};
[INFO] [stderr]    |              ^^^^^^^^^^^                ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `description` and `initialize` are never used
[INFO] [stderr]   --> src/cards/mod.rs:28:8
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub trait Card: Send + Sync {
[INFO] [stderr]    |           ---- methods in this trait
[INFO] [stderr] ...
[INFO] [stderr] 28 |     fn description(&self) -> &str;
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 31 |     fn initialize(&mut self, config: &CardConfig) -> Result<()>;
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: methods `register_card` and `card_exists` are never used
[INFO] [stderr]    --> src/cards/mod.rs:254:8
[INFO] [stderr]     |
[INFO] [stderr]  85 | impl CardManager {
[INFO] [stderr]     | ---------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 254 |     fn register_card(&mut self, card: Box<dyn Card>) -> Result<()> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 376 |     pub fn card_exists(&self, name: &str) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `description` is never read
[INFO] [stderr]   --> src/cards/backup.rs:79:5
[INFO] [stderr]    |
[INFO] [stderr] 71 | pub struct BackupCard {
[INFO] [stderr]    |            ---------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 79 |     description: String,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `description` and `data_dir` are never read
[INFO] [stderr]   --> src/cards/snippet.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub struct SnippetCard {
[INFO] [stderr]    |            ----------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 18 |     description: String,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 24 |     data_dir: PathBuf,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `description` and `data_dir` are never read
[INFO] [stderr]   --> src/cards/core.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct CoreCard {
[INFO] [stderr]    |            -------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 20 |     description: String,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 26 |     data_dir: PathBuf,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `description` and `data_dir` are never read
[INFO] [stderr]   --> src/cards/blend.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct BlendCard {
[INFO] [stderr]    |            --------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 20 |     description: String,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 26 |     data_dir: PathBuf,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `CONFIG` is never used
[INFO] [stderr]   --> src/config.rs:11:8
[INFO] [stderr]    |
[INFO] [stderr] 11 | static CONFIG: OnceCell<Arc<Mutex<ConfigManager>>> = OnceCell::new();
[INFO] [stderr]    |        ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Config` is never constructed
[INFO] [stderr]   --> src/config.rs:15:12
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub struct Config {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `default_config_version` is never used
[INFO] [stderr]   --> src/config.rs:53:4
[INFO] [stderr]    |
[INFO] [stderr] 53 | fn default_config_version() -> String {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `default_content_type` is never used
[INFO] [stderr]   --> src/config.rs:57:4
[INFO] [stderr]    |
[INFO] [stderr] 57 | fn default_content_type() -> String {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `default_log_level` is never used
[INFO] [stderr]   --> src/config.rs:61:4
[INFO] [stderr]    |
[INFO] [stderr] 61 | fn default_log_level() -> String {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `default_max_search_results` is never used
[INFO] [stderr]   --> src/config.rs:65:4
[INFO] [stderr]    |
[INFO] [stderr] 65 | fn default_max_search_results() -> usize {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `default_search_algorithm` is never used
[INFO] [stderr]   --> src/config.rs:69:4
[INFO] [stderr]    |
[INFO] [stderr] 69 | fn default_search_algorithm() -> String {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ConfigManager` is never constructed
[INFO] [stderr]   --> src/config.rs:91:12
[INFO] [stderr]    |
[INFO] [stderr] 91 | pub struct ConfigManager {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/config.rs:107:12
[INFO] [stderr]     |
[INFO] [stderr] 105 | impl ConfigManager {
[INFO] [stderr]     | ------------------ associated items in this implementation
[INFO] [stderr] 106 |     /// Create a new configuration manager
[INFO] [stderr] 107 |     pub fn new(data_dir: impl AsRef<Path>) -> PocketResult<Self> {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 151 |     pub fn get_config(&self) -> Config {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 156 |     pub fn update_config(&mut self, config: Config) -> PocketResult<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 163 |     pub fn get_card_config(&self, card_name: &str) -> Option<serde_json::Value> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 168 |     pub fn set_card_config(&mut self, card_name: &str, config: serde_json::Value) -> PocketResult<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 175 |     pub fn save(&self) -> PocketResult<()> {
[INFO] [stderr]     |            ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 194 |     pub fn get_data_dir(&self) -> PathBuf {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 199 |     pub fn get_hooks_dir(&self) -> PathBuf {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 207 |     pub fn get_bin_dir(&self) -> PathBuf {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `init` is never used
[INFO] [stderr]    --> src/config.rs:227:8
[INFO] [stderr]     |
[INFO] [stderr] 227 | pub fn init(data_dir: impl AsRef<Path>) -> PocketResult<()> {
[INFO] [stderr]     |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get` is never used
[INFO] [stderr]    --> src/config.rs:234:8
[INFO] [stderr]     |
[INFO] [stderr] 234 | pub fn get() -> PocketResult<Arc<Mutex<ConfigManager>>> {
[INFO] [stderr]     |        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_config` is never used
[INFO] [stderr]    --> src/config.rs:242:8
[INFO] [stderr]     |
[INFO] [stderr] 242 | pub fn get_config() -> PocketResult<Config> {
[INFO] [stderr]     |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `save` is never used
[INFO] [stderr]    --> src/config.rs:250:8
[INFO] [stderr]     |
[INFO] [stderr] 250 | pub fn save() -> PocketResult<()> {
[INFO] [stderr]     |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple variants are never constructed
[INFO] [stderr]   --> src/errors.rs:9:5
[INFO] [stderr]    |
[INFO] [stderr]  6 | pub enum PocketError {
[INFO] [stderr]    |          ----------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr]  9 |     Storage(String),
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 13 |     Entry(String),
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 25 |     Hook(String),
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 29 |     File {
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 41 |     Search(String),
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 45 |     Canceled,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 49 |     PermissionDenied(String),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 53 |     Other(String),
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `PocketError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: trait `IntoAnyhow` is never used
[INFO] [stderr]   --> src/errors.rs:60:11
[INFO] [stderr]    |
[INFO] [stderr] 60 | pub trait IntoAnyhow<T> {
[INFO] [stderr]    |           ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `IntoPocketError` is never used
[INFO] [stderr]   --> src/errors.rs:71:11
[INFO] [stderr]    |
[INFO] [stderr] 71 | pub trait IntoPocketError<T> {
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `cmd_text` is never used
[INFO] [stderr]   --> src/logging.rs:78:8
[INFO] [stderr]    |
[INFO] [stderr] 78 | pub fn cmd_text(cmd: &str, args: &[&str]) -> ColoredString {
[INFO] [stderr]    |        ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `value` is never used
[INFO] [stderr]   --> src/logging.rs:93:8
[INFO] [stderr]    |
[INFO] [stderr] 93 | pub fn value(text: &str) -> ColoredString {
[INFO] [stderr]    |        ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `path` is never used
[INFO] [stderr]   --> src/logging.rs:98:8
[INFO] [stderr]    |
[INFO] [stderr] 98 | pub fn path(text: &str) -> ColoredString {
[INFO] [stderr]    |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `id` is never used
[INFO] [stderr]    --> src/logging.rs:103:8
[INFO] [stderr]     |
[INFO] [stderr] 103 | pub fn id(text: &str) -> ColoredString {
[INFO] [stderr]     |        ^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Workflow` is never constructed
[INFO] [stderr]   --> src/models/mod.rs:60:12
[INFO] [stderr]    |
[INFO] [stderr] 60 | pub struct Workflow {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `WorkflowCommand` is never constructed
[INFO] [stderr]   --> src/models/mod.rs:73:12
[INFO] [stderr]    |
[INFO] [stderr] 73 | pub struct WorkflowCommand {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]    --> src/models/mod.rs:110:12
[INFO] [stderr]     |
[INFO] [stderr] 108 | impl Backpack {
[INFO] [stderr]     | ------------- associated function in this implementation
[INFO] [stderr] 109 |     /// Create a new backpack
[INFO] [stderr] 110 |     pub fn new(name: String, description: Option<String>) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]    --> src/models/mod.rs:121:12
[INFO] [stderr]     |
[INFO] [stderr] 119 | impl Workflow {
[INFO] [stderr]     | ------------- associated function in this implementation
[INFO] [stderr] 120 |     /// Create a new workflow
[INFO] [stderr] 121 |     pub fn new(name: String, commands: Vec<WorkflowCommand>) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `parse` is never used
[INFO] [stderr]    --> src/models/mod.rs:132:12
[INFO] [stderr]     |
[INFO] [stderr] 130 | impl WorkflowCommand {
[INFO] [stderr]     | -------------------- associated function in this implementation
[INFO] [stderr] 131 |     /// Parse a command string into a WorkflowCommand
[INFO] [stderr] 132 |     pub fn parse(command_str: &str) -> Result<Self> {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SearchResult` is never constructed
[INFO] [stderr]   --> src/search/mod.rs:13:12
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub struct SearchResult {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SearchEngine` is never constructed
[INFO] [stderr]   --> src/search/mod.rs:31:12
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub struct SearchEngine {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SearchIndex` is never constructed
[INFO] [stderr]   --> src/search/mod.rs:39:8
[INFO] [stderr]    |
[INFO] [stderr] 39 | struct SearchIndex {
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/search/mod.rs:70:12
[INFO] [stderr]     |
[INFO] [stderr]  68 | impl SearchEngine {
[INFO] [stderr]     | ----------------- associated items in this implementation
[INFO] [stderr]  69 |     /// Create a new search engine
[INFO] [stderr]  70 |     pub fn new(storage: StorageManager) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 102 |     pub fn search(&self, query: &str, limit: usize, backpack: Option<&str>, algorithm: SearchAlgorithm) -> Result<Vec<SearchResult>> {
[INFO] [stderr]     |            ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 149 |     fn bm25_search(&self, query: &str, index: &SearchIndex, backpack_filter: Option<&str>) -> Result<Vec<SearchResult>> {
[INFO] [stderr]     |        ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 232 |     fn fuzzy_search(&self, query: &str, _index: &SearchIndex, backpack_filter: Option<&str>) -> Result<Vec<SearchResult>> {
[INFO] [stderr]     |        ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 284 |     fn calculate_fuzzy_similarity(&self, query: &str, content: &str) -> f64 {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 305 |     fn generate_ngrams(&self, text: &str, n: usize) -> HashSet<String> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 324 |     fn tokenize(&self, text: &str) -> Vec<String> {
[INFO] [stderr]     |        ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 334 |     fn preprocess_text(&self, text: &str) -> String {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 347 |     fn generate_highlights(&self, results: Vec<SearchResult>, query: &str) -> Result<Vec<SearchResult>> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 408 |     fn get_context_snippet(&self, content: &str, position: usize, length: usize) -> String {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated functions `new`, `tokenize_content`, and `build` are never used
[INFO] [stderr]    --> src/search/mod.rs:451:8
[INFO] [stderr]     |
[INFO] [stderr] 449 | impl SearchIndex {
[INFO] [stderr]     | ---------------- associated functions in this implementation
[INFO] [stderr] 450 |     /// Create a new empty search index
[INFO] [stderr] 451 |     fn new() -> Self {
[INFO] [stderr]     |        ^^^
[INFO] [stderr] ...
[INFO] [stderr] 466 |     fn tokenize_content(text: &str) -> Vec<String> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 491 |     fn build(index: Arc<RwLock<SearchIndex>>, storage: StorageManager) -> Result<()> {
[INFO] [stderr]     |        ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/storage/mod.rs:36:12
[INFO] [stderr]     |
[INFO] [stderr]  14 | impl StorageManager {
[INFO] [stderr]     | ------------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  36 |     pub fn get_workflows_dir(&self) -> Result<PathBuf> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  71 |     fn get_workflow_path(&self, name: &str) -> PathBuf {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 173 |     pub fn list_backpacks(&self) -> Result<Vec<Backpack>> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 228 |     pub fn determine_content_type(path: &Path) -> ContentType {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 239 |     pub fn save_workflow(&self, workflow: &Workflow) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 258 |     pub fn load_workflow(&self, name: &str) -> Result<Workflow> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 268 |     pub fn delete_workflow(&self, name: &str) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 279 |     pub fn list_workflows(&self) -> Result<Vec<Workflow>> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 335 |     pub fn load_entry_content(&self, id: &str, backpack: Option<&str>) -> Result<String> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `read_file_content` is never used
[INFO] [stderr]   --> src/utils/mod.rs:27:8
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub fn read_file_content(path: &Path) -> Result<String> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `read_stdin_content` is never used
[INFO] [stderr]   --> src/utils/mod.rs:32:8
[INFO] [stderr]    |
[INFO] [stderr] 32 | pub fn read_stdin_content() -> Result<String> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `open_editor_with_type` is never used
[INFO] [stderr]   --> src/utils/mod.rs:76:8
[INFO] [stderr]    |
[INFO] [stderr] 76 | pub fn open_editor_with_type(content_type: ContentType, initial_content: Option<&str>) -> Result<String> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `edit_entry` is never used
[INFO] [stderr]    --> src/utils/mod.rs:160:8
[INFO] [stderr]     |
[INFO] [stderr] 160 | pub fn edit_entry(id: &str, content: &str, content_type: ContentType) -> Result<String> {
[INFO] [stderr]     |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `select` is never used
[INFO] [stderr]    --> src/utils/mod.rs:321:8
[INFO] [stderr]     |
[INFO] [stderr] 321 | pub fn select<T>(message: &str, options: &[T]) -> Result<usize>
[INFO] [stderr]     |        ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `format_with_tag` is never used
[INFO] [stderr]    --> src/utils/mod.rs:333:8
[INFO] [stderr]     |
[INFO] [stderr] 333 | pub fn format_with_tag(tag: &str, content: &str) -> String {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `truncate_string` is never used
[INFO] [stderr]    --> src/utils/mod.rs:338:8
[INFO] [stderr]     |
[INFO] [stderr] 338 | pub fn truncate_string(s: &str, max_len: usize) -> String {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `first_line` is never used
[INFO] [stderr]    --> src/utils/mod.rs:349:8
[INFO] [stderr]     |
[INFO] [stderr] 349 | pub fn first_line(s: &str) -> &str {
[INFO] [stderr]     |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_title_from_content` is never used
[INFO] [stderr]    --> src/utils/mod.rs:354:8
[INFO] [stderr]     |
[INFO] [stderr] 354 | pub fn get_title_from_content(content: &str) -> String {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `VERSION_LETTER` is never used
[INFO] [stderr]  --> src/version.rs:7:11
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub const VERSION_LETTER: &str = "v-pocket-R1";
[INFO] [stderr]   |           ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `VERSION_DATE` is never used
[INFO] [stderr]   --> src/version.rs:10:11
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub const VERSION_DATE: &str = "04012025";
[INFO] [stderr]    |           ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `VERSION_STRING` is never used
[INFO] [stderr]   --> src/version.rs:13:11
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub const VERSION_STRING: &str = "Pocket v-pocket-R1 (03172025 - Core Implementations)";
[INFO] [stderr]    |           ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `COMPATIBILITY` is never used
[INFO] [stderr]   --> src/version.rs:16:11
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub const COMPATIBILITY: Option<&str> = Some("");
[INFO] [stderr]    |           ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `AUTHOR` is never used
[INFO] [stderr]   --> src/version.rs:18:11
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub const AUTHOR: &str = "frgmt0 (j)";
[INFO] [stderr]    |           ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_version` is never used
[INFO] [stderr]   --> src/version.rs:21:8
[INFO] [stderr]    |
[INFO] [stderr] 21 | pub fn get_version() -> Version {
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `Stability` is never used
[INFO] [stderr]   --> src/version.rs:34:10
[INFO] [stderr]    |
[INFO] [stderr] 34 | pub enum Stability {
[INFO] [stderr]    |          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Version` is never constructed
[INFO] [stderr]   --> src/version.rs:60:12
[INFO] [stderr]    |
[INFO] [stderr] 60 | pub struct Version {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `pocket-cli` (bin "pocket" test) generated 80 warnings (24 duplicates) (run `cargo fix --bin "pocket" --tests` to apply 2 suggestions)
[INFO] [stderr] warning: `pocket-cli` (lib test) generated 28 warnings (28 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.33s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/pocket_cli-eef322311c7de234)
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/pocket-ddabc8506bd2dafd)
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests pocket_cli
[INFO] [stdout] running 3 tests
[INFO] [stdout] test utils::clipboard::tests::test_clipboard_write_read ... ignored
[INFO] [stdout] test utils::summarization::tests::test_summary_metadata_serialization ... ok
[INFO] [stdout] test utils::summarization::tests::test_fallback_summarization ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test utils::clipboard::tests::test_clipboard_write_read ... ignored
[INFO] [stdout] test utils::summarization::tests::test_summary_metadata_serialization ... ok
[INFO] [stdout] test utils::summarization::tests::test_fallback_summarization ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 1 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" "e0e8486842c97fcf99ca843dbbb7e738b4aaf573143ad6502e71c4d07497e81c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e0e8486842c97fcf99ca843dbbb7e738b4aaf573143ad6502e71c4d07497e81c", kill_on_drop: false }`
[INFO] [stdout] e0e8486842c97fcf99ca843dbbb7e738b4aaf573143ad6502e71c4d07497e81c
