[INFO] fetching crate pocket-cli 1.0.2...
[INFO] building pocket-cli-1.0.2 against master#ad85bc524b1ad696e42061ad8338d382dffbdbe5 for pr-146237-1
[INFO] extracting crate pocket-cli 1.0.2 into /workspace/builds/worker-7-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-7-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate pocket-cli 1.0.2 on toolchain ad85bc524b1ad696e42061ad8338d382dffbdbe5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "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" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "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 hostname v0.4.0
[INFO] [stderr]   Downloaded toml v0.8.20
[INFO] [stderr]   Downloaded owo-colors v4.2.0
[INFO] [stderr]   Downloaded safetensors v0.3.3
[INFO] [stderr]   Downloaded password-hash v0.4.2
[INFO] [stderr]   Downloaded uuid v1.15.1
[INFO] [stderr]   Downloaded downcast v0.11.0
[INFO] [stderr]   Downloaded assert_fs v1.1.2
[INFO] [stderr]   Downloaded dialoguer v0.11.0
[INFO] [stderr]   Downloaded fragile v2.0.0
[INFO] [stderr]   Downloaded unicode-normalization-alignments v0.1.12
[INFO] [stderr]   Downloaded rust_tokenizers v8.1.1
[INFO] [stderr]   Downloaded rstest v0.25.0
[INFO] [stderr]   Downloaded torch-sys v0.13.0
[INFO] [stderr]   Downloaded rstest_macros v0.25.0
[INFO] [stderr]   Downloaded openssl-sys v0.9.106
[INFO] [stderr]   Downloaded cached-path v0.6.1
[INFO] [stderr]   Downloaded indicatif v0.17.11
[INFO] [stderr]   Downloaded mockall v0.13.1
[INFO] [stderr]   Downloaded rust-bert v0.21.0
[INFO] [stderr]   Downloaded redox_syscall v0.5.10
[INFO] [stderr]   Downloaded ordered-float v3.9.2
[INFO] [stderr]   Downloaded mockall_derive v0.13.1
[INFO] [stderr]   Downloaded indicatif v0.16.2
[INFO] [stderr]   Downloaded xattr v1.5.0
[INFO] [stderr]   Downloaded openssl v0.10.71
[INFO] [stderr]   Downloaded tokio v1.44.0
[INFO] [stderr]   Downloaded tch v0.13.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] b6ceb9791b8fbbb9553d2d160cea486f0072985ddae94dfe3d427ac0c7374eb9
[INFO] running `Command { std: "docker" "start" "-a" "b6ceb9791b8fbbb9553d2d160cea486f0072985ddae94dfe3d427ac0c7374eb9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "b6ceb9791b8fbbb9553d2d160cea486f0072985ddae94dfe3d427ac0c7374eb9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b6ceb9791b8fbbb9553d2d160cea486f0072985ddae94dfe3d427ac0c7374eb9", kill_on_drop: false }`
[INFO] [stdout] b6ceb9791b8fbbb9553d2d160cea486f0072985ddae94dfe3d427ac0c7374eb9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b6cd2446fc6b224b2cc3766ab59e57d7619ed09c1369a32e28e5c42301718169
[INFO] running `Command { std: "docker" "start" "-a" "b6cd2446fc6b224b2cc3766ab59e57d7619ed09c1369a32e28e5c42301718169", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.171
[INFO] [stderr]    Compiling icu_locid_transform_data v1.5.0
[INFO] [stderr]    Compiling icu_properties_data v1.5.0
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling syn v2.0.100
[INFO] [stderr]    Compiling smallvec v1.14.0
[INFO] [stderr]    Compiling icu_normalizer_data v1.5.0
[INFO] [stderr]    Compiling once_cell v1.21.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling unicode-width v0.2.0
[INFO] [stderr]    Compiling linux-raw-sys v0.9.2
[INFO] [stderr]    Compiling portable-atomic v1.11.0
[INFO] [stderr]    Compiling winnow v0.7.3
[INFO] [stderr]    Compiling anyhow v1.0.97
[INFO] [stderr]    Compiling getrandom v0.3.1
[INFO] [stderr]    Compiling console v0.15.11
[INFO] [stderr]    Compiling owo-colors v4.2.0
[INFO] [stderr]    Compiling dirs-sys v0.5.0
[INFO] [stderr]    Compiling rustix v1.0.2
[INFO] [stderr]    Compiling is-terminal v0.4.16
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling number_prefix v0.4.0
[INFO] [stderr]    Compiling shell-words v1.1.0
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling zeroize v1.8.1
[INFO] [stderr]    Compiling log v0.4.26
[INFO] [stderr]    Compiling indicatif v0.17.11
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling dirs v6.0.0
[INFO] [stderr]    Compiling env_logger v0.10.2
[INFO] [stderr]    Compiling hostname v0.4.0
[INFO] [stderr]    Compiling libloading v0.8.6
[INFO] [stderr]    Compiling glob v0.3.2
[INFO] [stderr]    Compiling similar v2.7.0
[INFO] [stderr]    Compiling colored v3.0.0
[INFO] [stderr]    Compiling tempfile v3.18.0
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.7.5
[INFO] [stderr]    Compiling zerovec-derive v0.10.3
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling serde_derive v1.0.219
[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 zerofrom v0.1.6
[INFO] [stderr]    Compiling thiserror v1.0.69
[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 serde v1.0.219
[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 icu_normalizer v1.5.0
[INFO] [stderr]    Compiling toml_datetime v0.6.8
[INFO] [stderr]    Compiling serde_spanned v0.6.8
[INFO] [stderr]    Compiling rust-stemmers v1.2.0
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling uuid v1.15.1
[INFO] [stderr]    Compiling chrono v0.4.40
[INFO] [stderr]    Compiling toml_edit v0.22.24
[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 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: `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 1m 11s
[INFO] running `Command { std: "docker" "inspect" "b6cd2446fc6b224b2cc3766ab59e57d7619ed09c1369a32e28e5c42301718169", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b6cd2446fc6b224b2cc3766ab59e57d7619ed09c1369a32e28e5c42301718169", kill_on_drop: false }`
[INFO] [stdout] b6cd2446fc6b224b2cc3766ab59e57d7619ed09c1369a32e28e5c42301718169
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 167a755ca7dcfa596772d9367ebf6227f28eff86d9023f6564b1efbfa2dcd4bc
[INFO] running `Command { std: "docker" "start" "-a" "167a755ca7dcfa596772d9367ebf6227f28eff86d9023f6564b1efbfa2dcd4bc", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.100
[INFO] [stderr]    Compiling getrandom v0.3.1
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling zerocopy v0.8.23
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling memchr v2.7.4
[INFO] [stderr]    Compiling bstr v1.11.3
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling tempfile v3.18.0
[INFO] [stderr]    Compiling predicates-core v1.0.9
[INFO] [stderr]    Compiling toml_datetime v0.6.8
[INFO] [stderr]    Compiling rstest_macros v0.25.0
[INFO] [stderr]    Compiling toml_edit v0.22.24
[INFO] [stderr]    Compiling half v2.4.1
[INFO] [stderr]    Compiling difflib v0.4.0
[INFO] [stderr]    Compiling mockall_derive v0.13.1
[INFO] [stderr]    Compiling float-cmp v0.10.0
[INFO] [stderr]    Compiling normalize-line-endings v0.3.0
[INFO] [stderr]    Compiling termtree v0.5.1
[INFO] [stderr]    Compiling doc-comment v0.3.3
[INFO] [stderr]    Compiling predicates-tree v1.0.12
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling ciborium-ll v0.2.2
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling wait-timeout v0.2.1
[INFO] [stderr]    Compiling relative-path v1.9.3
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rusty-fork v0.3.0
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling proc-macro-crate v3.3.0
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling plotters v0.3.7
[INFO] [stderr]    Compiling rand_xorshift v0.3.0
[INFO] [stderr]    Compiling fragile v2.0.0
[INFO] [stderr]    Compiling downcast v0.11.0
[INFO] [stderr]    Compiling futures-timer v3.0.3
[INFO] [stderr]    Compiling proptest v1.6.0
[INFO] [stderr]    Compiling rand v0.9.0
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling globset v0.4.16
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling predicates v3.1.3
[INFO] [stderr]    Compiling ignore v0.4.23
[INFO] [stderr]    Compiling test-case-core v3.3.1
[INFO] [stderr]    Compiling env_logger v0.10.2
[INFO] [stderr]    Compiling globwalk v0.9.1
[INFO] [stderr]    Compiling assert_fs v1.1.2
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling yoke-derive v0.7.5
[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 clap_derive v4.5.32
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling test-case-macros v3.3.1
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.7.5
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling zerovec v0.10.4
[INFO] [stderr]    Compiling dialoguer v0.11.0
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling tinystr v0.7.6
[INFO] [stderr]    Compiling icu_locid v1.5.0
[INFO] [stderr]    Compiling icu_collections v1.5.0
[INFO] [stderr]    Compiling clap v4.5.32
[INFO] [stderr]    Compiling test-case v3.3.1
[INFO] [stderr]    Compiling icu_provider v1.5.0
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling icu_locid_transform v1.5.0
[INFO] [stderr]    Compiling rstest v0.25.0
[INFO] [stderr]    Compiling mockall v0.13.1
[INFO] [stderr]    Compiling icu_properties v1.5.1
[INFO] [stderr]    Compiling serde_spanned v0.6.8
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling chrono v0.4.40
[INFO] [stderr]    Compiling rust-stemmers v1.2.0
[INFO] [stderr]    Compiling uuid v1.15.1
[INFO] [stderr]    Compiling ciborium v0.2.2
[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 tinytemplate v1.2.1
[INFO] [stderr]    Compiling url v2.5.4
[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 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: 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 1m 58s
[INFO] running `Command { std: "docker" "inspect" "167a755ca7dcfa596772d9367ebf6227f28eff86d9023f6564b1efbfa2dcd4bc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "167a755ca7dcfa596772d9367ebf6227f28eff86d9023f6564b1efbfa2dcd4bc", kill_on_drop: false }`
[INFO] [stdout] 167a755ca7dcfa596772d9367ebf6227f28eff86d9023f6564b1efbfa2dcd4bc
