[INFO] cloning repository https://github.com/xyber-nova/LGS-Paintboard-Helper
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/xyber-nova/LGS-Paintboard-Helper" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fxyber-nova%2FLGS-Paintboard-Helper", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fxyber-nova%2FLGS-Paintboard-Helper'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] ea32c8edfc9a8553a04d4959602af7c90529735f
[INFO] checking xyber-nova/LGS-Paintboard-Helper against try#84addd32a13fa2d3f62fe5d99031611147b7fb13 for pr-147565-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fxyber-nova%2FLGS-Paintboard-Helper" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/xyber-nova/LGS-Paintboard-Helper
[INFO] finished tweaking git repo https://github.com/xyber-nova/LGS-Paintboard-Helper
[INFO] tweaked toml for git repo https://github.com/xyber-nova/LGS-Paintboard-Helper written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/xyber-nova/LGS-Paintboard-Helper on toolchain 84addd32a13fa2d3f62fe5d99031611147b7fb13
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+84addd32a13fa2d3f62fe5d99031611147b7fb13" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/xyber-nova/LGS-Paintboard-Helper 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" "+84addd32a13fa2d3f62fe5d99031611147b7fb13" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: /workspace/builds/worker-7-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] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+84addd32a13fa2d3f62fe5d99031611147b7fb13" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 727392b9d1f752c8e2ecb63712c290018a0a8929e781a91b1151ea62d4414744
[INFO] running `Command { std: "docker" "start" "-a" "727392b9d1f752c8e2ecb63712c290018a0a8929e781a91b1151ea62d4414744", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "727392b9d1f752c8e2ecb63712c290018a0a8929e781a91b1151ea62d4414744", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "727392b9d1f752c8e2ecb63712c290018a0a8929e781a91b1151ea62d4414744", kill_on_drop: false }`
[INFO] [stdout] 727392b9d1f752c8e2ecb63712c290018a0a8929e781a91b1151ea62d4414744
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+84addd32a13fa2d3f62fe5d99031611147b7fb13" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a7de9c9b9d724151dac0740edef8d1b92197a6cbc90d28163aa1d04f1125c8eb
[INFO] running `Command { std: "docker" "start" "-a" "a7de9c9b9d724151dac0740edef8d1b92197a6cbc90d28163aa1d04f1125c8eb", 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 libc v0.2.177
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]    Compiling quote v1.0.41
[INFO] [stderr]     Checking bytes v1.10.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]     Checking lock_api v0.4.14
[INFO] [stderr]     Checking futures-sink v0.3.31
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]     Checking tracing-core v0.1.34
[INFO] [stderr]     Checking futures-io v0.3.31
[INFO] [stderr]     Checking stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling find-msvc-tools v0.1.4
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling cc v1.2.41
[INFO] [stderr]    Compiling vcpkg v0.2.15
[INFO] [stderr]     Checking tower-service v0.3.3
[INFO] [stderr]     Checking equivalent v1.0.2
[INFO] [stderr]     Checking hashbrown v0.16.0
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]     Checking indexmap v2.11.4
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking mio v1.0.4
[INFO] [stderr]     Checking signal-hook-registry v1.4.6
[INFO] [stderr]     Checking socket2 v0.6.0
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]     Checking bitflags v2.9.4
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking http v1.3.1
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]     Checking regex-syntax v0.8.7
[INFO] [stderr]    Compiling generic-array v0.14.8
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]     Checking foreign-types-shared v0.1.1
[INFO] [stderr]     Checking foreign-types v0.3.2
[INFO] [stderr]     Checking http v0.2.12
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]     Checking crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling anyhow v1.0.100
[INFO] [stderr]     Checking openssl-probe v0.1.6
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]     Checking crossbeam-deque v0.8.6
[INFO] [stderr]     Checking form_urlencoded v1.2.2
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking thread_local v1.1.9
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling getrandom v0.1.16
[INFO] [stderr]     Checking tower-layer v0.3.3
[INFO] [stderr]     Checking bytemuck v1.24.0
[INFO] [stderr]     Checking regex-automata v0.4.12
[INFO] [stderr]     Checking nu-ansi-term v0.50.3
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]     Checking crypto-common v0.1.6
[INFO] [stderr]     Checking flate2 v1.1.4
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]     Checking sync_wrapper v1.0.2
[INFO] [stderr]    Compiling owo-colors v4.2.3
[INFO] [stderr]    Compiling object v0.37.3
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking http-body v0.4.6
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]    Compiling eyre v0.6.12
[INFO] [stderr]    Compiling color-spantrace v0.3.0
[INFO] [stderr]     Checking cpufeatures v0.2.17
[INFO] [stderr]     Checking gimli v0.32.3
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking serde_json v1.0.145
[INFO] [stderr]     Checking rayon v1.11.0
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking safe_arch v0.7.4
[INFO] [stderr]     Checking raw-cpuid v11.6.0
[INFO] [stderr]     Checking num-complex v0.4.6
[INFO] [stderr]    Compiling matrixmultiply v0.3.10
[INFO] [stderr]     Checking matchit v0.7.3
[INFO] [stderr]     Checking rustc-demangle v0.1.26
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking indenter v0.3.4
[INFO] [stderr]     Checking data-encoding v2.9.0
[INFO] [stderr]     Checking wide v0.7.33
[INFO] [stderr]     Checking addr2line v0.25.1
[INFO] [stderr]     Checking num-rational v0.4.2
[INFO] [stderr]     Checking jpeg-decoder v0.3.2
[INFO] [stderr]     Checking dashmap v5.5.3
[INFO] [stderr]     Checking getrandom v0.3.3
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking num_cpus v1.17.0
[INFO] [stderr]     Checking zune-inflate v0.2.54
[INFO] [stderr]     Checking spinning_top v0.3.0
[INFO] [stderr]     Checking quanta v0.12.6
[INFO] [stderr]     Checking encoding_rs v0.8.35
[INFO] [stderr]     Checking no-std-compat v0.4.1
[INFO] [stderr]     Checking rawpointer v0.2.1
[INFO] [stderr]     Checking anstyle v1.0.13
[INFO] [stderr]     Checking ttf-parser v0.15.2
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling zerocopy-derive v0.8.27
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]     Checking tokio v1.47.1
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]     Checking tracing v0.1.41
[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]     Checking tracing-subscriber v0.3.20
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking yoke v0.8.0
[INFO] [stderr]     Checking zerovec v0.11.4
[INFO] [stderr]     Checking zerotrie v0.2.2
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]     Checking tinystr v0.8.1
[INFO] [stderr]     Checking icu_locale_core v2.0.0
[INFO] [stderr]     Checking potential_utf v0.1.3
[INFO] [stderr]     Checking icu_collections v2.0.0
[INFO] [stderr]     Checking async-stream v0.3.6
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling prost-derive v0.13.5
[INFO] [stderr]     Checking icu_provider v2.0.0
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]     Checking icu_normalizer v2.0.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking icu_properties v2.0.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking axum-core v0.4.5
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking tracing-error v0.2.1
[INFO] [stderr]     Checking tokio-util v0.7.16
[INFO] [stderr]     Checking tokio-stream v0.1.17
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking prost v0.13.5
[INFO] [stderr]     Checking pin-project v1.1.10
[INFO] [stderr]     Checking deadpool-runtime v0.1.4
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking half v2.7.0
[INFO] [stderr]     Checking backtrace v0.3.76
[INFO] [stderr]     Checking h2 v0.4.12
[INFO] [stderr]     Checking h2 v0.3.27
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking futures-timer v3.0.3
[INFO] [stderr]     Checking lebe v0.5.3
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking bit_field v0.10.3
[INFO] [stderr]     Checking ipnet v2.11.0
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking nonzero_ext v0.3.0
[INFO] [stderr]     Checking anstream v0.6.21
[INFO] [stderr]     Checking governor v0.6.3
[INFO] [stderr]     Checking url v2.5.7
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking exr v1.73.0
[INFO] [stderr]     Checking gif v0.13.3
[INFO] [stderr]     Checking color-eyre v0.6.5
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking prost-types v0.13.5
[INFO] [stderr]     Checking deadpool v0.12.3
[INFO] [stderr]     Checking tungstenite v0.20.1
[INFO] [stderr]     Checking owned_ttf_parser v0.15.2
[INFO] [stderr]     Checking simba v0.7.3
[INFO] [stderr]     Checking axum v0.7.9
[INFO] [stderr]     Checking tokio-tungstenite v0.20.1
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking png v0.17.16
[INFO] [stderr]     Checking tiff v0.9.1
[INFO] [stderr]     Checking hyper v1.7.0
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]     Checking uuid v1.18.1
[INFO] [stderr]     Checking num-iter v0.1.45
[INFO] [stderr]     Checking qoi v0.4.1
[INFO] [stderr]     Checking humantime v2.3.0
[INFO] [stderr]     Checking custom_derive v0.1.7
[INFO] [stderr]     Checking clap_builder v4.5.48
[INFO] [stderr]     Checking conv v0.3.3
[INFO] [stderr]     Checking hdrhistogram v7.5.4
[INFO] [stderr]     Checking hyper-util v0.1.17
[INFO] [stderr]     Checking image v0.24.9
[INFO] [stderr]     Checking rusttype v0.9.3
[INFO] [stderr]    Compiling clap_derive v4.5.47
[INFO] [stderr]     Checking num v0.4.3
[INFO] [stderr]     Checking rand_distr v0.2.2
[INFO] [stderr]     Checking regex v1.12.1
[INFO] [stderr]     Checking itertools v0.10.5
[INFO] [stderr]     Checking hyper-timeout v0.5.2
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]     Checking is-terminal v0.4.16
[INFO] [stderr]     Checking crossbeam-channel v0.5.15
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking env_logger v0.10.2
[INFO] [stderr]     Checking tokio-test v0.4.4
[INFO] [stderr]     Checking winter-paintboard-sdk v0.1.0 (/opt/rustwide/workdir/crates/winter-paintboard-sdk)
[INFO] [stderr]     Checking 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] [stderr]     Checking clap v4.5.48
[INFO] [stderr]     Checking nalgebra v0.30.1
[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: `event_bus`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:316:21
[INFO] [stdout]     |
[INFO] [stdout] 316 |                 let event_bus = EventBus::global();
[INFO] [stdout]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_bus`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `client`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/http_client.rs:117:13
[INFO] [stdout]     |
[INFO] [stdout] 117 |         let client = HttpProvider::new(config).unwrap();
[INFO] [stdout]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_client`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) 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] 
[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: `event_bus`
[INFO] [stdout]    --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:316:21
[INFO] [stdout]     |
[INFO] [stdout] 316 |                 let event_bus = EventBus::global();
[INFO] [stdout]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_bus`
[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] [stderr]     Checking console-api v0.8.1
[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:65:5
[INFO] [stdout]    |
[INFO] [stdout] 61 | struct WsActor {
[INFO] [stdout]    |        ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 65 |     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:826:5
[INFO] [stdout]     |
[INFO] [stdout] 816 | pub struct AsyncWsProvider {
[INFO] [stdout]     |            --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 826 |     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]  76 |     pub async fn is_connected(&self) -> bool {
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  88 |     pub async fn send_binary(&self, data: Vec<u8>) -> Result<(), Report> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     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]  85 |     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: fields `current_delay`, `max_delay`, and `initial_delay` are never read
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct WsReconnectStrategy {
[INFO] [stdout]    |            ------------------- fields in this struct
[INFO] [stdout] 12 |     should_reconnect: Arc<AtomicBool>,
[INFO] [stdout] 13 |     current_delay: Duration,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 14 |     max_delay: Duration,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 15 |     initial_delay: Duration,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `WsReconnectStrategy` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `should_reconnect`, `next_delay`, `reset`, and `current_delay` are never used
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/ws_reconnect.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl WsReconnectStrategy {
[INFO] [stdout]    | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn should_reconnect(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn next_delay(&mut self) -> Duration {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn reset(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn current_delay(&self) -> Duration {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `should_reconnect`, `next_delay`, `reset`, `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]  81 |     pub fn should_reconnect(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  89 |     pub async fn next_delay(&mut self) -> Duration {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub async fn reset(&mut 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] [stdout] warning: field `rate_limiter` is never read
[INFO] [stdout]   --> crates/winter-paintboard-sdk/src/basic_client/ws_provider/async_ws_provider.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 61 | struct WsActor {
[INFO] [stdout]    |        ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 65 |     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:826:5
[INFO] [stdout]     |
[INFO] [stdout] 816 | pub struct AsyncWsProvider {
[INFO] [stdout]     |            --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 826 |     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]  76 |     pub async fn is_connected(&self) -> bool {
[INFO] [stdout]     |                  ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  88 |     pub async fn send_binary(&self, data: Vec<u8>) -> Result<(), Report> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     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]  85 |     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: associated items `new`, `should_reconnect`, `next_delay`, `reset`, `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]  81 |     pub fn should_reconnect(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  89 |     pub async fn next_delay(&mut self) -> Duration {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub async fn reset(&mut 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]     Checking console-subscriber v0.4.1
[INFO] [stderr]     Checking imageproc v0.23.0
[INFO] [stderr]     Checking lgs-paintboard v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `time::Duration`
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | 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: `crate::app::multi_token::cli::get_penalty_scale`
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::app::multi_token::cli::get_penalty_scale;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/app/image_processing.rs:3:24
[INFO] [stdout]   |
[INFO] [stdout] 3 | use imageproc::edges::{self, canny};
[INFO] [stdout]   |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `clap::error`
[INFO] [stdout]  --> src/app/multi_token/paint_executor.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use clap::error;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `color_eyre::Report`
[INFO] [stdout]  --> src/app/multi_token/paint_executor.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use color_eyre::Report;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::Rgb`
[INFO] [stdout]  --> src/app/utils.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use winter_paintboard_sdk::Rgb;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `time::Duration`
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | 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: `crate::app::multi_token::cli::get_penalty_scale`
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::app::multi_token::cli::get_penalty_scale;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/app/image_processing.rs:3:24
[INFO] [stdout]   |
[INFO] [stdout] 3 | use imageproc::edges::{self, canny};
[INFO] [stdout]   |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `clap::error`
[INFO] [stdout]  --> src/app/multi_token/paint_executor.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use clap::error;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `color_eyre::Report`
[INFO] [stdout]  --> src/app/multi_token/paint_executor.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use color_eyre::Report;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::Rgb`
[INFO] [stdout]  --> src/app/utils.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | 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:166:35
[INFO] [stdout]     |
[INFO] [stdout] 166 |                         if !board.verify_integrity() {
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[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:166:35
[INFO] [stdout]     |
[INFO] [stdout] 166 |                         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:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | 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:21:72
[INFO] [stdout]    |
[INFO] [stdout] 21 | use winter_paintboard_sdk::{basic_client::AsyncClient, config::Config, PaintboardClientTrait};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stdout]  --> src/app/multi_token/token_worker.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `original_version`
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:172:13
[INFO] [stdout]     |
[INFO] [stdout] 172 |         let original_version = self.version;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_version`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) 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:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | 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:21:72
[INFO] [stdout]    |
[INFO] [stdout] 21 | use winter_paintboard_sdk::{basic_client::AsyncClient, config::Config, PaintboardClientTrait};
[INFO] [stdout]    |                                                                        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `winter_paintboard_sdk::PaintboardClientTrait`
[INFO] [stdout]  --> src/app/multi_token/token_worker.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use winter_paintboard_sdk::PaintboardClientTrait;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `original_version`
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:172:13
[INFO] [stdout]     |
[INFO] [stdout] 172 |         let original_version = self.version;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_version`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canny_low_thresh`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |         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:77:9
[INFO] [stdout]    |
[INFO] [stdout] 77 |         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: `canny_low_thresh`
[INFO] [stdout]   --> src/app/multi_token/multi_token_service.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |         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:77:9
[INFO] [stdout]    |
[INFO] [stdout] 77 |         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: `index`
[INFO] [stdout]    --> src/app/multi_token/token_manager.rs:120:29
[INFO] [stdout]     |
[INFO] [stdout] 120 |     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:42:13
[INFO] [stdout]    |
[INFO] [stdout] 42 |             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:43:13
[INFO] [stdout]    |
[INFO] [stdout] 43 |             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:214:9
[INFO] [stdout]     |
[INFO] [stdout] 214 |     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: `index`
[INFO] [stdout]    --> src/app/multi_token/token_manager.rs:120:29
[INFO] [stdout]     |
[INFO] [stdout] 120 |     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: `e`
[INFO] [stdout]    --> src/app/mod.rs:110:73
[INFO] [stdout]     |
[INFO] [stdout] 110 |     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:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 |     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:137:13
[INFO] [stdout]     |
[INFO] [stdout] 137 |         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: unused variable: `access_keys`
[INFO] [stdout]   --> src/app/mod.rs:42:13
[INFO] [stdout]    |
[INFO] [stdout] 42 |             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:43:13
[INFO] [stdout]    |
[INFO] [stdout] 43 |             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:214:9
[INFO] [stdout]     |
[INFO] [stdout] 214 |     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:110:73
[INFO] [stdout]     |
[INFO] [stdout] 110 |     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:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 |     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:137:13
[INFO] [stdout]     |
[INFO] [stdout] 137 |         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:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | 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:22:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct PixelStatus {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 21 |     pub color: Rgb,
[INFO] [stdout] 22 |     pub source: PixelSource,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 23 |     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:45:11
[INFO] [stdout]    |
[INFO] [stdout] 45 |     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] 45 -     Error(String),
[INFO] [stdout] 45 +     Error(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Syncing` is never constructed
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub enum SyncStatus {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] 43 |     Idle,
[INFO] [stdout] 44 |     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:218:12
[INFO] [stdout]     |
[INFO] [stdout]  48 | impl LocalBoard {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 218 |     pub fn sync_status(&self) -> &SyncStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn last_sync_time(&self) -> Option<&std::time::SystemTime> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 238 |     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:38:18
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl BoardSyncManager {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  38 |     pub async fn start_sync_loop(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 297 |     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:127:4
[INFO] [stdout]     |
[INFO] [stdout] 127 | fn parse_client_type(s: &str) -> Result<winter_paintboard_sdk::ClientType, String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `scale_level_operations` is never read
[INFO] [stdout]   --> src/app/image_processing.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct ProcessedImageData {
[INFO] [stdout]    |            ------------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 14 |     pub scale_level_operations: Vec<Vec<(winter_paintboard_sdk::Pos, winter_paintboard_sdk::Rgb)>>,
[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:35:12
[INFO] [stdout]    |
[INFO] [stdout] 26 | impl TokenConfig {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |     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:28:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct MultiTokenService {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 28 |     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:44:18
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl MultiTokenService {
[INFO] [stdout]    | ---------------------- associated function in this implementation
[INFO] [stdout] 43 |     /// 创建新的多 Token 服务
[INFO] [stdout] 44 |     pub async fn new(
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `retry_count` and `max_retries` are never read
[INFO] [stdout]   --> src/app/multi_token/paint_request.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct PaintRequest {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout]  9 |     pub retry_count: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 10 |     pub max_retries: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PaintRequest` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `can_retry` and `increment_retry` are never used
[INFO] [stdout]   --> src/app/multi_token/paint_request.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl PaintRequest {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn can_retry(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn increment_retry(&mut self) {
[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:22:18
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl PixelQueue {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub async fn reset_and_push(&self, pixels: Vec<PriorityPixel>) {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub async fn len(&self) -> usize {
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 43 |     pub async fn is_empty(&self) -> bool {
[INFO] [stdout]    |                  ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub async 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:11:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct TokenInfo {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 11 |     pub last_paint_time: Option<Instant>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 12 |     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:17:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl TokenInfo {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 16 |     /// 创建新的 TokenInfo
[INFO] [stdout] 17 |     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:110:12
[INFO] [stdout]     |
[INFO] [stdout]  34 | impl TokenManager {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub fn cd_duration(&self) -> Duration {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn next_available_time(&self) -> Option<Duration> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 120 |     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:46:14
[INFO] [stdout]    |
[INFO] [stdout] 46 | 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:26:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct TokenMetricsData {
[INFO] [stdout]    |            ---------------- field in this struct
[INFO] [stdout] 25 |     /// 关联的 UID
[INFO] [stdout] 26 |     pub uid: u32,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HEATMAP_EXPIRE_DURATION_MILLS` is never used
[INFO] [stdout]  --> src/app/board_sync/local_board.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | 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:22:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct PixelStatus {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 21 |     pub color: Rgb,
[INFO] [stdout] 22 |     pub source: PixelSource,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 23 |     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:45:11
[INFO] [stdout]    |
[INFO] [stdout] 45 |     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] 45 -     Error(String),
[INFO] [stdout] 45 +     Error(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Syncing` is never constructed
[INFO] [stdout]   --> src/app/board_sync/local_board.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub enum SyncStatus {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] 43 |     Idle,
[INFO] [stdout] 44 |     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:218:12
[INFO] [stdout]     |
[INFO] [stdout]  48 | impl LocalBoard {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 218 |     pub fn sync_status(&self) -> &SyncStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn last_sync_time(&self) -> Option<&std::time::SystemTime> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 238 |     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:38:18
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl BoardSyncManager {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  38 |     pub async fn start_sync_loop(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 297 |     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:127:4
[INFO] [stdout]     |
[INFO] [stdout] 127 | fn parse_client_type(s: &str) -> Result<winter_paintboard_sdk::ClientType, String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `scale_level_operations` is never read
[INFO] [stdout]   --> src/app/image_processing.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct ProcessedImageData {
[INFO] [stdout]    |            ------------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 14 |     pub scale_level_operations: Vec<Vec<(winter_paintboard_sdk::Pos, winter_paintboard_sdk::Rgb)>>,
[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:35:12
[INFO] [stdout]    |
[INFO] [stdout] 26 | impl TokenConfig {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |     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:28:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct MultiTokenService {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 28 |     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:44:18
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl MultiTokenService {
[INFO] [stdout]    | ---------------------- associated function in this implementation
[INFO] [stdout] 43 |     /// 创建新的多 Token 服务
[INFO] [stdout] 44 |     pub async fn new(
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `retry_count` and `max_retries` are never read
[INFO] [stdout]   --> src/app/multi_token/paint_request.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub struct PaintRequest {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout]  9 |     pub retry_count: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 10 |     pub max_retries: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PaintRequest` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `can_retry` and `increment_retry` are never used
[INFO] [stdout]   --> src/app/multi_token/paint_request.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl PaintRequest {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn can_retry(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn increment_retry(&mut self) {
[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:22:18
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl PixelQueue {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub async fn reset_and_push(&self, pixels: Vec<PriorityPixel>) {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub async fn len(&self) -> usize {
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 43 |     pub async fn is_empty(&self) -> bool {
[INFO] [stdout]    |                  ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub async 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:11:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct TokenInfo {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 11 |     pub last_paint_time: Option<Instant>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 12 |     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:17:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl TokenInfo {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 16 |     /// 创建新的 TokenInfo
[INFO] [stdout] 17 |     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:110:12
[INFO] [stdout]     |
[INFO] [stdout]  34 | impl TokenManager {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub fn cd_duration(&self) -> Duration {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn next_available_time(&self) -> Option<Duration> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 120 |     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:46:14
[INFO] [stdout]    |
[INFO] [stdout] 46 | 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:26:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct TokenMetricsData {
[INFO] [stdout]    |            ---------------- field in this struct
[INFO] [stdout] 25 |     /// 关联的 UID
[INFO] [stdout] 26 |     pub uid: u32,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused implementer of `Future` that must be used
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:260:9
[INFO] [stdout]     |
[INFO] [stdout] 260 |         board.update_pixel(10, 20, test_color, PixelSource::Own);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused implementer of `Future` that must be used
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:277:9
[INFO] [stdout]     |
[INFO] [stdout] 277 |         local.update_pixel(0, 0, Rgb::new(0, 0, 0), PixelSource::Own);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused implementer of `Future` that must be used
[INFO] [stdout]    --> src/app/board_sync/local_board.rs:279:9
[INFO] [stdout]     |
[INFO] [stdout] 279 |         local.update_from_board(&server_board);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: futures do nothing unless you `.await` or poll them
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 14s
[INFO] running `Command { std: "docker" "inspect" "a7de9c9b9d724151dac0740edef8d1b92197a6cbc90d28163aa1d04f1125c8eb", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a7de9c9b9d724151dac0740edef8d1b92197a6cbc90d28163aa1d04f1125c8eb", kill_on_drop: false }`
[INFO] [stdout] a7de9c9b9d724151dac0740edef8d1b92197a6cbc90d28163aa1d04f1125c8eb
