[INFO] cloning repository https://github.com/zuojiarui1027/LGS-Paintboard-Helpe
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/zuojiarui1027/LGS-Paintboard-Helpe" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fzuojiarui1027%2FLGS-Paintboard-Helpe", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fzuojiarui1027%2FLGS-Paintboard-Helpe'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] a88feb74d5cc08a50abb659e660c1696c1310f6b
[INFO] testing zuojiarui1027/LGS-Paintboard-Helpe against beta-2026-03-05 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fzuojiarui1027%2FLGS-Paintboard-Helpe" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/zuojiarui1027/LGS-Paintboard-Helpe
[INFO] finished tweaking git repo https://github.com/zuojiarui1027/LGS-Paintboard-Helpe
[INFO] tweaked toml for git repo https://github.com/zuojiarui1027/LGS-Paintboard-Helpe written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/zuojiarui1027/LGS-Paintboard-Helpe on toolchain beta-2026-03-05
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/zuojiarui1027/LGS-Paintboard-Helpe 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-2026-03-05" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: /workspace/builds/worker-6-tc2/source/Cargo.toml: only one of `license` or `license-file` is necessary
[INFO] [stderr] `license` should be used if the package license can be expressed with a standard SPDX expression.
[INFO] [stderr] `license-file` should be used if the package uses a non-standard license.
[INFO] [stderr] See https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields for more information.
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] ee750130f3c7737287338f4a63e76207dbe344e33dbd89ccd14e781b3ac428f8
[INFO] running `Command { std: "docker" "start" "-a" "ee750130f3c7737287338f4a63e76207dbe344e33dbd89ccd14e781b3ac428f8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "ee750130f3c7737287338f4a63e76207dbe344e33dbd89ccd14e781b3ac428f8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ee750130f3c7737287338f4a63e76207dbe344e33dbd89ccd14e781b3ac428f8", kill_on_drop: false }`
[INFO] [stdout] ee750130f3c7737287338f4a63e76207dbe344e33dbd89ccd14e781b3ac428f8
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1ba943caa544257c8bca757e67d9131c64c9b4bba7af6cac7ee875faa6874ff5
[INFO] running `Command { std: "docker" "start" "-a" "1ba943caa544257c8bca757e67d9131c64c9b4bba7af6cac7ee875faa6874ff5", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: only one of `license` or `license-file` is necessary
[INFO] [stderr] `license` should be used if the package license can be expressed with a standard SPDX expression.
[INFO] [stderr] `license-file` should be used if the package uses a non-standard license.
[INFO] [stderr] See https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields for more information.
[INFO] [stderr]    Compiling proc-macro2 v1.0.101
[INFO] [stderr]    Compiling unicode-ident v1.0.19
[INFO] [stderr]    Compiling quote v1.0.41
[INFO] [stderr]    Compiling cfg-if v1.0.3
[INFO] [stderr]    Compiling libc v0.2.177
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling pin-project-lite v0.2.16
[INFO] [stderr]    Compiling memchr v2.7.6
[INFO] [stderr]    Compiling bytes v1.10.1
[INFO] [stderr]    Compiling futures-core v0.3.31
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling itoa v1.0.15
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]    Compiling slab v0.4.11
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling futures-task v0.3.31
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling log v0.4.28
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling simd-adler32 v0.3.7
[INFO] [stderr]    Compiling find-msvc-tools v0.1.4
[INFO] [stderr]    Compiling hashbrown v0.16.0
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling cc v1.2.41
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling litemap v0.8.0
[INFO] [stderr]    Compiling bitflags v2.9.4
[INFO] [stderr]    Compiling writeable v0.6.1
[INFO] [stderr]    Compiling icu_properties_data v2.0.1
[INFO] [stderr]    Compiling regex-syntax v0.8.7
[INFO] [stderr]    Compiling icu_normalizer_data v2.0.0
[INFO] [stderr]    Compiling generic-array v0.14.8
[INFO] [stderr]    Compiling http v1.3.1
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling anyhow v1.0.100
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling indexmap v2.11.4
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling getrandom v0.1.16
[INFO] [stderr]    Compiling bytemuck v1.24.0
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling openssl-probe v0.1.6
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling flate2 v1.1.4
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling owo-colors v4.2.3
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]    Compiling paste v1.0.15
[INFO] [stderr]    Compiling object v0.37.3
[INFO] [stderr]    Compiling ryu v1.0.20
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling num-complex v0.4.6
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]    Compiling num-bigint v0.4.6
[INFO] [stderr]    Compiling safe_arch v0.7.4
[INFO] [stderr]    Compiling matrixmultiply v0.3.10
[INFO] [stderr]    Compiling color-spantrace v0.3.0
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]    Compiling weezl v0.1.10
[INFO] [stderr]    Compiling gimli v0.32.3
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling jpeg-decoder v0.3.2
[INFO] [stderr]    Compiling http-body v0.4.6
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling socket2 v0.6.0
[INFO] [stderr]    Compiling signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling regex-automata v0.4.12
[INFO] [stderr]    Compiling rand_core v0.5.1
[INFO] [stderr]    Compiling wide v0.7.33
[INFO] [stderr]    Compiling approx v0.5.1
[INFO] [stderr]    Compiling raw-cpuid v11.6.0
[INFO] [stderr]    Compiling zune-inflate v0.2.54
[INFO] [stderr]    Compiling fdeflate v0.3.7
[INFO] [stderr]    Compiling num-rational v0.4.2
[INFO] [stderr]    Compiling data-encoding v2.9.0
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling ttf-parser v0.15.2
[INFO] [stderr]    Compiling rustc-demangle v0.1.26
[INFO] [stderr]    Compiling rawpointer v0.2.1
[INFO] [stderr]    Compiling anstyle-query v1.1.4
[INFO] [stderr]    Compiling bit_field v0.10.3
[INFO] [stderr]    Compiling color_quant v1.1.0
[INFO] [stderr]    Compiling indenter v0.3.4
[INFO] [stderr]    Compiling lebe v0.5.3
[INFO] [stderr]    Compiling anstream v0.6.21
[INFO] [stderr]    Compiling eyre v0.6.12
[INFO] [stderr]    Compiling gif v0.13.3
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling png v0.17.16
[INFO] [stderr]    Compiling quanta v0.12.6
[INFO] [stderr]    Compiling simba v0.7.3
[INFO] [stderr]    Compiling tiff v0.9.1
[INFO] [stderr]    Compiling dashmap v5.5.3
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling num_cpus v1.17.0
[INFO] [stderr]    Compiling num-iter v0.1.45
[INFO] [stderr]    Compiling rustls-pemfile v1.0.4
[INFO] [stderr]    Compiling qoi v0.4.1
[INFO] [stderr]    Compiling addr2line v0.25.1
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling spinning_top v0.3.0
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling ab_glyph_rasterizer v0.1.10
[INFO] [stderr]    Compiling no-std-compat v0.4.1
[INFO] [stderr]    Compiling nonzero_ext v0.3.0
[INFO] [stderr]    Compiling futures-timer v3.0.3
[INFO] [stderr]    Compiling humantime v2.3.0
[INFO] [stderr]    Compiling custom_derive v0.1.7
[INFO] [stderr]    Compiling clap_lex v0.7.5
[INFO] [stderr]    Compiling conv v0.3.3
[INFO] [stderr]    Compiling num v0.4.3
[INFO] [stderr]    Compiling uuid v1.18.1
[INFO] [stderr]    Compiling is-terminal v0.4.16
[INFO] [stderr]    Compiling clap_builder v4.5.48
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling termcolor v1.4.1
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling hdrhistogram v7.5.4
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling regex v1.12.1
[INFO] [stderr]    Compiling owned_ttf_parser v0.15.2
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling rusttype v0.9.3
[INFO] [stderr]    Compiling env_logger v0.10.2
[INFO] [stderr]    Compiling zerocopy-derive v0.8.27
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling prost-derive v0.13.5
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling backtrace v0.3.76
[INFO] [stderr]    Compiling clap_derive v4.5.47
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.0
[INFO] [stderr]    Compiling nalgebra v0.30.1
[INFO] [stderr]    Compiling pin-project v1.1.10
[INFO] [stderr]    Compiling zerovec v0.11.4
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling zerotrie v0.2.2
[INFO] [stderr]    Compiling tracing-subscriber v0.3.20
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling prost v0.13.5
[INFO] [stderr]    Compiling axum-core v0.4.5
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling tinystr v0.8.1
[INFO] [stderr]    Compiling potential_utf v0.1.3
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling clap v4.5.48
[INFO] [stderr]    Compiling icu_collections v2.0.0
[INFO] [stderr]    Compiling icu_locale_core v2.0.0
[INFO] [stderr]    Compiling prost-types v0.13.5
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling half v2.7.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand_chacha v0.2.2
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling tracing-error v0.2.1
[INFO] [stderr]    Compiling rand v0.7.3
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling exr v1.73.0
[INFO] [stderr]    Compiling icu_provider v2.0.0
[INFO] [stderr]    Compiling color-eyre v0.6.5
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling icu_normalizer v2.0.0
[INFO] [stderr]    Compiling icu_properties v2.0.1
[INFO] [stderr]    Compiling governor v0.6.3
[INFO] [stderr]    Compiling rand_distr v0.2.2
[INFO] [stderr]    Compiling axum v0.7.9
[INFO] [stderr]    Compiling tokio-util v0.7.16
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling deadpool-runtime v0.1.4
[INFO] [stderr]    Compiling deadpool v0.12.3
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling url v2.5.7
[INFO] [stderr]    Compiling h2 v0.4.12
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling tungstenite v0.20.1
[INFO] [stderr]    Compiling image v0.24.9
[INFO] [stderr]    Compiling tokio-tungstenite v0.20.1
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling hyper v1.7.0
[INFO] [stderr]    Compiling hyper-tls v0.5.0
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling hyper-util v0.1.17
[INFO] [stderr]    Compiling imageproc v0.23.0
[INFO] [stderr]    Compiling winter-paintboard-sdk v0.1.0 (/opt/rustwide/workdir/crates/winter-paintboard-sdk)
[INFO] [stderr]    Compiling hyper-timeout v0.5.2
[INFO] [stderr]    Compiling tonic v0.12.3
[INFO] [stdout] warning: unused imports: `Board`, `Pos`, `Rgb`, `config::Config`, and `error::PaintboardError`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     config::Config,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 26 |     error::PaintboardError,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 27 |     models::{Board, Pos, Rgb},
[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 imports: `AtomicBool` and `Ordering`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:29:25
[INFO] [stdout]    |
[INFO] [stdout] 29 | use std::sync::atomic::{AtomicBool, Ordering};
[INFO] [stdout]    |                         ^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_trait::async_trait`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | use async_trait::async_trait;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unexpected `cfg` condition value: `reqwest`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/error/mod.rs:216:7
[INFO] [stdout]     |
[INFO] [stdout] 216 | #[cfg(feature = "reqwest")]
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stdout]     |
[INFO] [stdout]     = note: no expected values for `feature`
[INFO] [stdout]     = help: consider adding `reqwest` as a feature in `Cargo.toml`
[INFO] [stdout]     = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]     = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `operations`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:104:9
[INFO] [stdout]     |
[INFO] [stdout] 104 |         operations: Vec<(Pos, Rgb)>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_operations`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uid`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:105:9
[INFO] [stdout]     |
[INFO] [stdout] 105 |         uid: u32,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_uid`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:106:9
[INFO] [stdout]     |
[INFO] [stdout] 106 |         token: &str,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `operations`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:123:9
[INFO] [stdout]     |
[INFO] [stdout] 123 |         operations: Vec<PaintOperation>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_operations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `other`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:149:13
[INFO] [stdout]     |
[INFO] [stdout] 149 |             other => {
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_other`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config_clone`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:167:13
[INFO] [stdout]     |
[INFO] [stdout] 167 |         let config_clone = config.clone();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_config_clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `rate_limiter` is never read
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 64 | struct WsActor {
[INFO] [stdout]    |        ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 68 |     rate_limiter: Arc<WsRateLimiter>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `actor_task_handle` is never read
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:822:5
[INFO] [stdout]     |
[INFO] [stdout] 811 | pub struct AsyncWsProvider {
[INFO] [stdout]     |            --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 822 |     actor_task_handle: Arc<TokioMutex<Option<JoinHandle<()>>>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AsyncWsProvider` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WsConnection` is never constructed
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct WsConnection {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `stream`, `connect`, `is_connected`, `send_binary`, and `close` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:22:12
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl WsConnection {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout]  21 |     /// 创建一个新的 WsConnection（初始处于未连接状态）
[INFO] [stdout]  22 |     pub fn new(config: Arc<Config>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  30 |     pub fn stream(&self) -> Arc<TokioMutex<Option<WebSocketStream<MaybeTlsStream<TcpStream>>>>> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     pub async fn connect(&self) -> Result<(), PaintboardError> {
[INFO] [stdout]     |                  ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  72 |     pub async fn is_connected(&self) -> bool {
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  84 |     pub async fn send_binary(&self, data: Vec<u8>) -> Result<(), Report> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 113 |     pub async fn close(&self) -> Result<(), PaintboardError> {
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WsMessageHandler` is never constructed
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct WsMessageHandler {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `handle_message_stream`, `handle_single_message`, and `start_message_processing_task` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:27:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl WsMessageHandler {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout]  27 |     pub fn new(response_tracker: Arc<WsResponseTracker>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  32 |     pub async fn handle_message_stream(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  84 |     async fn handle_single_message(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub async fn start_message_processing_task(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `current_delay` is never used
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:58:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl WsReconnectStrategy {
[INFO] [stdout]    | ------------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn current_delay(&self) -> Duration {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `current_delay`, and `reconnect` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:69:12
[INFO] [stdout]     |
[INFO] [stdout]  68 | impl WsReconnectManager {
[INFO] [stdout]     | ----------------------- associated items in this implementation
[INFO] [stdout]  69 |     pub fn new(initial_delay: Duration, max_delay: Duration) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn current_delay(&self) -> Duration {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub async fn reconnect(&mut self, connection: Arc<WsConnection>) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `pending_count` is never used
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_response_tracker.rs:63:18
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl WsResponseTracker {
[INFO] [stdout]    | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub async fn pending_count(&self) -> usize {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling console-api v0.8.1
[INFO] [stderr]    Compiling console-subscriber v0.4.1
[INFO] [stderr]    Compiling lgs-paintboard v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `time::Duration`
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:6:22
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::{sync::Arc, time::Duration};
[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: `self`
[INFO] [stdout]  --> src/app/image_processing.rs:8:24
[INFO] [stdout]   |
[INFO] [stdout] 8 | use imageproc::edges::{self, canny};
[INFO] [stdout]   |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rustc_hash::FxHashMap`
[INFO] [stdout]  --> src/app/multi_token/multi_token_service.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use rustc_hash::FxHashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AtomicU64`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:10:37
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::sync::atomic::{AtomicBool, AtomicU64, Ordering};
[INFO] [stdout]    |                                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Instant`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:13:36
[INFO] [stdout]    |
[INFO] [stdout] 13 | use tokio::time::{interval, sleep, Instant};
[INFO] [stdout]    |                                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `parking_lot::RwLock`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use parking_lot::RwLock;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::app::multi_token::cli::get_penalty_scale`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::app::multi_token::cli::get_penalty_scale;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::panic::AssertUnwindSafe`
[INFO] [stdout]  --> src/app/multi_token/paint_batcher.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::panic::AssertUnwindSafe;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `parking_lot::Mutex`
[INFO] [stdout]  --> src/app/multi_token/token_lease.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use parking_lot::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]  --> src/app/multi_token/token_lease.rs:9:17
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::time::{Duration, Instant};
[INFO] [stdout]   |                 ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PaintboardClientTrait`
[INFO] [stdout]   --> src/app/multi_token/token_worker.rs:15:53
[INFO] [stdout]    |
[INFO] [stdout] 15 | use winter_paintboard_sdk::{models::PaintOperation, PaintboardClientTrait};
[INFO] [stdout]    |                                                     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::Rgb`
[INFO] [stdout]  --> src/app/utils.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use winter_paintboard_sdk::Rgb;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `app::board_sync::local_board::LocalBoard::verify_integrity`: 不必要的完整性检查，造成性能损耗，改为返回 `true`
[INFO] [stdout]    --> src/app/board_sync/sync_manager.rs:204:35
[INFO] [stdout]     |
[INFO] [stdout] 204 |                         if !board.verify_integrity() {
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stdout]   --> src/app/board_sync/sync_manager.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PaintboardClientTrait`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:26:72
[INFO] [stdout]    |
[INFO] [stdout] 26 | use winter_paintboard_sdk::{basic_client::AsyncClient, config::Config, PaintboardClientTrait};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uid`
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:365:50
[INFO] [stdout]     |
[INFO] [stdout] 365 |                     event::PaintEvent::Success { uid, pos, color } => {
[INFO] [stdout]     |                                                  ^^^ help: try ignoring the field: `uid: _`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uid`
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:388:50
[INFO] [stdout]     |
[INFO] [stdout] 388 |                     event::PaintEvent::Failure { uid, pos } => {
[INFO] [stdout]     |                                                  ^^^ help: try ignoring the field: `uid: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canny_low_thresh`
[INFO] [stdout]    --> src/app/multi_token/multi_token_service.rs:133:9
[INFO] [stdout]     |
[INFO] [stdout] 133 |         canny_low_thresh: f32,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_low_thresh`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canny_high_thresh`
[INFO] [stdout]    --> src/app/multi_token/multi_token_service.rs:134:9
[INFO] [stdout]     |
[INFO] [stdout] 134 |         canny_high_thresh: f32,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_high_thresh`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `relative_pos`
[INFO] [stdout]    --> src/app/multi_token/multi_token_service.rs:345:21
[INFO] [stdout]     |
[INFO] [stdout] 345 |                 let relative_pos = relative_pos.unwrap();
[INFO] [stdout]     |                     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_relative_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/app/multi_token/token_manager.rs:213:29
[INFO] [stdout]     |
[INFO] [stdout] 213 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `access_keys`
[INFO] [stdout]   --> src/app/mod.rs:61:13
[INFO] [stdout]    |
[INFO] [stdout] 61 |             access_keys,
[INFO] [stdout]    |             ^^^^^^^^^^^ help: try ignoring the field: `access_keys: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uids`
[INFO] [stdout]   --> src/app/mod.rs:62:13
[INFO] [stdout]    |
[INFO] [stdout] 62 |             uids,
[INFO] [stdout]    |             ^^^^ help: try ignoring the field: `uids: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> src/app/mod.rs:277:9
[INFO] [stdout]     |
[INFO] [stdout] 277 |     let token = match validate_auth_args(&token, &access_key) {
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/app/mod.rs:159:73
[INFO] [stdout]     |
[INFO] [stdout] 159 |     let _ = multi_token::cli::PENALTY_SCALE.set(penalty_scale).map_err(|e| {
[INFO] [stdout]     |                                                                         ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cd_time`
[INFO] [stdout]    --> src/app/mod.rs:141:5
[INFO] [stdout]     |
[INFO] [stdout] 141 |     cd_time: u64,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cd_time`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> src/app/mod.rs:185:13
[INFO] [stdout]     |
[INFO] [stdout] 185 |         let token = match (&first_token.token, &first_token.access_key) {
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HEATMAP_EXPIRE_DURATION_MILLS` is never used
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:18:7
[INFO] [stdout]    |
[INFO] [stdout] 18 | const HEATMAP_EXPIRE_DURATION_MILLS: u64 = 10 * 60 * 1000; // 10min
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `source` and `timestamp` are never read
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:38:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct PixelStatus {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub source: PixelSource,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 39 |     /// 像素更新时间戳
[INFO] [stdout] 40 |     pub timestamp: std::time::SystemTime,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PixelStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:76:11
[INFO] [stdout]    |
[INFO] [stdout] 76 |     Error(String),
[INFO] [stdout]    |     ----- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SyncStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 76 -     Error(String),
[INFO] [stdout] 76 +     Error(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Syncing` is never constructed
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:74:5
[INFO] [stdout]    |
[INFO] [stdout] 70 | pub enum SyncStatus {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 74 |     Syncing,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SyncStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `sync_status`, `last_sync_time`, and `version` are never used
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:293:12
[INFO] [stdout]     |
[INFO] [stdout]  79 | impl LocalBoard {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 293 |     pub fn sync_status(&self) -> SyncStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 311 |     pub fn last_sync_time(&self) -> Option<std::time::SystemTime> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 329 |     pub fn version(&self) -> u64 {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `start_sync_loop` and `stop` are never used
[INFO] [stdout]    --> src/app/board_sync/sync_manager.rs:64:18
[INFO] [stdout]     |
[INFO] [stdout]  28 | impl BoardSyncManager {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  64 |     pub async fn start_sync_loop(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 241 |     pub async fn stop(&self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_client_type` is never used
[INFO] [stdout]    --> src/app/cli.rs:139:4
[INFO] [stdout]     |
[INFO] [stdout] 139 | fn parse_client_type(s: &str) -> Result<winter_paintboard_sdk::ClientType, String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `scale_level_operations` and `pixel_canny_priorities` are never read
[INFO] [stdout]   --> src/app/image_processing.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct ProcessedImageData {
[INFO] [stdout]    |            ------------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 26 |     pub scale_level_operations: Vec<Vec<(winter_paintboard_sdk::Pos, winter_paintboard_sdk::Rgb)>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 27 |     /// 网格图算法计算出的像素优先级映射，优先级值越高表示越重要
[INFO] [stdout] 28 |     pub pixel_canny_priorities: FxHashMap<winter_paintboard_sdk::Pos, f64>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProcessedImageData` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_cli_args` is never used
[INFO] [stdout]   --> src/app/multi_token/config.rs:78:12
[INFO] [stdout]    |
[INFO] [stdout] 45 | impl TokenConfig {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 78 |     pub fn from_cli_args(
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `metrics_handle` is never read
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct MultiTokenService {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 40 |     metrics_handle: Option<tokio::task::JoinHandle<()>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:82:18
[INFO] [stdout]    |
[INFO] [stdout] 63 | impl MultiTokenService {
[INFO] [stdout]    | ---------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 82 |     pub async fn new(
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `reset_and_push`, `len`, `is_empty`, and `get_all_pixels` are never used
[INFO] [stdout]   --> src/app/multi_token/pixel_queue.rs:40:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl PixelQueue {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub fn reset_and_push(&self, pixels: Vec<PriorityPixel>) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn len(&self) -> usize {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 75 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 85 |     pub fn get_all_pixels(&self) -> Vec<PriorityPixel> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `last_paint_time` and `is_available` are never read
[INFO] [stdout]   --> src/app/multi_token/token_manager.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct TokenInfo {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub last_paint_time: Option<Instant>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 23 |     /// 是否可用
[INFO] [stdout] 24 |     pub is_available: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TokenInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/app/multi_token/token_manager.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | impl TokenInfo {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn new(uid: u32, token: String) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `cd_duration`, `next_available_time`, and `get_token` are never used
[INFO] [stdout]    --> src/app/multi_token/token_manager.rs:191:12
[INFO] [stdout]     |
[INFO] [stdout]  61 | impl TokenManager {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn cd_duration(&self) -> Duration {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 200 |     pub fn next_available_time(&self) -> Option<Duration> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 213 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_auth_token` is never used
[INFO] [stdout]   --> src/app/utils.rs:87:14
[INFO] [stdout]    |
[INFO] [stdout] 87 | pub async fn resolve_auth_token(
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `uid` is never read
[INFO] [stdout]   --> src/app/metrics/mod.rs:42:9
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub struct TokenMetricsData {
[INFO] [stdout]    |            ---------------- field in this struct
[INFO] [stdout] 41 |     /// 关联的 UID
[INFO] [stdout] 42 |     pub uid: u32,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_token_metrics`, `record_global_paint_success`, and `record_global_paint_failure` are never used
[INFO] [stdout]    --> src/app/metrics/mod.rs:99:12
[INFO] [stdout]     |
[INFO] [stdout]  55 | impl Metrics {
[INFO] [stdout]     | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn get_token_metrics(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 116 |     pub fn record_global_paint_success(&self, uid: u32, pos: Pos) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn record_global_paint_failure(&self, uid: u32, pos: Pos) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `record_paint_success`, `record_paint_failure`, and `clear_old_entries` are never used
[INFO] [stdout]    --> src/app/metrics/mod.rs:151:12
[INFO] [stdout]     |
[INFO] [stdout] 141 | impl TokenMetricsData {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 151 |     pub fn new(uid: u32) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub(self) fn record_paint_success(&self, pos: Pos) {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 184 |     pub(self) fn record_paint_failure(&self, pos: Pos) {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 196 |     fn clear_old_entries(&self, history: &mut VecDeque<(std::time::Instant, Pos)>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 59s
[INFO] running `Command { std: "docker" "inspect" "1ba943caa544257c8bca757e67d9131c64c9b4bba7af6cac7ee875faa6874ff5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1ba943caa544257c8bca757e67d9131c64c9b4bba7af6cac7ee875faa6874ff5", kill_on_drop: false }`
[INFO] [stdout] 1ba943caa544257c8bca757e67d9131c64c9b4bba7af6cac7ee875faa6874ff5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 28bfc65fee1c1b02278b6e12266996582dabee6c9398e9ae22e08c9313081bda
[INFO] running `Command { std: "docker" "start" "-a" "28bfc65fee1c1b02278b6e12266996582dabee6c9398e9ae22e08c9313081bda", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: only one of `license` or `license-file` is necessary
[INFO] [stderr] `license` should be used if the package license can be expressed with a standard SPDX expression.
[INFO] [stderr] `license-file` should be used if the package uses a non-standard license.
[INFO] [stderr] See https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields for more information.
[INFO] [stdout] warning: unused imports: `Board`, `Pos`, `Rgb`, `config::Config`, and `error::PaintboardError`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     config::Config,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 26 |     error::PaintboardError,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 27 |     models::{Board, Pos, Rgb},
[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 imports: `AtomicBool` and `Ordering`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:29:25
[INFO] [stdout]    |
[INFO] [stdout] 29 | use std::sync::atomic::{AtomicBool, Ordering};
[INFO] [stdout]    |                         ^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_trait::async_trait`
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | use async_trait::async_trait;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unexpected `cfg` condition value: `reqwest`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/error/mod.rs:216:7
[INFO] [stdout]     |
[INFO] [stdout] 216 | #[cfg(feature = "reqwest")]
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stdout]     |
[INFO] [stdout]     = note: no expected values for `feature`
[INFO] [stdout]     = help: consider adding `reqwest` as a feature in `Cargo.toml`
[INFO] [stdout]     = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]     = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `operations`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:104:9
[INFO] [stdout]     |
[INFO] [stdout] 104 |         operations: Vec<(Pos, Rgb)>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_operations`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uid`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:105:9
[INFO] [stdout]     |
[INFO] [stdout] 105 |         uid: u32,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_uid`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:106:9
[INFO] [stdout]     |
[INFO] [stdout] 106 |         token: &str,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `operations`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:123:9
[INFO] [stdout]     |
[INFO] [stdout] 123 |         operations: Vec<PaintOperation>,
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_operations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `other`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:149:13
[INFO] [stdout]     |
[INFO] [stdout] 149 |             other => {
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_other`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config_clone`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:167:13
[INFO] [stdout]     |
[INFO] [stdout] 167 |         let config_clone = config.clone();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_config_clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `rate_limiter` is never read
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 64 | struct WsActor {
[INFO] [stdout]    |        ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 68 |     rate_limiter: Arc<WsRateLimiter>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `actor_task_handle` is never read
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:822:5
[INFO] [stdout]     |
[INFO] [stdout] 811 | pub struct AsyncWsProvider {
[INFO] [stdout]     |            --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 822 |     actor_task_handle: Arc<TokioMutex<Option<JoinHandle<()>>>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AsyncWsProvider` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WsConnection` is never constructed
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct WsConnection {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `stream`, `connect`, `is_connected`, `send_binary`, and `close` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:22:12
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl WsConnection {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout]  21 |     /// 创建一个新的 WsConnection（初始处于未连接状态）
[INFO] [stdout]  22 |     pub fn new(config: Arc<Config>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  30 |     pub fn stream(&self) -> Arc<TokioMutex<Option<WebSocketStream<MaybeTlsStream<TcpStream>>>>> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     pub async fn connect(&self) -> Result<(), PaintboardError> {
[INFO] [stdout]     |                  ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  72 |     pub async fn is_connected(&self) -> bool {
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  84 |     pub async fn send_binary(&self, data: Vec<u8>) -> Result<(), Report> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 113 |     pub async fn close(&self) -> Result<(), PaintboardError> {
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WsMessageHandler` is never constructed
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct WsMessageHandler {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `handle_message_stream`, `handle_single_message`, and `start_message_processing_task` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:27:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl WsMessageHandler {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout]  27 |     pub fn new(response_tracker: Arc<WsResponseTracker>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  32 |     pub async fn handle_message_stream(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  84 |     async fn handle_single_message(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub async fn start_message_processing_task(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `current_delay` is never used
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:58:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl WsReconnectStrategy {
[INFO] [stdout]    | ------------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn current_delay(&self) -> Duration {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `current_delay`, and `reconnect` are never used
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:69:12
[INFO] [stdout]     |
[INFO] [stdout]  68 | impl WsReconnectManager {
[INFO] [stdout]     | ----------------------- associated items in this implementation
[INFO] [stdout]  69 |     pub fn new(initial_delay: Duration, max_delay: Duration) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn current_delay(&self) -> Duration {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub async fn reconnect(&mut self, connection: Arc<WsConnection>) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `pending_count` is never used
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_response_tracker.rs:63:18
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl WsResponseTracker {
[INFO] [stdout]    | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub async fn pending_count(&self) -> usize {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling lgs-paintboard v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `time::Duration`
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:6:22
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::{sync::Arc, time::Duration};
[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: `self`
[INFO] [stdout]  --> src/app/image_processing.rs:8:24
[INFO] [stdout]   |
[INFO] [stdout] 8 | use imageproc::edges::{self, canny};
[INFO] [stdout]   |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rustc_hash::FxHashMap`
[INFO] [stdout]  --> src/app/multi_token/multi_token_service.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use rustc_hash::FxHashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AtomicU64`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:10:37
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::sync::atomic::{AtomicBool, AtomicU64, Ordering};
[INFO] [stdout]    |                                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Instant`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:13:36
[INFO] [stdout]    |
[INFO] [stdout] 13 | use tokio::time::{interval, sleep, Instant};
[INFO] [stdout]    |                                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `parking_lot::RwLock`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use parking_lot::RwLock;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::app::multi_token::cli::get_penalty_scale`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::app::multi_token::cli::get_penalty_scale;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::panic::AssertUnwindSafe`
[INFO] [stdout]  --> src/app/multi_token/paint_batcher.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::panic::AssertUnwindSafe;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `parking_lot::Mutex`
[INFO] [stdout]  --> src/app/multi_token/token_lease.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use parking_lot::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]  --> src/app/multi_token/token_lease.rs:9:17
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::time::{Duration, Instant};
[INFO] [stdout]   |                 ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PaintboardClientTrait`
[INFO] [stdout]   --> src/app/multi_token/token_worker.rs:15:53
[INFO] [stdout]    |
[INFO] [stdout] 15 | use winter_paintboard_sdk::{models::PaintOperation, PaintboardClientTrait};
[INFO] [stdout]    |                                                     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::Rgb`
[INFO] [stdout]  --> src/app/utils.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use winter_paintboard_sdk::Rgb;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `app::board_sync::local_board::LocalBoard::verify_integrity`: 不必要的完整性检查，造成性能损耗，改为返回 `true`
[INFO] [stdout]    --> src/app/board_sync/sync_manager.rs:204:35
[INFO] [stdout]     |
[INFO] [stdout] 204 |                         if !board.verify_integrity() {
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stdout]   --> src/app/board_sync/sync_manager.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PaintboardClientTrait`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:26:72
[INFO] [stdout]    |
[INFO] [stdout] 26 | use winter_paintboard_sdk::{basic_client::AsyncClient, config::Config, PaintboardClientTrait};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uid`
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:365:50
[INFO] [stdout]     |
[INFO] [stdout] 365 |                     event::PaintEvent::Success { uid, pos, color } => {
[INFO] [stdout]     |                                                  ^^^ help: try ignoring the field: `uid: _`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uid`
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:388:50
[INFO] [stdout]     |
[INFO] [stdout] 388 |                     event::PaintEvent::Failure { uid, pos } => {
[INFO] [stdout]     |                                                  ^^^ help: try ignoring the field: `uid: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canny_low_thresh`
[INFO] [stdout]    --> src/app/multi_token/multi_token_service.rs:133:9
[INFO] [stdout]     |
[INFO] [stdout] 133 |         canny_low_thresh: f32,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_low_thresh`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canny_high_thresh`
[INFO] [stdout]    --> src/app/multi_token/multi_token_service.rs:134:9
[INFO] [stdout]     |
[INFO] [stdout] 134 |         canny_high_thresh: f32,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_high_thresh`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `relative_pos`
[INFO] [stdout]    --> src/app/multi_token/multi_token_service.rs:345:21
[INFO] [stdout]     |
[INFO] [stdout] 345 |                 let relative_pos = relative_pos.unwrap();
[INFO] [stdout]     |                     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_relative_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/app/multi_token/token_manager.rs:213:29
[INFO] [stdout]     |
[INFO] [stdout] 213 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `access_keys`
[INFO] [stdout]   --> src/app/mod.rs:61:13
[INFO] [stdout]    |
[INFO] [stdout] 61 |             access_keys,
[INFO] [stdout]    |             ^^^^^^^^^^^ help: try ignoring the field: `access_keys: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `uids`
[INFO] [stdout]   --> src/app/mod.rs:62:13
[INFO] [stdout]    |
[INFO] [stdout] 62 |             uids,
[INFO] [stdout]    |             ^^^^ help: try ignoring the field: `uids: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> src/app/mod.rs:277:9
[INFO] [stdout]     |
[INFO] [stdout] 277 |     let token = match validate_auth_args(&token, &access_key) {
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/app/mod.rs:159:73
[INFO] [stdout]     |
[INFO] [stdout] 159 |     let _ = multi_token::cli::PENALTY_SCALE.set(penalty_scale).map_err(|e| {
[INFO] [stdout]     |                                                                         ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cd_time`
[INFO] [stdout]    --> src/app/mod.rs:141:5
[INFO] [stdout]     |
[INFO] [stdout] 141 |     cd_time: u64,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cd_time`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token`
[INFO] [stdout]    --> src/app/mod.rs:185:13
[INFO] [stdout]     |
[INFO] [stdout] 185 |         let token = match (&first_token.token, &first_token.access_key) {
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HEATMAP_EXPIRE_DURATION_MILLS` is never used
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:18:7
[INFO] [stdout]    |
[INFO] [stdout] 18 | const HEATMAP_EXPIRE_DURATION_MILLS: u64 = 10 * 60 * 1000; // 10min
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `source` and `timestamp` are never read
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:38:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct PixelStatus {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub source: PixelSource,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 39 |     /// 像素更新时间戳
[INFO] [stdout] 40 |     pub timestamp: std::time::SystemTime,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PixelStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:76:11
[INFO] [stdout]    |
[INFO] [stdout] 76 |     Error(String),
[INFO] [stdout]    |     ----- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SyncStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 76 -     Error(String),
[INFO] [stdout] 76 +     Error(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Syncing` is never constructed
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:74:5
[INFO] [stdout]    |
[INFO] [stdout] 70 | pub enum SyncStatus {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 74 |     Syncing,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SyncStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `sync_status`, `last_sync_time`, and `version` are never used
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:293:12
[INFO] [stdout]     |
[INFO] [stdout]  79 | impl LocalBoard {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 293 |     pub fn sync_status(&self) -> SyncStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 311 |     pub fn last_sync_time(&self) -> Option<std::time::SystemTime> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 329 |     pub fn version(&self) -> u64 {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `start_sync_loop` and `stop` are never used
[INFO] [stdout]    --> src/app/board_sync/sync_manager.rs:64:18
[INFO] [stdout]     |
[INFO] [stdout]  28 | impl BoardSyncManager {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  64 |     pub async fn start_sync_loop(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 241 |     pub async fn stop(&self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_client_type` is never used
[INFO] [stdout]    --> src/app/cli.rs:139:4
[INFO] [stdout]     |
[INFO] [stdout] 139 | fn parse_client_type(s: &str) -> Result<winter_paintboard_sdk::ClientType, String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `scale_level_operations` and `pixel_canny_priorities` are never read
[INFO] [stdout]   --> src/app/image_processing.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct ProcessedImageData {
[INFO] [stdout]    |            ------------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 26 |     pub scale_level_operations: Vec<Vec<(winter_paintboard_sdk::Pos, winter_paintboard_sdk::Rgb)>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 27 |     /// 网格图算法计算出的像素优先级映射，优先级值越高表示越重要
[INFO] [stdout] 28 |     pub pixel_canny_priorities: FxHashMap<winter_paintboard_sdk::Pos, f64>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProcessedImageData` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_cli_args` is never used
[INFO] [stdout]   --> src/app/multi_token/config.rs:78:12
[INFO] [stdout]    |
[INFO] [stdout] 45 | impl TokenConfig {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 78 |     pub fn from_cli_args(
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `metrics_handle` is never read
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct MultiTokenService {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 40 |     metrics_handle: Option<tokio::task::JoinHandle<()>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:82:18
[INFO] [stdout]    |
[INFO] [stdout] 63 | impl MultiTokenService {
[INFO] [stdout]    | ---------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 82 |     pub async fn new(
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `reset_and_push`, `len`, `is_empty`, and `get_all_pixels` are never used
[INFO] [stdout]   --> src/app/multi_token/pixel_queue.rs:40:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl PixelQueue {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub fn reset_and_push(&self, pixels: Vec<PriorityPixel>) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn len(&self) -> usize {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 75 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 85 |     pub fn get_all_pixels(&self) -> Vec<PriorityPixel> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `last_paint_time` and `is_available` are never read
[INFO] [stdout]   --> src/app/multi_token/token_manager.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct TokenInfo {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub last_paint_time: Option<Instant>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 23 |     /// 是否可用
[INFO] [stdout] 24 |     pub is_available: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TokenInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/app/multi_token/token_manager.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | impl TokenInfo {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn new(uid: u32, token: String) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `cd_duration`, `next_available_time`, and `get_token` are never used
[INFO] [stdout]    --> src/app/multi_token/token_manager.rs:191:12
[INFO] [stdout]     |
[INFO] [stdout]  61 | impl TokenManager {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn cd_duration(&self) -> Duration {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 200 |     pub fn next_available_time(&self) -> Option<Duration> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 213 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_auth_token` is never used
[INFO] [stdout]   --> src/app/utils.rs:87:14
[INFO] [stdout]    |
[INFO] [stdout] 87 | pub async fn resolve_auth_token(
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `uid` is never read
[INFO] [stdout]   --> src/app/metrics/mod.rs:42:9
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub struct TokenMetricsData {
[INFO] [stdout]    |            ---------------- field in this struct
[INFO] [stdout] 41 |     /// 关联的 UID
[INFO] [stdout] 42 |     pub uid: u32,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_token_metrics`, `record_global_paint_success`, and `record_global_paint_failure` are never used
[INFO] [stdout]    --> src/app/metrics/mod.rs:99:12
[INFO] [stdout]     |
[INFO] [stdout]  55 | impl Metrics {
[INFO] [stdout]     | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn get_token_metrics(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 116 |     pub fn record_global_paint_success(&self, uid: u32, pos: Pos) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn record_global_paint_failure(&self, uid: u32, pos: Pos) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `record_paint_success`, `record_paint_failure`, and `clear_old_entries` are never used
[INFO] [stdout]    --> src/app/metrics/mod.rs:151:12
[INFO] [stdout]     |
[INFO] [stdout] 141 | impl TokenMetricsData {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 151 |     pub fn new(uid: u32) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub(self) fn record_paint_success(&self, pos: Pos) {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 184 |     pub(self) fn record_paint_failure(&self, pos: Pos) {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 196 |     fn clear_old_entries(&self, history: &mut VecDeque<(std::time::Instant, Pos)>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 4.48s
[INFO] running `Command { std: "docker" "inspect" "28bfc65fee1c1b02278b6e12266996582dabee6c9398e9ae22e08c9313081bda", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "28bfc65fee1c1b02278b6e12266996582dabee6c9398e9ae22e08c9313081bda", kill_on_drop: false }`
[INFO] [stdout] 28bfc65fee1c1b02278b6e12266996582dabee6c9398e9ae22e08c9313081bda
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 5021c08604a6fe1eb20a0877869bf96b5c3cad7ad38b3c4c68bd577fbde8bf42
[INFO] running `Command { std: "docker" "start" "-a" "5021c08604a6fe1eb20a0877869bf96b5c3cad7ad38b3c4c68bd577fbde8bf42", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: only one of `license` or `license-file` is necessary
[INFO] [stderr] `license` should be used if the package license can be expressed with a standard SPDX expression.
[INFO] [stderr] `license-file` should be used if the package uses a non-standard license.
[INFO] [stderr] See https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields for more information.
[INFO] [stderr] warning: unused imports: `Board`, `Pos`, `Rgb`, `config::Config`, and `error::PaintboardError`
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 |     config::Config,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 26 |     error::PaintboardError,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 27 |     models::{Board, Pos, Rgb},
[INFO] [stderr]    |              ^^^^^  ^^^  ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `AtomicBool` and `Ordering`
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:29:25
[INFO] [stderr]    |
[INFO] [stderr] 29 | use std::sync::atomic::{AtomicBool, Ordering};
[INFO] [stderr]    |                         ^^^^^^^^^^  ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::sync::Arc`
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:30:5
[INFO] [stderr]    |
[INFO] [stderr] 30 | use std::sync::Arc;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `async_trait::async_trait`
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/mod.rs:32:5
[INFO] [stderr]    |
[INFO] [stderr] 32 | use async_trait::async_trait;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unexpected `cfg` condition value: `reqwest`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/error/mod.rs:216:7
[INFO] [stderr]     |
[INFO] [stderr] 216 | #[cfg(feature = "reqwest")]
[INFO] [stderr]     |       ^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stderr]     |
[INFO] [stderr]     = note: no expected values for `feature`
[INFO] [stderr]     = help: consider adding `reqwest` as a feature in `Cargo.toml`
[INFO] [stderr]     = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stderr]     = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `operations`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:104:9
[INFO] [stderr]     |
[INFO] [stderr] 104 |         operations: Vec<(Pos, Rgb)>,
[INFO] [stderr]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_operations`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `uid`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:105:9
[INFO] [stderr]     |
[INFO] [stderr] 105 |         uid: u32,
[INFO] [stderr]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_uid`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `token`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:106:9
[INFO] [stderr]     |
[INFO] [stderr] 106 |         token: &str,
[INFO] [stderr]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `operations`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/paintboard_client_trait.rs:123:9
[INFO] [stderr]     |
[INFO] [stderr] 123 |         operations: Vec<PaintOperation>,
[INFO] [stderr]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_operations`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `other`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:149:13
[INFO] [stderr]     |
[INFO] [stderr] 149 |             other => {
[INFO] [stderr]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_other`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `config_clone`
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:167:13
[INFO] [stderr]     |
[INFO] [stderr] 167 |         let config_clone = config.clone();
[INFO] [stderr]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_config_clone`
[INFO] [stderr] 
[INFO] [stderr] warning: field `rate_limiter` is never read
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:68:5
[INFO] [stderr]    |
[INFO] [stderr] 64 | struct WsActor {
[INFO] [stderr]    |        ------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 68 |     rate_limiter: Arc<WsRateLimiter>,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `actor_task_handle` is never read
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:822:5
[INFO] [stderr]     |
[INFO] [stderr] 811 | pub struct AsyncWsProvider {
[INFO] [stderr]     |            --------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 822 |     actor_task_handle: Arc<TokioMutex<Option<JoinHandle<()>>>>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `AsyncWsProvider` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `WsConnection` is never constructed
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:15:12
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub struct WsConnection {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `stream`, `connect`, `is_connected`, `send_binary`, and `close` are never used
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_connection.rs:22:12
[INFO] [stderr]     |
[INFO] [stderr]  20 | impl WsConnection {
[INFO] [stderr]     | ----------------- associated items in this implementation
[INFO] [stderr]  21 |     /// 创建一个新的 WsConnection（初始处于未连接状态）
[INFO] [stderr]  22 |     pub fn new(config: Arc<Config>) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr]  30 |     pub fn stream(&self) -> Arc<TokioMutex<Option<WebSocketStream<MaybeTlsStream<TcpStream>>>>> {
[INFO] [stderr]     |            ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  35 |     pub async fn connect(&self) -> Result<(), PaintboardError> {
[INFO] [stderr]     |                  ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  72 |     pub async fn is_connected(&self) -> bool {
[INFO] [stderr]     |                  ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  84 |     pub async fn send_binary(&self, data: Vec<u8>) -> Result<(), Report> {
[INFO] [stderr]     |                  ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 113 |     pub async fn close(&self) -> Result<(), PaintboardError> {
[INFO] [stderr]     |                  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `WsMessageHandler` is never constructed
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:22:12
[INFO] [stderr]    |
[INFO] [stderr] 22 | pub struct WsMessageHandler {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `handle_message_stream`, `handle_single_message`, and `start_message_processing_task` are never used
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_message_handler.rs:27:12
[INFO] [stderr]     |
[INFO] [stderr]  26 | impl WsMessageHandler {
[INFO] [stderr]     | --------------------- associated items in this implementation
[INFO] [stderr]  27 |     pub fn new(response_tracker: Arc<WsResponseTracker>) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr]  32 |     pub async fn handle_message_stream(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  84 |     async fn handle_single_message(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 156 |     pub async fn start_message_processing_task(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `current_delay` is never used
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:58:12
[INFO] [stderr]    |
[INFO] [stderr] 18 | impl WsReconnectStrategy {
[INFO] [stderr]    | ------------------------ method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 58 |     pub fn current_delay(&self) -> Duration {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `current_delay`, and `reconnect` are never used
[INFO] [stderr]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:69:12
[INFO] [stderr]     |
[INFO] [stderr]  68 | impl WsReconnectManager {
[INFO] [stderr]     | ----------------------- associated items in this implementation
[INFO] [stderr]  69 |     pub fn new(initial_delay: Duration, max_delay: Duration) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr]  97 |     pub fn current_delay(&self) -> Duration {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 101 |     pub async fn reconnect(&mut self, connection: Arc<WsConnection>) -> Result<()> {
[INFO] [stderr]     |                  ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `pending_count` is never used
[INFO] [stderr]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_response_tracker.rs:63:18
[INFO] [stderr]    |
[INFO] [stderr] 20 | impl WsResponseTracker {
[INFO] [stderr]    | ---------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 63 |     pub async fn pending_count(&self) -> usize {
[INFO] [stderr]    |                  ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `winter-paintboard-sdk` (lib) generated 20 warnings (run `cargo fix --lib -p winter-paintboard-sdk` to apply 10 suggestions)
[INFO] [stderr] warning: unused import: `time::Duration`
[INFO] [stderr]  --> src/app/board_sync/local_board.rs:6:22
[INFO] [stderr]   |
[INFO] [stderr] 6 | use std::{sync::Arc, time::Duration};
[INFO] [stderr]   |                      ^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `self`
[INFO] [stderr]  --> src/app/image_processing.rs:8:24
[INFO] [stderr]   |
[INFO] [stderr] 8 | use imageproc::edges::{self, canny};
[INFO] [stderr]   |                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rustc_hash::FxHashMap`
[INFO] [stderr]  --> src/app/multi_token/multi_token_service.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 | use rustc_hash::FxHashMap;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `AtomicU64`
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:10:37
[INFO] [stderr]    |
[INFO] [stderr] 10 | use std::sync::atomic::{AtomicBool, AtomicU64, Ordering};
[INFO] [stderr]    |                                     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Instant`
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:13:36
[INFO] [stderr]    |
[INFO] [stderr] 13 | use tokio::time::{interval, sleep, Instant};
[INFO] [stderr]    |                                    ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `parking_lot::RwLock`
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | use parking_lot::RwLock;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::app::multi_token::cli::get_penalty_scale`
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:19:5
[INFO] [stderr]    |
[INFO] [stderr] 19 | use crate::app::multi_token::cli::get_penalty_scale;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::panic::AssertUnwindSafe`
[INFO] [stderr]  --> src/app/multi_token/paint_batcher.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::panic::AssertUnwindSafe;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `parking_lot::Mutex`
[INFO] [stderr]  --> src/app/multi_token/token_lease.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use parking_lot::Mutex;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]  --> src/app/multi_token/token_lease.rs:9:17
[INFO] [stderr]   |
[INFO] [stderr] 9 | use std::time::{Duration, Instant};
[INFO] [stderr]   |                 ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `PaintboardClientTrait`
[INFO] [stderr]   --> src/app/multi_token/token_worker.rs:15:53
[INFO] [stderr]    |
[INFO] [stderr] 15 | use winter_paintboard_sdk::{models::PaintOperation, PaintboardClientTrait};
[INFO] [stderr]    |                                                     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `winter_paintboard_sdk::Rgb`
[INFO] [stderr]  --> src/app/utils.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use winter_paintboard_sdk::Rgb;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `app::board_sync::local_board::LocalBoard::verify_integrity`: 不必要的完整性检查，造成性能损耗，改为返回 `true`
[INFO] [stderr]    --> src/app/board_sync/sync_manager.rs:204:35
[INFO] [stderr]     |
[INFO] [stderr] 204 |                         if !board.verify_integrity() {
[INFO] [stderr]     |                                   ^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stderr]   --> src/app/board_sync/sync_manager.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `PaintboardClientTrait`
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:26:72
[INFO] [stderr]    |
[INFO] [stderr] 26 | use winter_paintboard_sdk::{basic_client::AsyncClient, config::Config, PaintboardClientTrait};
[INFO] [stderr]    |                                                                        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `uid`
[INFO] [stderr]    --> src/app/board_sync/local_board.rs:365:50
[INFO] [stderr]     |
[INFO] [stderr] 365 |                     event::PaintEvent::Success { uid, pos, color } => {
[INFO] [stderr]     |                                                  ^^^ help: try ignoring the field: `uid: _`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `uid`
[INFO] [stderr]    --> src/app/board_sync/local_board.rs:388:50
[INFO] [stderr]     |
[INFO] [stderr] 388 |                     event::PaintEvent::Failure { uid, pos } => {
[INFO] [stderr]     |                                                  ^^^ help: try ignoring the field: `uid: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `canny_low_thresh`
[INFO] [stderr]    --> src/app/multi_token/multi_token_service.rs:133:9
[INFO] [stderr]     |
[INFO] [stderr] 133 |         canny_low_thresh: f32,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_low_thresh`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `canny_high_thresh`
[INFO] [stderr]    --> src/app/multi_token/multi_token_service.rs:134:9
[INFO] [stderr]     |
[INFO] [stderr] 134 |         canny_high_thresh: f32,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_canny_high_thresh`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `relative_pos`
[INFO] [stderr]    --> src/app/multi_token/multi_token_service.rs:345:21
[INFO] [stderr]     |
[INFO] [stderr] 345 |                 let relative_pos = relative_pos.unwrap();
[INFO] [stderr]     |                     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_relative_pos`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `index`
[INFO] [stderr]    --> src/app/multi_token/token_manager.rs:213:29
[INFO] [stderr]     |
[INFO] [stderr] 213 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stderr]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `access_keys`
[INFO] [stderr]   --> src/app/mod.rs:61:13
[INFO] [stderr]    |
[INFO] [stderr] 61 |             access_keys,
[INFO] [stderr]    |             ^^^^^^^^^^^ help: try ignoring the field: `access_keys: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `uids`
[INFO] [stderr]   --> src/app/mod.rs:62:13
[INFO] [stderr]    |
[INFO] [stderr] 62 |             uids,
[INFO] [stderr]    |             ^^^^ help: try ignoring the field: `uids: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `token`
[INFO] [stderr]    --> src/app/mod.rs:277:9
[INFO] [stderr]     |
[INFO] [stderr] 277 |     let token = match validate_auth_args(&token, &access_key) {
[INFO] [stderr]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/app/mod.rs:159:73
[INFO] [stderr]     |
[INFO] [stderr] 159 |     let _ = multi_token::cli::PENALTY_SCALE.set(penalty_scale).map_err(|e| {
[INFO] [stderr]     |                                                                         ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `cd_time`
[INFO] [stderr]    --> src/app/mod.rs:141:5
[INFO] [stderr]     |
[INFO] [stderr] 141 |     cd_time: u64,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cd_time`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `token`
[INFO] [stderr]    --> src/app/mod.rs:185:13
[INFO] [stderr]     |
[INFO] [stderr] 185 |         let token = match (&first_token.token, &first_token.access_key) {
[INFO] [stderr]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_token`
[INFO] [stderr] 
[INFO] [stderr] warning: constant `HEATMAP_EXPIRE_DURATION_MILLS` is never used
[INFO] [stderr]   --> src/app/board_sync/local_board.rs:18:7
[INFO] [stderr]    |
[INFO] [stderr] 18 | const HEATMAP_EXPIRE_DURATION_MILLS: u64 = 10 * 60 * 1000; // 10min
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: fields `source` and `timestamp` are never read
[INFO] [stderr]   --> src/app/board_sync/local_board.rs:38:9
[INFO] [stderr]    |
[INFO] [stderr] 34 | pub struct PixelStatus {
[INFO] [stderr]    |            ----------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 38 |     pub source: PixelSource,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 39 |     /// 像素更新时间戳
[INFO] [stderr] 40 |     pub timestamp: std::time::SystemTime,
[INFO] [stderr]    |         ^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `PixelStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/app/board_sync/local_board.rs:76:11
[INFO] [stderr]    |
[INFO] [stderr] 76 |     Error(String),
[INFO] [stderr]    |     ----- ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `SyncStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 76 -     Error(String),
[INFO] [stderr] 76 +     Error(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Syncing` is never constructed
[INFO] [stderr]   --> src/app/board_sync/local_board.rs:74:5
[INFO] [stderr]    |
[INFO] [stderr] 70 | pub enum SyncStatus {
[INFO] [stderr]    |          ---------- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 74 |     Syncing,
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `SyncStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `sync_status`, `last_sync_time`, and `version` are never used
[INFO] [stderr]    --> src/app/board_sync/local_board.rs:293:12
[INFO] [stderr]     |
[INFO] [stderr]  79 | impl LocalBoard {
[INFO] [stderr]     | --------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 293 |     pub fn sync_status(&self) -> SyncStatus {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 311 |     pub fn last_sync_time(&self) -> Option<std::time::SystemTime> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 329 |     pub fn version(&self) -> u64 {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `start_sync_loop` and `stop` are never used
[INFO] [stderr]    --> src/app/board_sync/sync_manager.rs:64:18
[INFO] [stderr]     |
[INFO] [stderr]  28 | impl BoardSyncManager {
[INFO] [stderr]     | --------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  64 |     pub async fn start_sync_loop(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 241 |     pub async fn stop(&self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]     |                  ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_client_type` is never used
[INFO] [stderr]    --> src/app/cli.rs:139:4
[INFO] [stderr]     |
[INFO] [stderr] 139 | fn parse_client_type(s: &str) -> Result<winter_paintboard_sdk::ClientType, String> {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `scale_level_operations` and `pixel_canny_priorities` are never read
[INFO] [stderr]   --> src/app/image_processing.rs:26:9
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub struct ProcessedImageData {
[INFO] [stderr]    |            ------------------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 26 |     pub scale_level_operations: Vec<Vec<(winter_paintboard_sdk::Pos, winter_paintboard_sdk::Rgb)>>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 27 |     /// 网格图算法计算出的像素优先级映射，优先级值越高表示越重要
[INFO] [stderr] 28 |     pub pixel_canny_priorities: FxHashMap<winter_paintboard_sdk::Pos, f64>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ProcessedImageData` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_cli_args` is never used
[INFO] [stderr]   --> src/app/multi_token/config.rs:78:12
[INFO] [stderr]    |
[INFO] [stderr] 45 | impl TokenConfig {
[INFO] [stderr]    | ---------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 78 |     pub fn from_cli_args(
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `metrics_handle` is never read
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:40:5
[INFO] [stderr]    |
[INFO] [stderr] 32 | pub struct MultiTokenService {
[INFO] [stderr]    |            ----------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 40 |     metrics_handle: Option<tokio::task::JoinHandle<()>>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/app/multi_token/multi_token_service.rs:82:18
[INFO] [stderr]    |
[INFO] [stderr] 63 | impl MultiTokenService {
[INFO] [stderr]    | ---------------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 82 |     pub async fn new(
[INFO] [stderr]    |                  ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `reset_and_push`, `len`, `is_empty`, and `get_all_pixels` are never used
[INFO] [stderr]   --> src/app/multi_token/pixel_queue.rs:40:12
[INFO] [stderr]    |
[INFO] [stderr] 21 | impl PixelQueue {
[INFO] [stderr]    | --------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 40 |     pub fn reset_and_push(&self, pixels: Vec<PriorityPixel>) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 65 |     pub fn len(&self) -> usize {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 75 |     pub fn is_empty(&self) -> bool {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 85 |     pub fn get_all_pixels(&self) -> Vec<PriorityPixel> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `last_paint_time` and `is_available` are never read
[INFO] [stderr]   --> src/app/multi_token/token_manager.rs:22:9
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub struct TokenInfo {
[INFO] [stderr]    |            --------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 22 |     pub last_paint_time: Option<Instant>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^
[INFO] [stderr] 23 |     /// 是否可用
[INFO] [stderr] 24 |     pub is_available: bool,
[INFO] [stderr]    |         ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `TokenInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/app/multi_token/token_manager.rs:38:12
[INFO] [stderr]    |
[INFO] [stderr] 27 | impl TokenInfo {
[INFO] [stderr]    | -------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 38 |     pub fn new(uid: u32, token: String) -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `cd_duration`, `next_available_time`, and `get_token` are never used
[INFO] [stderr]    --> src/app/multi_token/token_manager.rs:191:12
[INFO] [stderr]     |
[INFO] [stderr]  61 | impl TokenManager {
[INFO] [stderr]     | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 191 |     pub fn cd_duration(&self) -> Duration {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 200 |     pub fn next_available_time(&self) -> Option<Duration> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 213 |     pub fn get_token(&self, index: usize) -> Option<&TokenInfo> {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `resolve_auth_token` is never used
[INFO] [stderr]   --> src/app/utils.rs:87:14
[INFO] [stderr]    |
[INFO] [stderr] 87 | pub async fn resolve_auth_token(
[INFO] [stderr]    |              ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `uid` is never read
[INFO] [stderr]   --> src/app/metrics/mod.rs:42:9
[INFO] [stderr]    |
[INFO] [stderr] 40 | pub struct TokenMetricsData {
[INFO] [stderr]    |            ---------------- field in this struct
[INFO] [stderr] 41 |     /// 关联的 UID
[INFO] [stderr] 42 |     pub uid: u32,
[INFO] [stderr]    |         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `get_token_metrics`, `record_global_paint_success`, and `record_global_paint_failure` are never used
[INFO] [stderr]    --> src/app/metrics/mod.rs:99:12
[INFO] [stderr]     |
[INFO] [stderr]  55 | impl Metrics {
[INFO] [stderr]     | ------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  99 |     pub fn get_token_metrics(
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 116 |     pub fn record_global_paint_success(&self, uid: u32, pos: Pos) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 132 |     pub fn record_global_paint_failure(&self, uid: u32, pos: Pos) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `record_paint_success`, `record_paint_failure`, and `clear_old_entries` are never used
[INFO] [stderr]    --> src/app/metrics/mod.rs:151:12
[INFO] [stderr]     |
[INFO] [stderr] 141 | impl TokenMetricsData {
[INFO] [stderr]     | --------------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 151 |     pub fn new(uid: u32) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 168 |     pub(self) fn record_paint_success(&self, pos: Pos) {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 184 |     pub(self) fn record_paint_failure(&self, pos: Pos) {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 196 |     fn clear_old_entries(&self, history: &mut VecDeque<(std::time::Instant, Pos)>) {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `lgs-paintboard` (bin "lgs-paintboard" test) generated 46 warnings (run `cargo fix --bin "lgs-paintboard" -p lgs-paintboard --tests` to apply 24 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.39s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/lgs_paintboard-e25fa25eb3293b21)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test app::board_sync::local_board::tests::test_local_board_creation ... ok
[INFO] [stdout] test app::board_sync::local_board::tests::test_local_board_pixel_operations ... ok
[INFO] [stdout] test app::board_sync::local_board::tests::test_update_from_board_applies_server_data ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.99s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "5021c08604a6fe1eb20a0877869bf96b5c3cad7ad38b3c4c68bd577fbde8bf42", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5021c08604a6fe1eb20a0877869bf96b5c3cad7ad38b3c4c68bd577fbde8bf42", kill_on_drop: false }`
[INFO] [stdout] 5021c08604a6fe1eb20a0877869bf96b5c3cad7ad38b3c4c68bd577fbde8bf42
