[INFO] cloning repository https://github.com/bradleyd/sparkle
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/bradleyd/sparkle" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbradleyd%2Fsparkle", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbradleyd%2Fsparkle'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 41e37105c5237dbbc97e09e67db3c413def8e742
[INFO] testing bradleyd/sparkle against beta-2025-09-21 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbradleyd%2Fsparkle" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/bradleyd/sparkle
[INFO] finished tweaking git repo https://github.com/bradleyd/sparkle
[INFO] tweaked toml for git repo https://github.com/bradleyd/sparkle written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/bradleyd/sparkle on toolchain beta-2025-09-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/bradleyd/sparkle 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" "+beta-2025-09-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] b0764e69b1c5541ad86a075c9477211a86f05df378f243971089fa79c0a882d9
[INFO] running `Command { std: "docker" "start" "-a" "b0764e69b1c5541ad86a075c9477211a86f05df378f243971089fa79c0a882d9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "b0764e69b1c5541ad86a075c9477211a86f05df378f243971089fa79c0a882d9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b0764e69b1c5541ad86a075c9477211a86f05df378f243971089fa79c0a882d9", kill_on_drop: false }`
[INFO] [stdout] b0764e69b1c5541ad86a075c9477211a86f05df378f243971089fa79c0a882d9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0c167a77989962c3936cb7c1c2e20f0c694eacc443b7a3108429c092eebad076
[INFO] running `Command { std: "docker" "start" "-a" "0c167a77989962c3936cb7c1c2e20f0c694eacc443b7a3108429c092eebad076", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.104
[INFO] [stderr]    Compiling siphasher v1.0.1
[INFO] [stderr]    Compiling anstyle-query v1.1.3
[INFO] [stderr]    Compiling colorchoice v1.0.4
[INFO] [stderr]    Compiling anstyle v1.0.11
[INFO] [stderr]    Compiling memchr v2.7.5
[INFO] [stderr]    Compiling winnow v0.7.11
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling anstyle-parse v0.2.7
[INFO] [stderr]    Compiling log v0.4.27
[INFO] [stderr]    Compiling clap_lex v0.7.5
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling toml_writer v1.0.0
[INFO] [stderr]    Compiling file-format v0.27.0
[INFO] [stderr]    Compiling phf_shared v0.11.3
[INFO] [stderr]    Compiling phf v0.11.3
[INFO] [stderr]    Compiling mime_guess2 v2.3.1
[INFO] [stderr]    Compiling anstream v0.6.19
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling clap_builder v4.5.41
[INFO] [stderr]    Compiling toml_parser v1.0.0
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling clap_derive v4.5.41
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling clap v4.5.41
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling tracing-serde v0.2.0
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling serde_spanned v1.0.0
[INFO] [stderr]    Compiling toml_datetime v0.7.0
[INFO] [stderr]    Compiling toml v0.9.1
[INFO] [stderr]    Compiling tracing-subscriber v0.3.19
[INFO] [stderr]    Compiling sparkle v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `pattern`
[INFO] [stdout]   --> src/handlers/action.rs:64:17
[INFO] [stdout]    |
[INFO] [stdout] 64 |                 pattern,
[INFO] [stdout]    |                 ^^^^^^^ help: try ignoring the field: `pattern: _`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_created_time` is never used
[INFO] [stdout]   --> src/crawl.rs:73:4
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn get_created_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_access_time` is never used
[INFO] [stdout]   --> src/crawl.rs:84:4
[INFO] [stdout]    |
[INFO] [stdout] 84 | fn get_access_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_parent_dir` is never used
[INFO] [stdout]    --> src/file_metadata.rs:198:4
[INFO] [stdout]     |
[INFO] [stdout] 198 | fn get_parent_dir(p: &Path) -> PathBuf {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pattern`
[INFO] [stdout]   --> src/handlers/action.rs:64:17
[INFO] [stdout]    |
[INFO] [stdout] 64 |                 pattern,
[INFO] [stdout]    |                 ^^^^^^^ help: try ignoring the field: `pattern: _`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompressionFormat` is never constructed
[INFO] [stdout]   --> src/config.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct CompressionFormat {}
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/content_info.rs:7:9
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub struct ContentInfo {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout]  6 |     // MIME type detection
[INFO] [stdout]  7 |     pub mime_type: String,    // "image/jpeg", "text/plain", etc.
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]  8 |     pub mime_confidence: f32, // How confident the detection is
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 11 |     pub media_info: Option<MediaInfo>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 12 |     pub document_info: Option<DocumentInfo>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 13 |     pub archive_info: Option<ArchiveInfo>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     pub text_encoding: Option<String>, // UTF-8, ASCII, etc.
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 17 |     pub language: Option<String>,      // For text files
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 18 |     pub hash: Option<String>,          // SHA-256 for deduplication
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 19 |     pub has_metadata: bool,            // EXIF, ID3 ta
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ContentInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/content_info.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub struct MediaInfo {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] 24 |     pub width: Option<u32>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 25 |     pub height: Option<u32>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 26 |     pub duration: Option<Duration>,     // For video/audio
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 27 |     pub date_taken: Option<SystemTime>, // From EXIF
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 28 |     pub camera_make: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 29 |     pub camera_model: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 30 |     pub gps_coordinates: Option<(f64, f64)>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MediaInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `page_count`, `word_count`, `author`, `title`, and `created_date` are never read
[INFO] [stdout]   --> src/content_info.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct DocumentInfo {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] 35 |     pub page_count: Option<u32>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 36 |     pub word_count: Option<u32>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 37 |     pub author: Option<String>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 38 |     pub title: Option<String>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 39 |     pub created_date: Option<SystemTime>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DocumentInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `format`, `file_count`, `uncompressed_size`, and `compression_ratio` are never read
[INFO] [stdout]   --> src/content_info.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub struct ArchiveInfo {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 44 |     pub format: String, // "zip", "tar.gz", etc.
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 45 |     pub file_count: u32,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 46 |     pub uncompressed_size: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 47 |     pub compression_ratio: f32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ArchiveInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_created_time` is never used
[INFO] [stdout]   --> src/crawl.rs:73:4
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn get_created_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_access_time` is never used
[INFO] [stdout]   --> src/crawl.rs:84:4
[INFO] [stdout]    |
[INFO] [stdout] 84 | fn get_access_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `NoMetaData` and `InvalidInput` are never constructed
[INFO] [stdout]   --> src/file_metadata.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum FileMetadataError {
[INFO] [stdout]    |          ----------------- variants in this enum
[INFO] [stdout] 12 |     NoMetaData,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 13 |     InvalidInput(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FileMetadataError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `path`, `metadata`, `content_info`, `parent_dir`, and `base_dir` are never read
[INFO] [stdout]   --> src/file_metadata.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct FileContext {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 47 |     pub path: PathBuf,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 48 |     pub metadata: FileMetadata,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 49 |     pub content_info: Option<ContentInfo>, // MIME type, etc.
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 50 |     pub parent_dir: PathBuf,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 51 |     pub base_dir: PathBuf, // The root we're organizing from
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FileContext` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Large` and `Huge` are never constructed
[INFO] [stdout]    --> src/file_metadata.rs:99:5
[INFO] [stdout]     |
[INFO] [stdout]  95 | pub enum SizeCategory {
[INFO] [stdout]     |          ------------ variants in this enum
[INFO] [stdout] ...
[INFO] [stdout]  99 |     Large,  // 100MB - 1GB
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 100 |     Huge,   // > 1GB
[INFO] [stdout]     |     ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `SizeCategory` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Video` and `Audio` are never constructed
[INFO] [stdout]    --> src/file_metadata.rs:116:5
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub enum FileType {
[INFO] [stdout]     |          -------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 116 |     Video,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 117 |     Audio,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `FileType` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `as_str` is never used
[INFO] [stdout]    --> src/file_metadata.rs:126:12
[INFO] [stdout]     |
[INFO] [stdout] 125 | impl FileType {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] 126 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_parent_dir` is never used
[INFO] [stdout]    --> src/file_metadata.rs:198:4
[INFO] [stdout]     |
[INFO] [stdout] 198 | fn get_parent_dir(p: &Path) -> PathBuf {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 24.27s
[INFO] running `Command { std: "docker" "inspect" "0c167a77989962c3936cb7c1c2e20f0c694eacc443b7a3108429c092eebad076", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0c167a77989962c3936cb7c1c2e20f0c694eacc443b7a3108429c092eebad076", kill_on_drop: false }`
[INFO] [stdout] 0c167a77989962c3936cb7c1c2e20f0c694eacc443b7a3108429c092eebad076
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1fce7392c977a61c967427444910fec52d9cca80ea309aad719c34a068e112d2
[INFO] running `Command { std: "docker" "start" "-a" "1fce7392c977a61c967427444910fec52d9cca80ea309aad719c34a068e112d2", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.174
[INFO] [stderr]    Compiling rustix v1.0.8
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling linux-raw-sys v0.9.4
[INFO] [stderr]    Compiling bitflags v2.9.1
[INFO] [stdout] warning: unused variable: `pattern`
[INFO] [stdout]   --> src/handlers/action.rs:64:17
[INFO] [stdout]    |
[INFO] [stdout] 64 |                 pattern,
[INFO] [stdout]    |                 ^^^^^^^ help: try ignoring the field: `pattern: _`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_created_time` is never used
[INFO] [stdout]   --> src/crawl.rs:73:4
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn get_created_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_access_time` is never used
[INFO] [stdout]   --> src/crawl.rs:84:4
[INFO] [stdout]    |
[INFO] [stdout] 84 | fn get_access_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_parent_dir` is never used
[INFO] [stdout]    --> src/file_metadata.rs:198:4
[INFO] [stdout]     |
[INFO] [stdout] 198 | fn get_parent_dir(p: &Path) -> PathBuf {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pattern`
[INFO] [stdout]   --> src/handlers/action.rs:64:17
[INFO] [stdout]    |
[INFO] [stdout] 64 |                 pattern,
[INFO] [stdout]    |                 ^^^^^^^ help: try ignoring the field: `pattern: _`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompressionFormat` is never constructed
[INFO] [stdout]   --> src/config.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct CompressionFormat {}
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/content_info.rs:7:9
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub struct ContentInfo {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout]  6 |     // MIME type detection
[INFO] [stdout]  7 |     pub mime_type: String,    // "image/jpeg", "text/plain", etc.
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]  8 |     pub mime_confidence: f32, // How confident the detection is
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 11 |     pub media_info: Option<MediaInfo>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 12 |     pub document_info: Option<DocumentInfo>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 13 |     pub archive_info: Option<ArchiveInfo>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     pub text_encoding: Option<String>, // UTF-8, ASCII, etc.
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 17 |     pub language: Option<String>,      // For text files
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 18 |     pub hash: Option<String>,          // SHA-256 for deduplication
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 19 |     pub has_metadata: bool,            // EXIF, ID3 ta
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ContentInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/content_info.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub struct MediaInfo {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] 24 |     pub width: Option<u32>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 25 |     pub height: Option<u32>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 26 |     pub duration: Option<Duration>,     // For video/audio
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 27 |     pub date_taken: Option<SystemTime>, // From EXIF
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 28 |     pub camera_make: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 29 |     pub camera_model: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 30 |     pub gps_coordinates: Option<(f64, f64)>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MediaInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `page_count`, `word_count`, `author`, `title`, and `created_date` are never read
[INFO] [stdout]   --> src/content_info.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct DocumentInfo {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] 35 |     pub page_count: Option<u32>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 36 |     pub word_count: Option<u32>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 37 |     pub author: Option<String>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 38 |     pub title: Option<String>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 39 |     pub created_date: Option<SystemTime>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DocumentInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `format`, `file_count`, `uncompressed_size`, and `compression_ratio` are never read
[INFO] [stdout]   --> src/content_info.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub struct ArchiveInfo {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 44 |     pub format: String, // "zip", "tar.gz", etc.
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 45 |     pub file_count: u32,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 46 |     pub uncompressed_size: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 47 |     pub compression_ratio: f32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ArchiveInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_created_time` is never used
[INFO] [stdout]   --> src/crawl.rs:73:4
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn get_created_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_access_time` is never used
[INFO] [stdout]   --> src/crawl.rs:84:4
[INFO] [stdout]    |
[INFO] [stdout] 84 | fn get_access_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `NoMetaData` and `InvalidInput` are never constructed
[INFO] [stdout]   --> src/file_metadata.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum FileMetadataError {
[INFO] [stdout]    |          ----------------- variants in this enum
[INFO] [stdout] 12 |     NoMetaData,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 13 |     InvalidInput(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FileMetadataError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `path`, `metadata`, `content_info`, `parent_dir`, and `base_dir` are never read
[INFO] [stdout]   --> src/file_metadata.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct FileContext {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 47 |     pub path: PathBuf,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 48 |     pub metadata: FileMetadata,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 49 |     pub content_info: Option<ContentInfo>, // MIME type, etc.
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 50 |     pub parent_dir: PathBuf,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 51 |     pub base_dir: PathBuf, // The root we're organizing from
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FileContext` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Large` and `Huge` are never constructed
[INFO] [stdout]    --> src/file_metadata.rs:99:5
[INFO] [stdout]     |
[INFO] [stdout]  95 | pub enum SizeCategory {
[INFO] [stdout]     |          ------------ variants in this enum
[INFO] [stdout] ...
[INFO] [stdout]  99 |     Large,  // 100MB - 1GB
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 100 |     Huge,   // > 1GB
[INFO] [stdout]     |     ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `SizeCategory` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Video` and `Audio` are never constructed
[INFO] [stdout]    --> src/file_metadata.rs:116:5
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub enum FileType {
[INFO] [stdout]     |          -------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 116 |     Video,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 117 |     Audio,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `FileType` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `as_str` is never used
[INFO] [stdout]    --> src/file_metadata.rs:126:12
[INFO] [stdout]     |
[INFO] [stdout] 125 | impl FileType {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] 126 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_parent_dir` is never used
[INFO] [stdout]    --> src/file_metadata.rs:198:4
[INFO] [stdout]     |
[INFO] [stdout] 198 | fn get_parent_dir(p: &Path) -> PathBuf {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling tempfile v3.20.0
[INFO] [stderr]    Compiling sparkle v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `pattern`
[INFO] [stdout]   --> src/handlers/action.rs:64:17
[INFO] [stdout]    |
[INFO] [stdout] 64 |                 pattern,
[INFO] [stdout]    |                 ^^^^^^^ help: try ignoring the field: `pattern: _`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_created_time` is never used
[INFO] [stdout]   --> src/crawl.rs:73:4
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn get_created_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_access_time` is never used
[INFO] [stdout]   --> src/crawl.rs:84:4
[INFO] [stdout]    |
[INFO] [stdout] 84 | fn get_access_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_parent_dir` is never used
[INFO] [stdout]    --> src/file_metadata.rs:198:4
[INFO] [stdout]     |
[INFO] [stdout] 198 | fn get_parent_dir(p: &Path) -> PathBuf {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pattern`
[INFO] [stdout]   --> src/handlers/action.rs:64:17
[INFO] [stdout]    |
[INFO] [stdout] 64 |                 pattern,
[INFO] [stdout]    |                 ^^^^^^^ help: try ignoring the field: `pattern: _`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompressionFormat` is never constructed
[INFO] [stdout]   --> src/config.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct CompressionFormat {}
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/content_info.rs:7:9
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub struct ContentInfo {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout]  6 |     // MIME type detection
[INFO] [stdout]  7 |     pub mime_type: String,    // "image/jpeg", "text/plain", etc.
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]  8 |     pub mime_confidence: f32, // How confident the detection is
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 11 |     pub media_info: Option<MediaInfo>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 12 |     pub document_info: Option<DocumentInfo>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 13 |     pub archive_info: Option<ArchiveInfo>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     pub text_encoding: Option<String>, // UTF-8, ASCII, etc.
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 17 |     pub language: Option<String>,      // For text files
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 18 |     pub hash: Option<String>,          // SHA-256 for deduplication
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 19 |     pub has_metadata: bool,            // EXIF, ID3 ta
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ContentInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/content_info.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub struct MediaInfo {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] 24 |     pub width: Option<u32>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 25 |     pub height: Option<u32>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 26 |     pub duration: Option<Duration>,     // For video/audio
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 27 |     pub date_taken: Option<SystemTime>, // From EXIF
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 28 |     pub camera_make: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 29 |     pub camera_model: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 30 |     pub gps_coordinates: Option<(f64, f64)>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MediaInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `page_count`, `word_count`, `author`, `title`, and `created_date` are never read
[INFO] [stdout]   --> src/content_info.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct DocumentInfo {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] 35 |     pub page_count: Option<u32>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 36 |     pub word_count: Option<u32>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 37 |     pub author: Option<String>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 38 |     pub title: Option<String>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 39 |     pub created_date: Option<SystemTime>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DocumentInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `format`, `file_count`, `uncompressed_size`, and `compression_ratio` are never read
[INFO] [stdout]   --> src/content_info.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub struct ArchiveInfo {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 44 |     pub format: String, // "zip", "tar.gz", etc.
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 45 |     pub file_count: u32,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 46 |     pub uncompressed_size: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 47 |     pub compression_ratio: f32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ArchiveInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_created_time` is never used
[INFO] [stdout]   --> src/crawl.rs:73:4
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn get_created_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_access_time` is never used
[INFO] [stdout]   --> src/crawl.rs:84:4
[INFO] [stdout]    |
[INFO] [stdout] 84 | fn get_access_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `NoMetaData` and `InvalidInput` are never constructed
[INFO] [stdout]   --> src/file_metadata.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum FileMetadataError {
[INFO] [stdout]    |          ----------------- variants in this enum
[INFO] [stdout] 12 |     NoMetaData,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 13 |     InvalidInput(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FileMetadataError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `path`, `metadata`, `content_info`, `parent_dir`, and `base_dir` are never read
[INFO] [stdout]   --> src/file_metadata.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct FileContext {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 47 |     pub path: PathBuf,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 48 |     pub metadata: FileMetadata,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 49 |     pub content_info: Option<ContentInfo>, // MIME type, etc.
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 50 |     pub parent_dir: PathBuf,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 51 |     pub base_dir: PathBuf, // The root we're organizing from
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FileContext` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Large` and `Huge` are never constructed
[INFO] [stdout]    --> src/file_metadata.rs:99:5
[INFO] [stdout]     |
[INFO] [stdout]  95 | pub enum SizeCategory {
[INFO] [stdout]     |          ------------ variants in this enum
[INFO] [stdout] ...
[INFO] [stdout]  99 |     Large,  // 100MB - 1GB
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 100 |     Huge,   // > 1GB
[INFO] [stdout]     |     ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `SizeCategory` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Video` and `Audio` are never constructed
[INFO] [stdout]    --> src/file_metadata.rs:116:5
[INFO] [stdout]     |
[INFO] [stdout] 113 | pub enum FileType {
[INFO] [stdout]     |          -------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 116 |     Video,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 117 |     Audio,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `FileType` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `as_str` is never used
[INFO] [stdout]    --> src/file_metadata.rs:126:12
[INFO] [stdout]     |
[INFO] [stdout] 125 | impl FileType {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] 126 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_parent_dir` is never used
[INFO] [stdout]    --> src/file_metadata.rs:198:4
[INFO] [stdout]     |
[INFO] [stdout] 198 | fn get_parent_dir(p: &Path) -> PathBuf {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 6.23s
[INFO] running `Command { std: "docker" "inspect" "1fce7392c977a61c967427444910fec52d9cca80ea309aad719c34a068e112d2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1fce7392c977a61c967427444910fec52d9cca80ea309aad719c34a068e112d2", kill_on_drop: false }`
[INFO] [stdout] 1fce7392c977a61c967427444910fec52d9cca80ea309aad719c34a068e112d2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 61db27e3b16ae82f49c147d8e9de7ecfe48741a4e40af60f32379813a2a57619
[INFO] running `Command { std: "docker" "start" "-a" "61db27e3b16ae82f49c147d8e9de7ecfe48741a4e40af60f32379813a2a57619", kill_on_drop: false }`
[INFO] [stderr] warning: unused variable: `pattern`
[INFO] [stderr]   --> src/handlers/action.rs:64:17
[INFO] [stderr]    |
[INFO] [stderr] 64 |                 pattern,
[INFO] [stderr]    |                 ^^^^^^^ help: try ignoring the field: `pattern: _`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_created_time` is never used
[INFO] [stderr]   --> src/crawl.rs:73:4
[INFO] [stderr]    |
[INFO] [stderr] 73 | fn get_created_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_access_time` is never used
[INFO] [stderr]   --> src/crawl.rs:84:4
[INFO] [stderr]    |
[INFO] [stderr] 84 | fn get_access_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_parent_dir` is never used
[INFO] [stderr]    --> src/file_metadata.rs:198:4
[INFO] [stderr]     |
[INFO] [stderr] 198 | fn get_parent_dir(p: &Path) -> PathBuf {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `sparkle` (lib) generated 4 warnings
[INFO] [stderr] warning: `sparkle` (lib test) generated 4 warnings (4 duplicates)
[INFO] [stderr] warning: struct `CompressionFormat` is never constructed
[INFO] [stderr]   --> src/config.rs:20:12
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub struct CompressionFormat {}
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: multiple fields are never read
[INFO] [stderr]   --> src/content_info.rs:7:9
[INFO] [stderr]    |
[INFO] [stderr]  5 | pub struct ContentInfo {
[INFO] [stderr]    |            ----------- fields in this struct
[INFO] [stderr]  6 |     // MIME type detection
[INFO] [stderr]  7 |     pub mime_type: String,    // "image/jpeg", "text/plain", etc.
[INFO] [stderr]    |         ^^^^^^^^^
[INFO] [stderr]  8 |     pub mime_confidence: f32, // How confident the detection is
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 11 |     pub media_info: Option<MediaInfo>,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr] 12 |     pub document_info: Option<DocumentInfo>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^
[INFO] [stderr] 13 |     pub archive_info: Option<ArchiveInfo>,
[INFO] [stderr]    |         ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 16 |     pub text_encoding: Option<String>, // UTF-8, ASCII, etc.
[INFO] [stderr]    |         ^^^^^^^^^^^^^
[INFO] [stderr] 17 |     pub language: Option<String>,      // For text files
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] 18 |     pub hash: Option<String>,          // SHA-256 for deduplication
[INFO] [stderr]    |         ^^^^
[INFO] [stderr] 19 |     pub has_metadata: bool,            // EXIF, ID3 ta
[INFO] [stderr]    |         ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ContentInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: multiple fields are never read
[INFO] [stderr]   --> src/content_info.rs:24:9
[INFO] [stderr]    |
[INFO] [stderr] 23 | pub struct MediaInfo {
[INFO] [stderr]    |            --------- fields in this struct
[INFO] [stderr] 24 |     pub width: Option<u32>,
[INFO] [stderr]    |         ^^^^^
[INFO] [stderr] 25 |     pub height: Option<u32>,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 26 |     pub duration: Option<Duration>,     // For video/audio
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] 27 |     pub date_taken: Option<SystemTime>, // From EXIF
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr] 28 |     pub camera_make: Option<String>,
[INFO] [stderr]    |         ^^^^^^^^^^^
[INFO] [stderr] 29 |     pub camera_model: Option<String>,
[INFO] [stderr]    |         ^^^^^^^^^^^^
[INFO] [stderr] 30 |     pub gps_coordinates: Option<(f64, f64)>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MediaInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `page_count`, `word_count`, `author`, `title`, and `created_date` are never read
[INFO] [stderr]   --> src/content_info.rs:35:9
[INFO] [stderr]    |
[INFO] [stderr] 34 | pub struct DocumentInfo {
[INFO] [stderr]    |            ------------ fields in this struct
[INFO] [stderr] 35 |     pub page_count: Option<u32>,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr] 36 |     pub word_count: Option<u32>,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr] 37 |     pub author: Option<String>,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 38 |     pub title: Option<String>,
[INFO] [stderr]    |         ^^^^^
[INFO] [stderr] 39 |     pub created_date: Option<SystemTime>,
[INFO] [stderr]    |         ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `DocumentInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `format`, `file_count`, `uncompressed_size`, and `compression_ratio` are never read
[INFO] [stderr]   --> src/content_info.rs:44:9
[INFO] [stderr]    |
[INFO] [stderr] 43 | pub struct ArchiveInfo {
[INFO] [stderr]    |            ----------- fields in this struct
[INFO] [stderr] 44 |     pub format: String, // "zip", "tar.gz", etc.
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 45 |     pub file_count: u32,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr] 46 |     pub uncompressed_size: u64,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 47 |     pub compression_ratio: f32,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ArchiveInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_created_time` is never used
[INFO] [stderr]   --> src/crawl.rs:73:4
[INFO] [stderr]    |
[INFO] [stderr] 73 | fn get_created_time(metadata: &Metadata) -> Option<SystemTime> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `NoMetaData` and `InvalidInput` are never constructed
[INFO] [stderr]   --> src/file_metadata.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub enum FileMetadataError {
[INFO] [stderr]    |          ----------------- variants in this enum
[INFO] [stderr] 12 |     NoMetaData,
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] 13 |     InvalidInput(String),
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `FileMetadataError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `path`, `metadata`, `content_info`, `parent_dir`, and `base_dir` are never read
[INFO] [stderr]   --> src/file_metadata.rs:47:9
[INFO] [stderr]    |
[INFO] [stderr] 46 | pub struct FileContext {
[INFO] [stderr]    |            ----------- fields in this struct
[INFO] [stderr] 47 |     pub path: PathBuf,
[INFO] [stderr]    |         ^^^^
[INFO] [stderr] 48 |     pub metadata: FileMetadata,
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] 49 |     pub content_info: Option<ContentInfo>, // MIME type, etc.
[INFO] [stderr]    |         ^^^^^^^^^^^^
[INFO] [stderr] 50 |     pub parent_dir: PathBuf,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr] 51 |     pub base_dir: PathBuf, // The root we're organizing from
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `FileContext` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Large` and `Huge` are never constructed
[INFO] [stderr]    --> src/file_metadata.rs:99:5
[INFO] [stderr]     |
[INFO] [stderr]  95 | pub enum SizeCategory {
[INFO] [stderr]     |          ------------ variants in this enum
[INFO] [stderr] ...
[INFO] [stderr]  99 |     Large,  // 100MB - 1GB
[INFO] [stderr]     |     ^^^^^
[INFO] [stderr] 100 |     Huge,   // > 1GB
[INFO] [stderr]     |     ^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `SizeCategory` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Video` and `Audio` are never constructed
[INFO] [stderr]    --> src/file_metadata.rs:116:5
[INFO] [stderr]     |
[INFO] [stderr] 113 | pub enum FileType {
[INFO] [stderr]     |          -------- variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 116 |     Video,
[INFO] [stderr]     |     ^^^^^
[INFO] [stderr] 117 |     Audio,
[INFO] [stderr]     |     ^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `FileType` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: method `as_str` is never used
[INFO] [stderr]    --> src/file_metadata.rs:126:12
[INFO] [stderr]     |
[INFO] [stderr] 125 | impl FileType {
[INFO] [stderr]     | ------------- method in this implementation
[INFO] [stderr] 126 |     pub fn as_str(&self) -> &'static str {
[INFO] [stderr]     |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `sparkle` (bin "sparkle") generated 14 warnings (3 duplicates)
[INFO] [stderr] warning: `sparkle` (bin "sparkle" test) generated 14 warnings (14 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.14s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/sparkle-d3eac2afa3cf7e7d)
[INFO] [stdout] 
[INFO] [stdout] running 14 tests
[INFO] [stdout] test file_detector::tests::test_get_file_type_by_extension ... ok
[INFO] [stdout] test file_detector::tests::test_get_file_type_case_insensitive ... ok
[INFO] [stdout] test file_detector::tests::test_get_file_type_unknown ... ok
[INFO] [stdout] test config::tests::test_config_new_empty_rules ... ok
[INFO] [stdout] test config::tests::test_filter_variants ... ok
[INFO] [stdout] test file_detector::tests::test_get_file_type_documents ... ok
[INFO] [stdout] test file_detector::tests::test_get_file_type_text ... ok
[INFO] [stdout] test config::tests::test_config_new_nonexistent_file ... ok
[INFO] [stdout] test config::tests::test_config_new_invalid_toml ... ok
[INFO] [stdout] test config::tests::test_config_new_valid_toml ... ok
[INFO] [stdout] test file_detector::tests::test_get_file_size_category_with_test_files ... ok
[INFO] [stdout] test config::tests::test_action_variants ... FAILED
[INFO] [stdout] test config::tests::test_name_contains ... FAILED
[INFO] [stdout] test file_detector::tests::test_get_file_type_configuration ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- config::tests::test_action_variants stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'config::tests::test_action_variants' (25) panicked at src/config.rs:179:70:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: Error { message: "unknown variant `set_permissions`, expected one of `echo`, `move`, `copy`, `delete`, `rename`", input: Some("\n[[rules]]\nname = \"action_test\"\nlocations = [\"/tmp\"]\nsubfolders = false\nfilters = [{ extension = \"tmp\" }]\nactions = [\n    { echo = \"Test message\" },\n    { move = \"/archive\" },\n    { copy = \"/backup\" },\n    \"delete\",\n    { rename = { pattern = \"old\", replacement = \"new\" } },\n    { set_permissions = 644 }\n]\n"), keys: ["rules", "actions"], span: Some(281..296) }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5a4a2abb6d52 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5a4a2abb6d52 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5a4a2abb6d52 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5a4a2abb6d52 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h67edf0e4d33c343c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5a4a2abc86ff - core::fmt::rt::Argument::fmt::hef94184842aeafdd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5a4a2abc86ff - core::fmt::write::hcf0c66b48a8fa606
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x5a4a2ab83c01 - std::io::default_write_fmt::h69967ac0ba93195f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5a4a2ab83c01 - std::io::Write::write_fmt::h8db9396209deaa1c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5a4a2ab8fee2 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5a4a2ab94d2f - std::panicking::default_hook::{{closure}}::h91001850288db5f7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x5a4a2ab94bc1 - std::panicking::default_hook::h2346dbb704ef5512
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x5a4a2aaea9be - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h18383b2e29377420
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   12:     0x5a4a2aaea9be - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5a4a2ab953ef - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h6dba6e441651a0d1
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   14:     0x5a4a2ab953ef - std::panicking::panic_with_hook::hd2b063a6090d23a4
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x5a4a2ab9524a - std::panicking::panic_handler::{{closure}}::he666d95f139a333e
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13
[INFO] [stdout]   16:     0x5a4a2ab90019 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x5a4a2ab7779d - __rustc[1d67440d6e82e4f]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x5a4a2abd1c30 - core::panicking::panic_fmt::h420ddb7fd73daf53
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x5a4a2abd0f66 - core::result::unwrap_failed::hdde076be853d034f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5
[INFO] [stdout]   20:     0x5a4a2aa4e53a - core::result::Result<T,E>::unwrap::h5593aeea28522cae
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23
[INFO] [stdout]   21:     0x5a4a2aa4e53a - sparkle::config::tests::test_action_variants::h6d7300f3099b43b7
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:179:70
[INFO] [stdout]   22:     0x5a4a2aa4e827 - sparkle::config::tests::test_action_variants::{{closure}}::h31202c2da56b2eb1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:160:30
[INFO] [stdout]   23:     0x5a4a2aa3b8a6 - core::ops::function::FnOnce::call_once::hb9c0506b381b7bf1
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5a4a2aaea77b - core::ops::function::FnOnce::call_once::h70887edf07a630ba
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x5a4a2aaea77b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x5a4a2ab003e5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x5a4a2ab003e5 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x5a4a2ab003e5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   29:     0x5a4a2ab003e5 - std::panicking::catch_unwind::hae1ec7bf94407afa
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   30:     0x5a4a2ab003e5 - std::panic::catch_unwind::h0f4ff4773d84d3cd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x5a4a2ab003e5 - test::run_test_in_process::h03fbc77ae48b3f10
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x5a4a2ab003e5 - test::run_test::{{closure}}::h83476a9c453dc4d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x5a4a2aad6bd4 - test::run_test::{{closure}}::h515482ad1e7fe7de
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x5a4a2aad6bd4 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   35:     0x5a4a2aada49a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   36:     0x5a4a2aada49a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x5a4a2aada49a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   38:     0x5a4a2aada49a - std::panicking::catch_unwind::h9e402d6a96fef41c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   39:     0x5a4a2aada49a - std::panic::catch_unwind::h9213c0c54aec70e0
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x5a4a2aada49a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   41:     0x5a4a2aada49a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x5a4a2ab8b17f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h2044e71c41d3958a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   43:     0x5a4a2ab8b17f - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17
[INFO] [stdout]   44:     0x79c5bf2f5aa4 - <unknown>
[INFO] [stdout]   45:     0x79c5bf382a34 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- config::tests::test_name_contains stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'config::tests::test_name_contains' (31) panicked at src/config.rs:208:70:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: Error { message: "unknown variant `set_permissions`, expected one of `echo`, `move`, `copy`, `delete`, `rename`", input: Some("\n[[rules]]\nname = \"action_test\"\nlocations = [\"/tmp\"]\nsubfolders = false\nfilters = [{ name_contains = \"tmp\" }]\nactions = [\n    { echo = \"Test message\" },\n    { move = \"/archive\" },\n    { copy = \"/backup\" },\n    \"delete\",\n    { rename = { pattern = \"old\", replacement = \"new\" } },\n    { set_permissions = 644 }\n]\n"), keys: ["rules", "actions"], span: Some(285..300) }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5a4a2abb6d52 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5a4a2abb6d52 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5a4a2abb6d52 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5a4a2abb6d52 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h67edf0e4d33c343c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5a4a2abc86ff - core::fmt::rt::Argument::fmt::hef94184842aeafdd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5a4a2abc86ff - core::fmt::write::hcf0c66b48a8fa606
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x5a4a2ab83c01 - std::io::default_write_fmt::h69967ac0ba93195f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5a4a2ab83c01 - std::io::Write::write_fmt::h8db9396209deaa1c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5a4a2ab8fee2 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5a4a2ab94d2f - std::panicking::default_hook::{{closure}}::h91001850288db5f7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x5a4a2ab94bc1 - std::panicking::default_hook::h2346dbb704ef5512
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x5a4a2aaea9be - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h18383b2e29377420
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   12:     0x5a4a2aaea9be - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5a4a2ab953ef - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h6dba6e441651a0d1
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   14:     0x5a4a2ab953ef - std::panicking::panic_with_hook::hd2b063a6090d23a4
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x5a4a2ab9524a - std::panicking::panic_handler::{{closure}}::he666d95f139a333e
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13
[INFO] [stdout]   16:     0x5a4a2ab90019 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x5a4a2ab7779d - __rustc[1d67440d6e82e4f]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x5a4a2abd1c30 - core::panicking::panic_fmt::h420ddb7fd73daf53
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x5a4a2abd0f66 - core::result::unwrap_failed::hdde076be853d034f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5
[INFO] [stdout]   20:     0x5a4a2aa4de8a - core::result::Result<T,E>::unwrap::h5593aeea28522cae
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23
[INFO] [stdout]   21:     0x5a4a2aa4de8a - sparkle::config::tests::test_name_contains::h13ffa46d7e3942fc
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:208:70
[INFO] [stdout]   22:     0x5a4a2aa4e177 - sparkle::config::tests::test_name_contains::{{closure}}::h08c4a7f23ca62373
[INFO] [stdout]                                at /opt/rustwide/workdir/src/config.rs:189:28
[INFO] [stdout]   23:     0x5a4a2aa3b496 - core::ops::function::FnOnce::call_once::h363579c613ca18ed
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5a4a2aaea77b - core::ops::function::FnOnce::call_once::h70887edf07a630ba
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x5a4a2aaea77b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x5a4a2ab003e5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x5a4a2ab003e5 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x5a4a2ab003e5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   29:     0x5a4a2ab003e5 - std::panicking::catch_unwind::hae1ec7bf94407afa
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   30:     0x5a4a2ab003e5 - std::panic::catch_unwind::h0f4ff4773d84d3cd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x5a4a2ab003e5 - test::run_test_in_process::h03fbc77ae48b3f10
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x5a4a2ab003e5 - test::run_test::{{closure}}::h83476a9c453dc4d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x5a4a2aad6bd4 - test::run_test::{{closure}}::h515482ad1e7fe7de
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x5a4a2aad6bd4 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   35:     0x5a4a2aada49a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   36:     0x5a4a2aada49a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x5a4a2aada49a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   38:     0x5a4a2aada49a - std::panicking::catch_unwind::h9e402d6a96fef41c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   39:     0x5a4a2aada49a - std::panic::catch_unwind::h9213c0c54aec70e0
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x5a4a2aada49a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   41:     0x5a4a2aada49a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x5a4a2ab8b17f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h2044e71c41d3958a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   43:     0x5a4a2ab8b17f - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17
[INFO] [stdout]   44:     0x79c5bf2f5aa4 - <unknown>
[INFO] [stdout]   45:     0x79c5bf382a34 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     config::tests::test_action_variants
[INFO] [stdout]     config::tests::test_name_contains
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 12 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.24s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "61db27e3b16ae82f49c147d8e9de7ecfe48741a4e40af60f32379813a2a57619", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "61db27e3b16ae82f49c147d8e9de7ecfe48741a4e40af60f32379813a2a57619", kill_on_drop: false }`
[INFO] [stdout] 61db27e3b16ae82f49c147d8e9de7ecfe48741a4e40af60f32379813a2a57619
