[INFO] cloning repository https://github.com/Brownymister/led-cat-server [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Brownymister/led-cat-server" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBrownymister%2Fled-cat-server", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBrownymister%2Fled-cat-server'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 8c581003e996fc50bc615b9cca98892e09ac4686 [INFO] checking Brownymister/led-cat-server against master#068609ce766e55d2e7371cd2a86143a6d7e8e2e4 for pr-138952 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBrownymister%2Fled-cat-server" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/Brownymister/led-cat-server on toolchain 068609ce766e55d2e7371cd2a86143a6d7e8e2e4 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+068609ce766e55d2e7371cd2a86143a6d7e8e2e4" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/Brownymister/led-cat-server [INFO] finished tweaking git repo https://github.com/Brownymister/led-cat-server [INFO] tweaked toml for git repo https://github.com/Brownymister/led-cat-server written to /workspace/builds/worker-7-tc1/source/Cargo.toml [INFO] crate git repo https://github.com/Brownymister/led-cat-server 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" "+068609ce766e55d2e7371cd2a86143a6d7e8e2e4" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded uuid-macro-internal v1.7.0 [INFO] [stderr] Downloaded argh_shared v0.1.12 [INFO] [stderr] Downloaded server_fn_macro_default v0.6.15 [INFO] [stderr] Downloaded parse-size v1.0.0 [INFO] [stderr] Downloaded ciborium-io v0.2.2 [INFO] [stderr] Downloaded quote-use-macros v0.8.4 [INFO] [stderr] Downloaded serde_plain v1.0.2 [INFO] [stderr] Downloaded object-chain v0.1.3 [INFO] [stderr] Downloaded leptos_config v0.6.15 [INFO] [stderr] Downloaded v_htmlescape v0.15.8 [INFO] [stderr] Downloaded actix-multipart-derive v0.6.1 [INFO] [stderr] Downloaded actix-cors v0.7.0 [INFO] [stderr] Downloaded actix-files v0.6.6 [INFO] [stderr] Downloaded darling_core v0.20.5 [INFO] [stderr] Downloaded darling_macro v0.20.5 [INFO] [stderr] Downloaded embedded-text v0.7.2 [INFO] [stderr] Downloaded micromath v2.1.0 [INFO] [stderr] Downloaded tinytga v0.5.0 [INFO] [stderr] Downloaded png v0.17.11 [INFO] [stderr] Downloaded config v0.14.0 [INFO] [stderr] Downloaded serde_yaml v0.9.32 [INFO] [stderr] Downloaded leptos_dom v0.6.15 [INFO] [stderr] Downloaded prettyplease v0.2.17 [INFO] [stderr] Downloaded leptos_macro v0.6.15 [INFO] [stderr] Downloaded leptos_reactive v0.6.15 [INFO] [stderr] Downloaded const_format v0.2.33 [INFO] [stderr] Downloaded unsafe-libyaml v0.2.10 [INFO] [stderr] Downloaded indexmap v2.2.1 [INFO] [stderr] Downloaded quote-use v0.8.4 [INFO] [stderr] Downloaded rpi-led-panel v0.5.1 [INFO] [stderr] Downloaded darling v0.20.5 [INFO] [stderr] Downloaded actix-multipart v0.6.1 [INFO] [stderr] Downloaded proc-macro-utils v0.10.0 [INFO] [stderr] Downloaded manyhow v0.10.4 [INFO] [stderr] Downloaded attribute-derive v0.9.2 [INFO] [stderr] Downloaded ciborium v0.2.2 [INFO] [stderr] Downloaded server_fn v0.6.15 [INFO] [stderr] Downloaded leptos v0.6.15 [INFO] [stderr] Downloaded argh v0.1.12 [INFO] [stderr] Downloaded thread-priority v0.15.1 [INFO] [stderr] Downloaded attribute-derive-macro v0.9.2 [INFO] [stderr] Downloaded leptos_hot_reload v0.6.15 [INFO] [stderr] Downloaded leptos_server v0.6.15 [INFO] [stderr] Downloaded ciborium-ll v0.2.2 [INFO] [stderr] Downloaded const_format_proc_macros v0.2.33 [INFO] [stderr] Downloaded server_fn_macro v0.6.15 [INFO] [stderr] Downloaded inventory v0.3.15 [INFO] [stderr] Downloaded typed-builder v0.18.2 [INFO] [stderr] Downloaded typed-builder-macro v0.18.2 [INFO] [stderr] Downloaded argh_derive v0.1.12 [INFO] [stderr] Downloaded hermit-abi v0.3.4 [INFO] [stderr] Downloaded manyhow-macros v0.10.4 [INFO] [stderr] Downloaded oco_ref v0.1.1 [INFO] [stderr] Downloaded embedded-graphics v0.8.1 [INFO] [stderr] Downloaded openssl-src v300.2.1+3.2.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4b26683ee3c49f365255c425c23003cbf4366de097804722c29c5bbbee3624d2" "/opt/rustwide/cargo-home/bin/cargo" "+068609ce766e55d2e7371cd2a86143a6d7e8e2e4" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] e27a45beb431eea5d68e0cbadf03421db433c43179eb250929f0e4491e26709b [INFO] running `Command { std: "docker" "start" "-a" "e27a45beb431eea5d68e0cbadf03421db433c43179eb250929f0e4491e26709b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "e27a45beb431eea5d68e0cbadf03421db433c43179eb250929f0e4491e26709b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e27a45beb431eea5d68e0cbadf03421db433c43179eb250929f0e4491e26709b", kill_on_drop: false }` [INFO] [stdout] e27a45beb431eea5d68e0cbadf03421db433c43179eb250929f0e4491e26709b [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4b26683ee3c49f365255c425c23003cbf4366de097804722c29c5bbbee3624d2" "/opt/rustwide/cargo-home/bin/cargo" "+068609ce766e55d2e7371cd2a86143a6d7e8e2e4" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] f7408661307ccd4399394116a0b94a5ebce14cb4fb5aa46eb536edf4950b6c49 [INFO] running `Command { std: "docker" "start" "-a" "f7408661307ccd4399394116a0b94a5ebce14cb4fb5aa46eb536edf4950b6c49", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.78 [INFO] [stderr] Compiling serde v1.0.196 [INFO] [stderr] Compiling parking_lot_core v0.9.9 [INFO] [stderr] Compiling once_cell v1.19.0 [INFO] [stderr] Checking smallvec v1.13.1 [INFO] [stderr] Compiling lock_api v0.4.11 [INFO] [stderr] Checking bytes v1.5.0 [INFO] [stderr] Compiling log v0.4.20 [INFO] [stderr] Checking hashbrown v0.14.3 [INFO] [stderr] Compiling pkg-config v0.3.29 [INFO] [stderr] Compiling libc v0.2.152 [INFO] [stderr] Compiling wasm-bindgen-shared v0.2.93 [INFO] [stderr] Compiling bumpalo v3.14.0 [INFO] [stderr] Compiling thiserror v1.0.57 [INFO] [stderr] Checking ryu v1.0.16 [INFO] [stderr] Checking signal-hook-registry v1.4.1 [INFO] [stderr] Checking socket2 v0.5.5 [INFO] [stderr] Checking num_cpus v1.16.0 [INFO] [stderr] Compiling serde_json v1.0.113 [INFO] [stderr] Compiling wasm-bindgen v0.2.93 [INFO] [stderr] Checking simd-adler32 v0.3.7 [INFO] [stderr] Compiling num-traits v0.2.17 [INFO] [stderr] Checking bitflags v2.4.2 [INFO] [stderr] Checking unicode-normalization v0.1.22 [INFO] [stderr] Checking getrandom v0.2.12 [INFO] [stderr] Compiling crc32fast v1.3.2 [INFO] [stderr] Compiling crossbeam-utils v0.8.19 [INFO] [stderr] Checking parking_lot v0.12.1 [INFO] [stderr] Compiling tracing-core v0.1.32 [INFO] [stderr] Compiling pin-project-lite v0.2.13 [INFO] [stderr] Checking miniz_oxide v0.7.1 [INFO] [stderr] Checking aho-corasick v1.1.2 [INFO] [stderr] Checking regex-syntax v0.8.2 [INFO] [stderr] Checking rand_core v0.6.4 [INFO] [stderr] Checking rand_chacha v0.3.1 [INFO] [stderr] Checking http v0.2.11 [INFO] [stderr] Compiling proc-macro-error v1.0.4 [INFO] [stderr] Checking half v2.3.1 [INFO] [stderr] Compiling jobserver v0.1.27 [INFO] [stderr] Checking either v1.9.0 [INFO] [stderr] Compiling anyhow v1.0.80 [INFO] [stderr] Checking indexmap v2.2.1 [INFO] [stderr] Checking idna v0.5.0 [INFO] [stderr] Compiling zstd-safe v7.0.0 [INFO] [stderr] Compiling quote v1.0.35 [INFO] [stderr] Compiling cc v1.0.83 [INFO] [stderr] Checking crossbeam-epoch v0.9.18 [INFO] [stderr] Compiling unicode-segmentation v1.12.0 [INFO] [stderr] Checking flate2 v1.0.28 [INFO] [stderr] Compiling rayon-core v1.12.1 [INFO] [stderr] Checking rand v0.8.5 [INFO] [stderr] Checking crossbeam-deque v0.8.5 [INFO] [stderr] Compiling syn v2.0.48 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling proc-macro-utils v0.8.0 [INFO] [stderr] Compiling const_format_proc_macros v0.2.33 [INFO] [stderr] Compiling proc-macro-error-attr v1.0.4 [INFO] [stderr] Checking url v2.5.0 [INFO] [stderr] Compiling proc-macro-utils v0.10.0 [INFO] [stderr] Compiling convert_case v0.6.0 [INFO] [stderr] Compiling ahash v0.8.7 [INFO] [stderr] Compiling proc-macro2-diagnostics v0.10.1 [INFO] [stderr] Compiling xxhash-rust v0.8.12 [INFO] [stderr] Compiling time-core v0.1.2 [INFO] [stderr] Compiling itoa v1.0.10 [INFO] [stderr] Compiling openssl-src v300.2.1+3.2.0 [INFO] [stderr] Checking deranged v0.3.11 [INFO] [stderr] Compiling time-macros v0.2.18 [INFO] [stderr] Compiling manyhow-macros v0.10.4 [INFO] [stderr] Compiling bytestring v1.3.1 [INFO] [stderr] Checking brotli-decompressor v2.5.1 [INFO] [stderr] Checking actix-utils v3.0.1 [INFO] [stderr] Checking actix-service v2.0.2 [INFO] [stderr] Compiling slotmap v1.0.7 [INFO] [stderr] Compiling zstd-sys v2.0.9+zstd.1.5.5 [INFO] [stderr] Compiling openssl-sys v0.9.101 [INFO] [stderr] Compiling const_format v0.2.33 [INFO] [stderr] Compiling cookie v0.16.2 [INFO] [stderr] Compiling convert_case v0.4.0 [INFO] [stderr] Compiling scopeguard v1.2.0 [INFO] [stderr] Compiling camino v1.1.9 [INFO] [stderr] Checking ciborium-io v0.2.2 [INFO] [stderr] Compiling yansi v1.0.1 [INFO] [stderr] Compiling openssl v0.10.64 [INFO] [stderr] Checking ciborium-ll v0.2.2 [INFO] [stderr] Checking local-channel v0.1.5 [INFO] [stderr] Checking http v1.1.0 [INFO] [stderr] Compiling prettyplease v0.2.17 [INFO] [stderr] Compiling collection_literals v1.0.1 [INFO] [stderr] Checking minimal-lexical v0.2.1 [INFO] [stderr] Checking winnow v0.6.18 [INFO] [stderr] Compiling native-tls v0.2.11 [INFO] [stderr] Compiling interpolator v0.5.0 [INFO] [stderr] Checking nom v7.1.3 [INFO] [stderr] Checking regex-automata v0.4.5 [INFO] [stderr] Checking embedded-graphics-core v0.4.0 [INFO] [stderr] Checking brotli v3.4.0 [INFO] [stderr] Checking time v0.3.36 [INFO] [stderr] Checking rayon v1.8.1 [INFO] [stderr] Checking float-cmp v0.9.0 [INFO] [stderr] Compiling proc-macro-error-attr2 v2.0.0 [INFO] [stderr] Checking dashmap v5.5.3 [INFO] [stderr] Checking send_wrapper v0.6.0 [INFO] [stderr] Compiling utf8-width v0.1.7 [INFO] [stderr] Checking rustc-hash v1.1.0 [INFO] [stderr] Checking micromath v2.1.0 [INFO] [stderr] Compiling rustix v0.38.31 [INFO] [stderr] Checking self_cell v1.0.4 [INFO] [stderr] Compiling html-escape v0.2.13 [INFO] [stderr] Checking embedded-graphics v0.8.1 [INFO] [stderr] Compiling itertools v0.12.1 [INFO] [stderr] Compiling proc-macro-error2 v2.0.1 [INFO] [stderr] Compiling uuid v1.7.0 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Checking http-body v0.4.6 [INFO] [stderr] Checking spin v0.9.8 [INFO] [stderr] Checking pathdiff v0.2.1 [INFO] [stderr] Checking weezl v0.1.8 [INFO] [stderr] Compiling v_htmlescape v0.15.8 [INFO] [stderr] Checking linux-raw-sys v0.4.13 [INFO] [stderr] Checking flume v0.11.0 [INFO] [stderr] Checking ordered-float v2.10.1 [INFO] [stderr] Checking fdeflate v0.3.4 [INFO] [stderr] Checking zune-inflate v0.2.54 [INFO] [stderr] Compiling derive_more v0.99.17 [INFO] [stderr] Checking drain_filter_polyfill v0.1.3 [INFO] [stderr] Compiling parse-size v1.0.0 [INFO] [stderr] Checking fastrand v2.0.1 [INFO] [stderr] Checking pad-adapter v0.1.1 [INFO] [stderr] Checking inventory v0.3.15 [INFO] [stderr] Checking lebe v0.5.2 [INFO] [stderr] Checking bytemuck v1.14.3 [INFO] [stderr] Checking bit_field v0.10.2 [INFO] [stderr] Checking color_quant v1.1.0 [INFO] [stderr] Checking unsafe-libyaml v0.2.10 [INFO] [stderr] Checking iana-time-zone v0.1.60 [INFO] [stderr] Checking gif v0.12.0 [INFO] [stderr] Checking regex v1.10.3 [INFO] [stderr] Checking chrono v0.4.38 [INFO] [stderr] Checking qoi v0.4.1 [INFO] [stderr] Checking exr v1.72.0 [INFO] [stderr] Checking png v0.17.11 [INFO] [stderr] Compiling derivative v2.2.0 [INFO] [stderr] Checking thread-id v4.2.1 [INFO] [stderr] Checking memmap2 v0.9.4 [INFO] [stderr] Checking http-range v0.1.5 [INFO] [stderr] Checking jpeg-decoder v0.3.1 [INFO] [stderr] Checking object-chain v0.1.3 [INFO] [stderr] Checking arc-swap v1.6.0 [INFO] [stderr] Checking sysinfo v0.30.5 [INFO] [stderr] Checking tempfile v3.10.0 [INFO] [stderr] Checking embedded-text v0.7.2 [INFO] [stderr] Compiling wasm-bindgen-backend v0.2.93 [INFO] [stderr] Compiling server_fn_macro v0.6.15 [INFO] [stderr] Compiling manyhow v0.10.4 [INFO] [stderr] Compiling darling_core v0.20.5 [INFO] [stderr] Checking tinytga v0.5.0 [INFO] [stderr] Checking dotenv v0.15.0 [INFO] [stderr] Checking tiff v0.9.1 [INFO] [stderr] Compiling serde_derive v1.0.196 [INFO] [stderr] Compiling tracing-attributes v0.1.27 [INFO] [stderr] Compiling futures-macro v0.3.30 [INFO] [stderr] Compiling thiserror-impl v1.0.57 [INFO] [stderr] Compiling tokio-macros v2.3.0 [INFO] [stderr] Compiling pin-project-internal v1.1.5 [INFO] [stderr] Compiling quote-use-macros v0.8.4 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling wasm-bindgen-macro-support v0.2.93 [INFO] [stderr] Compiling syn_derive v0.1.8 [INFO] [stderr] Compiling quote-use v0.8.4 [INFO] [stderr] Compiling server_fn_macro_default v0.6.15 [INFO] [stderr] Compiling attribute-derive-macro v0.9.2 [INFO] [stderr] Compiling derive-where v1.2.7 [INFO] [stderr] Compiling actix-macros v0.2.4 [INFO] [stderr] Checking futures-util v0.3.30 [INFO] [stderr] Compiling typed-builder-macro v0.18.2 [INFO] [stderr] Compiling async-recursion v1.1.1 [INFO] [stderr] Compiling uuid-macro-internal v1.7.0 [INFO] [stderr] Checking image v0.24.8 [INFO] [stderr] Checking pin-project v1.1.5 [INFO] [stderr] Compiling tracing v0.1.40 [INFO] [stderr] Compiling rstml v0.11.2 [INFO] [stderr] Compiling wasm-bindgen-macro v0.2.93 [INFO] [stderr] Compiling darling_macro v0.20.5 [INFO] [stderr] Compiling attribute-derive v0.9.2 [INFO] [stderr] Checking typed-builder v0.18.2 [INFO] [stderr] Compiling darling v0.20.5 [INFO] [stderr] Compiling actix-multipart-derive v0.6.1 [INFO] [stderr] Checking js-sys v0.3.70 [INFO] [stderr] Checking zstd v0.13.0 [INFO] [stderr] Checking futures-executor v0.3.30 [INFO] [stderr] Checking futures v0.3.30 [INFO] [stderr] Checking toml_datetime v0.6.8 [INFO] [stderr] Checking serde_spanned v0.6.7 [INFO] [stderr] Checking serde_urlencoded v0.7.1 [INFO] [stderr] Checking serde_qs v0.12.0 [INFO] [stderr] Checking ciborium v0.2.2 [INFO] [stderr] Checking oco_ref v0.1.1 [INFO] [stderr] Checking argh_shared v0.1.12 [INFO] [stderr] Checking serde-value v0.7.0 [INFO] [stderr] Checking serde_yaml v0.9.32 [INFO] [stderr] Checking serde_plain v1.0.2 [INFO] [stderr] Compiling actix-router v0.5.2 [INFO] [stderr] Compiling leptos_hot_reload v0.6.15 [INFO] [stderr] Checking toml_edit v0.22.20 [INFO] [stderr] Checking mio v0.8.10 [INFO] [stderr] Checking thread-priority v0.15.1 [INFO] [stderr] Compiling argh_derive v0.1.12 [INFO] [stderr] Checking tokio v1.38.0 [INFO] [stderr] Checking web-sys v0.3.70 [INFO] [stderr] Checking wasm-bindgen-futures v0.4.41 [INFO] [stderr] Checking serde-wasm-bindgen v0.6.5 [INFO] [stderr] Compiling actix-web-codegen v4.2.2 [INFO] [stderr] Compiling leptos_macro v0.6.15 [INFO] [stderr] Checking argh v0.1.12 [INFO] [stderr] Checking log4rs v1.3.0 [INFO] [stderr] Checking rpi-led-panel v0.5.1 [INFO] [stderr] Checking toml v0.8.19 [INFO] [stderr] Checking config v0.14.0 [INFO] [stderr] Checking leptos_config v0.6.15 [INFO] [stderr] Checking tokio-util v0.7.10 [INFO] [stderr] Checking actix-rt v2.9.0 [INFO] [stderr] Checking actix-server v2.3.0 [INFO] [stderr] Checking h2 v0.3.24 [INFO] [stderr] Checking actix-codec v0.5.1 [INFO] [stderr] Checking actix-http v3.5.1 [INFO] [stderr] Checking hyper v0.14.28 [INFO] [stderr] Checking actix-web v4.4.1 [INFO] [stderr] Checking gloo-utils v0.2.0 [INFO] [stderr] Checking wasm-streams v0.4.0 [INFO] [stderr] Checking leptos_reactive v0.6.15 [INFO] [stderr] Checking gloo-net v0.6.0 [INFO] [stderr] Checking server_fn v0.6.15 [INFO] [stderr] Checking leptos_server v0.6.15 [INFO] [stderr] Checking leptos_dom v0.6.15 [INFO] [stderr] Checking actix-files v0.6.6 [INFO] [stderr] Checking actix-multipart v0.6.1 [INFO] [stderr] Checking actix-cors v0.7.0 [INFO] [stderr] Checking leptos v0.6.15 [INFO] [stderr] Checking tokio-native-tls v0.3.1 [INFO] [stderr] Checking hyper-tls v0.5.0 [INFO] [stderr] Checking reqwest v0.11.24 [INFO] [stderr] Checking led-cat-server v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `actix_web::dev::ServiceResponse` [INFO] [stdout] --> src/main.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use actix_web::dev::ServiceResponse; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `HttpResponse`, `http`, and `middleware` [INFO] [stdout] --> src/main.rs:4:17 [INFO] [stdout] | [INFO] [stdout] 4 | use actix_web::{http, middleware, HttpResponse}; [INFO] [stdout] | ^^^^ ^^^^^^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `futures_util::future::ok` [INFO] [stdout] --> src/main.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use futures_util::future::ok; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `dev::Service as _` [INFO] [stdout] --> src/main.rs:9:17 [INFO] [stdout] | [INFO] [stdout] 9 | use actix_web::{dev::Service as _,web, App, HttpServer}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `FutureExt` [INFO] [stdout] --> src/main.rs:11:14 [INFO] [stdout] | [INFO] [stdout] 11 | use future::{FutureExt, Future}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `RGBMatrixConfig` and `RGBMatrix` [INFO] [stdout] --> src/main.rs:14:46 [INFO] [stdout] | [INFO] [stdout] 14 | use rpi_led_panel::{Canvas, HardwareMapping, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `self` [INFO] [stdout] --> src/main.rs:16:17 [INFO] [stdout] | [INFO] [stdout] 16 | use std::time::{self, Duration, SystemTime}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `dotenv::dotenv` [INFO] [stdout] --> src/main.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | use dotenv::dotenv; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `actix_web::dev::ServiceRequest` [INFO] [stdout] --> src/http_endpoints.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use actix_web::dev::ServiceRequest; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `leptos::leptos_dom::logging` [INFO] [stdout] --> src/http_endpoints.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use leptos::leptos_dom::logging; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::default` [INFO] [stdout] --> src/http_endpoints.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::default; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::path::PathBuf` [INFO] [stdout] --> src/http_endpoints.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::path::PathBuf; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `File` and `OpenOptions` [INFO] [stdout] --> src/http_endpoints.rs:21:15 [INFO] [stdout] | [INFO] [stdout] 21 | use std::fs::{File,OpenOptions}; [INFO] [stdout] | ^^^^ ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `get_pollen_data` [INFO] [stdout] --> src/http_endpoints.rs:27:70 [INFO] [stdout] | [INFO] [stdout] 27 | use crate::api::api::{get_autobahn_info, get_bvg_info, get_osm_info, get_pollen_data, get_weather_info}; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::api::dwd::DwdPollen` [INFO] [stdout] --> src/http_endpoints.rs:28:5 [INFO] [stdout] | [INFO] [stdout] 28 | use crate::api::dwd::DwdPollen; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `led` [INFO] [stdout] --> src/http_endpoints.rs:29:24 [INFO] [stdout] | [INFO] [stdout] 29 | use crate::{fireplace, led, LedFuncData}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `autobahn` [INFO] [stdout] --> src/http_endpoints.rs:30:18 [INFO] [stdout] | [INFO] [stdout] 30 | use crate::api::{autobahn, bvg::*}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::api::autobahn::*` [INFO] [stdout] --> src/http_endpoints.rs:31:5 [INFO] [stdout] | [INFO] [stdout] 31 | use crate::api::autobahn::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/led/clock.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Local}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `FONT_10X20`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `Line`, `PrimitiveStyleBuilder`, and `Rectangle` [INFO] [stdout] --> src/led/clock.rs:4:22 [INFO] [stdout] | [INFO] [stdout] 4 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 9 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Alignment`, `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `ImageRaw`, `Line`, `MonoTextStyle`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, `Rectangle`, `Rgb565`, and `Text` [INFO] [stdout] --> src/led/image.rs:3:22 [INFO] [stdout] | [INFO] [stdout] 3 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] 4 | MonoTextStyle, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 5 | }, [INFO] [stdout] 6 | pixelcolor::{Rgb888, Rgb565}, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 7 | prelude::*, [INFO] [stdout] 8 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] 9 | text::{Alignment, Text}, [INFO] [stdout] | ^^^^^^^^^ ^^^^ [INFO] [stdout] 10 | Drawable, [INFO] [stdout] 11 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GenericImageView` and `RgbImage` [INFO] [stdout] --> src/led/image.rs:13:27 [INFO] [stdout] | [INFO] [stdout] 13 | use image::{DynamicImage, GenericImageView, RgbImage}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Canvas` [INFO] [stdout] --> src/led/image.rs:14:21 [INFO] [stdout] | [INFO] [stdout] 14 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `Line`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, and `Rectangle` [INFO] [stdout] --> src/led/run_text.rs:3:34 [INFO] [stdout] | [INFO] [stdout] 3 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 8 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/run_text.rs:12:29 [INFO] [stdout] | [INFO] [stdout] 12 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::api::weatherkit` [INFO] [stdout] --> src/led/led.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::api::weatherkit; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `actix_web::dev::ServiceResponse` [INFO] [stdout] --> src/main.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use actix_web::dev::ServiceResponse; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `HttpResponse`, `http`, and `middleware` [INFO] [stdout] --> src/main.rs:4:17 [INFO] [stdout] | [INFO] [stdout] 4 | use actix_web::{http, middleware, HttpResponse}; [INFO] [stdout] | ^^^^ ^^^^^^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `ImageRawBE`, `ImageRaw`, `Image`, `PrimitiveStyleBuilder`, `Rectangle`, and `Rgb565` [INFO] [stdout] --> src/led/led.rs:4:13 [INFO] [stdout] | [INFO] [stdout] 4 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^ ^^^^^^^^ ^^^^^^^^^^ [INFO] [stdout] 5 | mono_font::{ [INFO] [stdout] 6 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 9 | pixelcolor::{Rgb565, Rgb888}, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 10 | prelude::*, [INFO] [stdout] 11 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `futures_util::future::ok` [INFO] [stdout] --> src/main.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use futures_util::future::ok; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DynamicImage`, `GenericImageView`, and `RgbImage` [INFO] [stdout] --> src/led/led.rs:15:13 [INFO] [stdout] | [INFO] [stdout] 15 | use image::{DynamicImage, GenericImageView, RgbImage}; [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `dev::Service as _` [INFO] [stdout] --> src/main.rs:9:17 [INFO] [stdout] | [INFO] [stdout] 9 | use actix_web::{dev::Service as _,web, App, HttpServer}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/led/led.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs` [INFO] [stdout] --> src/led/led.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | use std::fs; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `FutureExt` [INFO] [stdout] --> src/main.rs:11:14 [INFO] [stdout] | [INFO] [stdout] 11 | use future::{FutureExt, Future}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/led/led.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `RGBMatrixConfig` and `RGBMatrix` [INFO] [stdout] --> src/main.rs:14:46 [INFO] [stdout] | [INFO] [stdout] 14 | use rpi_led_panel::{Canvas, HardwareMapping, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tinytga::Tga` [INFO] [stdout] --> src/led/led.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | use tinytga::Tga; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `self` [INFO] [stdout] --> src/main.rs:16:17 [INFO] [stdout] | [INFO] [stdout] 16 | use std::time::{self, Duration, SystemTime}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `dotenv::dotenv` [INFO] [stdout] --> src/main.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | use dotenv::dotenv; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `Line`, and `PrimitiveStyle` [INFO] [stdout] --> src/led/bvg.rs:5:22 [INFO] [stdout] | [INFO] [stdout] 5 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 10 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `actix_web::dev::ServiceRequest` [INFO] [stdout] --> src/http_endpoints.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use actix_web::dev::ServiceRequest; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `leptos::leptos_dom::logging` [INFO] [stdout] --> src/http_endpoints.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use leptos::leptos_dom::logging; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `RGBMatrixConfig` and `RGBMatrix` [INFO] [stdout] --> src/led/bvg.rs:14:29 [INFO] [stdout] | [INFO] [stdout] 14 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::default` [INFO] [stdout] --> src/http_endpoints.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::default; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::path::PathBuf` [INFO] [stdout] --> src/http_endpoints.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::path::PathBuf; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Local` [INFO] [stdout] --> src/led/weather.rs:2:24 [INFO] [stdout] | [INFO] [stdout] 2 | use chrono::{DateTime, Local}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `File` and `OpenOptions` [INFO] [stdout] --> src/http_endpoints.rs:21:15 [INFO] [stdout] | [INFO] [stdout] 21 | use std::fs::{File,OpenOptions}; [INFO] [stdout] | ^^^^ ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `get_pollen_data` [INFO] [stdout] --> src/http_endpoints.rs:27:70 [INFO] [stdout] | [INFO] [stdout] 27 | use crate::api::api::{get_autobahn_info, get_bvg_info, get_osm_info, get_pollen_data, get_weather_info}; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `ImageRaw`, `Line`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, and `Rectangle` [INFO] [stdout] --> src/led/weather.rs:4:20 [INFO] [stdout] | [INFO] [stdout] 4 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 5 | mono_font::{ [INFO] [stdout] 6 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 11 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::api::dwd::DwdPollen` [INFO] [stdout] --> src/http_endpoints.rs:28:5 [INFO] [stdout] | [INFO] [stdout] 28 | use crate::api::dwd::DwdPollen; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `led` [INFO] [stdout] --> src/http_endpoints.rs:29:24 [INFO] [stdout] | [INFO] [stdout] 29 | use crate::{fireplace, led, LedFuncData}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GenericImageView` and `RgbImage` [INFO] [stdout] --> src/led/weather.rs:15:27 [INFO] [stdout] | [INFO] [stdout] 15 | use image::{DynamicImage, GenericImageView, RgbImage}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/weather.rs:16:29 [INFO] [stdout] | [INFO] [stdout] 16 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `autobahn` [INFO] [stdout] --> src/http_endpoints.rs:30:18 [INFO] [stdout] | [INFO] [stdout] 30 | use crate::api::{autobahn, bvg::*}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::api::autobahn::*` [INFO] [stdout] --> src/http_endpoints.rs:31:5 [INFO] [stdout] | [INFO] [stdout] 31 | use crate::api::autobahn::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs` [INFO] [stdout] --> src/led/weather.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | use std::fs; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/led/weather.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `api::weatherkit` [INFO] [stdout] --> src/led/dashboard.rs:1:13 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::{api::weatherkit, http_endpoints::DashboardWidgets}; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `actix_web::HttpResponse` [INFO] [stdout] --> src/led/dashboard.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use actix_web::HttpResponse; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/led/dashboard.rs:3:14 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, Local}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_5X8`, `FONT_9X15`, `ImageRawBE`, `ImageRaw`, `Image`, `Line`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, and `Rectangle` [INFO] [stdout] --> src/led/dashboard.rs:5:13 [INFO] [stdout] | [INFO] [stdout] 5 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^ ^^^^^^^^ ^^^^^^^^^^ [INFO] [stdout] 6 | mono_font::{ [INFO] [stdout] 7 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_7X13, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 12 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DynamicImage`, `GenericImageView`, and `RgbImage` [INFO] [stdout] --> src/led/dashboard.rs:16:13 [INFO] [stdout] | [INFO] [stdout] 16 | use image::{DynamicImage, GenericImageView, RgbImage}; [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::Rng` [INFO] [stdout] --> src/led/dashboard.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | use rand::Rng; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/dashboard.rs:18:29 [INFO] [stdout] | [INFO] [stdout] 18 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/led/dashboard.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs` [INFO] [stdout] --> src/led/dashboard.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | use std::fs; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/led/clock.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Local}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/led/dashboard.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::api::football::FootballRes` [INFO] [stdout] --> src/led/football.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::api::football::FootballRes; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `football` and `weatherkit` [INFO] [stdout] --> src/led/football.rs:2:18 [INFO] [stdout] | [INFO] [stdout] 2 | use crate::api::{football, weatherkit}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime` and `Local` [INFO] [stdout] --> src/led/football.rs:3:14 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, Local}; [INFO] [stdout] | ^^^^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `FONT_10X20`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `Line`, `PrimitiveStyleBuilder`, and `Rectangle` [INFO] [stdout] --> src/led/clock.rs:4:22 [INFO] [stdout] | [INFO] [stdout] 4 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 9 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `ImageRawBE`, `ImageRaw`, `Image`, `Line`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, and `Rectangle` [INFO] [stdout] --> src/led/football.rs:5:13 [INFO] [stdout] | [INFO] [stdout] 5 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^ ^^^^^^^^ ^^^^^^^^^^ [INFO] [stdout] 6 | mono_font::{ [INFO] [stdout] 7 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 12 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DynamicImage`, `GenericImageView`, and `RgbImage` [INFO] [stdout] --> src/led/football.rs:16:13 [INFO] [stdout] | [INFO] [stdout] 16 | use image::{DynamicImage, GenericImageView, RgbImage}; [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Alignment`, `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `ImageRaw`, `Line`, `MonoTextStyle`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, `Rectangle`, `Rgb565`, and `Text` [INFO] [stdout] --> src/led/image.rs:3:22 [INFO] [stdout] | [INFO] [stdout] 3 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] 4 | MonoTextStyle, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 5 | }, [INFO] [stdout] 6 | pixelcolor::{Rgb888, Rgb565}, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 7 | prelude::*, [INFO] [stdout] 8 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] 9 | text::{Alignment, Text}, [INFO] [stdout] | ^^^^^^^^^ ^^^^ [INFO] [stdout] 10 | Drawable, [INFO] [stdout] 11 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/football.rs:17:29 [INFO] [stdout] | [INFO] [stdout] 17 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GenericImageView` and `RgbImage` [INFO] [stdout] --> src/led/image.rs:13:27 [INFO] [stdout] | [INFO] [stdout] 13 | use image::{DynamicImage, GenericImageView, RgbImage}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/led/football.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs` [INFO] [stdout] --> src/led/football.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | use std::fs; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Canvas` [INFO] [stdout] --> src/led/image.rs:14:21 [INFO] [stdout] | [INFO] [stdout] 14 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/led/football.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `Line`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, and `Rectangle` [INFO] [stdout] --> src/led/run_text.rs:3:34 [INFO] [stdout] | [INFO] [stdout] 3 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 8 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Alignment`, `BinaryColor`, `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `Line`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, and `Text` [INFO] [stdout] --> src/led/error.rs:3:22 [INFO] [stdout] | [INFO] [stdout] 3 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 6 | pixelcolor::{BinaryColor, Rgb888}, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 7 | prelude::*, [INFO] [stdout] 8 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 9 | text::{Alignment, Text}, [INFO] [stdout] | ^^^^^^^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/run_text.rs:12:29 [INFO] [stdout] | [INFO] [stdout] 12 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/error.rs:17:29 [INFO] [stdout] | [INFO] [stdout] 17 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::api::weatherkit` [INFO] [stdout] --> src/led/led.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::api::weatherkit; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime` and `Local` [INFO] [stdout] --> src/led/start_screen.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Local}; [INFO] [stdout] | ^^^^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `FONT_10X20`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `Line`, `PrimitiveStyleBuilder`, and `Rectangle` [INFO] [stdout] --> src/led/start_screen.rs:4:22 [INFO] [stdout] | [INFO] [stdout] 4 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 9 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `ImageRawBE`, `ImageRaw`, `Image`, `PrimitiveStyleBuilder`, `Rectangle`, and `Rgb565` [INFO] [stdout] --> src/led/led.rs:4:13 [INFO] [stdout] | [INFO] [stdout] 4 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^ ^^^^^^^^ ^^^^^^^^^^ [INFO] [stdout] 5 | mono_font::{ [INFO] [stdout] 6 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 9 | pixelcolor::{Rgb565, Rgb888}, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 10 | prelude::*, [INFO] [stdout] 11 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Canvas` [INFO] [stdout] --> src/led/start_screen.rs:13:21 [INFO] [stdout] | [INFO] [stdout] 13 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `core::panic` [INFO] [stdout] --> src/led/pong.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use core::panic; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DynamicImage`, `GenericImageView`, and `RgbImage` [INFO] [stdout] --> src/led/led.rs:15:13 [INFO] [stdout] | [INFO] [stdout] 15 | use image::{DynamicImage, GenericImageView, RgbImage}; [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/led/led.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs` [INFO] [stdout] --> src/led/led.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | use std::fs; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_9X15`, `PrimitiveStyleBuilder`, and `Rectangle` [INFO] [stdout] --> src/led/pong.rs:5:22 [INFO] [stdout] | [INFO] [stdout] 5 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 10 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/led/led.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/pong.rs:14:29 [INFO] [stdout] | [INFO] [stdout] 14 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tinytga::Tga` [INFO] [stdout] --> src/led/led.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | use tinytga::Tga; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::pong::BallPos` [INFO] [stdout] --> src/led/pong.rs:16:5 [INFO] [stdout] | [INFO] [stdout] 16 | use crate::pong::BallPos; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `super::led` [INFO] [stdout] --> src/led/pong.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | use super::led; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::sync::Arc` [INFO] [stdout] --> src/cron.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::sync::Arc; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::time::SystemTime` [INFO] [stdout] --> src/cron.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::time::SystemTime; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `Line`, and `PrimitiveStyle` [INFO] [stdout] --> src/led/bvg.rs:5:22 [INFO] [stdout] | [INFO] [stdout] 5 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 10 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::Mutex` [INFO] [stdout] --> src/cron.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use tokio::sync::Mutex; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `uuid::Uuid` [INFO] [stdout] --> src/cron.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use uuid::Uuid; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `RGBMatrixConfig` and `RGBMatrix` [INFO] [stdout] --> src/led/bvg.rs:14:29 [INFO] [stdout] | [INFO] [stdout] 14 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Local` [INFO] [stdout] --> src/led/weather.rs:2:24 [INFO] [stdout] | [INFO] [stdout] 2 | use chrono::{DateTime, Local}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Alignment`, `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `ImageRawBE`, `ImageRaw`, `Image`, `MonoTextStyle`, `PrimitiveStyleBuilder`, `Rectangle`, `Rgb565`, `Text`, and `pixelcolor::BinaryColor` [INFO] [stdout] --> src/fireplace.rs:3:13 [INFO] [stdout] | [INFO] [stdout] 3 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^ ^^^^^^^^ ^^^^^^^^^^ [INFO] [stdout] 4 | mono_font::{ [INFO] [stdout] 5 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] 6 | MonoTextStyle, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 7 | }, [INFO] [stdout] 8 | pixelcolor::BinaryColor, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 9 | pixelcolor::{Rgb565, Rgb888}, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 10 | prelude::*, [INFO] [stdout] 11 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] 12 | text::{Alignment, Text}, [INFO] [stdout] | ^^^^^^^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `ImageRaw`, `Line`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, and `Rectangle` [INFO] [stdout] --> src/led/weather.rs:4:20 [INFO] [stdout] | [INFO] [stdout] 4 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 5 | mono_font::{ [INFO] [stdout] 6 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 11 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::seq::SliceRandom` [INFO] [stdout] --> src/fireplace.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use rand::seq::SliceRandom; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::f32::consts::PI` [INFO] [stdout] --> src/fireplace.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | use std::f32::consts::PI; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GenericImageView` and `RgbImage` [INFO] [stdout] --> src/led/weather.rs:15:27 [INFO] [stdout] | [INFO] [stdout] 15 | use image::{DynamicImage, GenericImageView, RgbImage}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/weather.rs:16:29 [INFO] [stdout] | [INFO] [stdout] 16 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Local`, `NaiveDate`, and `TimeZone` [INFO] [stdout] --> src/tokens.rs:1:34 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Duration, Local, NaiveDate, TimeZone, Utc}; [INFO] [stdout] | ^^^^^ ^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::json` [INFO] [stdout] --> src/tokens.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use serde_json::json; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs` [INFO] [stdout] --> src/led/weather.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | use std::fs; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `OpenOptions` [INFO] [stdout] --> src/tokens.rs:4:31 [INFO] [stdout] | [INFO] [stdout] 4 | use std::fs::{metadata, File, OpenOptions}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/led/weather.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `prelude::*` and `self` [INFO] [stdout] --> src/tokens.rs:5:15 [INFO] [stdout] | [INFO] [stdout] 5 | use std::io::{self, prelude::*, Read, Write}; [INFO] [stdout] | ^^^^ ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `api::weatherkit` [INFO] [stdout] --> src/led/dashboard.rs:1:13 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::{api::weatherkit, http_endpoints::DashboardWidgets}; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `actix_web::HttpResponse` [INFO] [stdout] --> src/led/dashboard.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use actix_web::HttpResponse; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/tokens.rs:116:9 [INFO] [stdout] | [INFO] [stdout] 116 | / /// check if given token is in the list of tokens [INFO] [stdout] 117 | | /// and if the expiration date is not passed [INFO] [stdout] | |____________________________________________________^ [INFO] [stdout] ... [INFO] [stdout] 127 | / if token.token == given_token.token.to_string() { [INFO] [stdout] 128 | | /// expirated token is only deleted when it is used !! [INFO] [stdout] 129 | | if date_is_passed(token.expiration_date.as_ref().unwrap()) { [INFO] [stdout] 130 | | log::info!("token expired"); [INFO] [stdout] ... | [INFO] [stdout] 139 | | } [INFO] [stdout] | |_________- rustdoc does not generate documentation for expressions [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] = note: `#[warn(unused_doc_comments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/led/dashboard.rs:3:14 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, Local}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/tokens.rs:128:13 [INFO] [stdout] | [INFO] [stdout] 128 | /// expirated token is only deleted when it is used !! [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 129 | / if date_is_passed(token.expiration_date.as_ref().unwrap()) { [INFO] [stdout] 130 | | log::info!("token expired"); [INFO] [stdout] 131 | | given_token.delete_token().expect("Failed to delete token"); [INFO] [stdout] 132 | | return Err(std::io::Error::new( [INFO] [stdout] ... | [INFO] [stdout] 135 | | )); [INFO] [stdout] 136 | | } [INFO] [stdout] | |_____________- rustdoc does not generate documentation for expressions [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/pong.rs:128:12 [INFO] [stdout] | [INFO] [stdout] 128 | if (self.ball_pos.x == self.player_x_pos [INFO] [stdout] | ^ [INFO] [stdout] ... [INFO] [stdout] 131 | || self.ball_pos.y == self.player_y_pos + 1)) [INFO] [stdout] | ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 128 ~ if self.ball_pos.x == self.player_x_pos [INFO] [stdout] 129 | && (self.ball_pos.y == self.player_y_pos [INFO] [stdout] 130 | || self.ball_pos.y == self.player_y_pos - 1 [INFO] [stdout] 131 ~ || self.ball_pos.y == self.player_y_pos + 1) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_5X8`, `FONT_9X15`, `ImageRawBE`, `ImageRaw`, `Image`, `Line`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, and `Rectangle` [INFO] [stdout] --> src/led/dashboard.rs:5:13 [INFO] [stdout] | [INFO] [stdout] 5 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^ ^^^^^^^^ ^^^^^^^^^^ [INFO] [stdout] 6 | mono_font::{ [INFO] [stdout] 7 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_7X13, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 12 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `App`, `HttpServer`, and `web` [INFO] [stdout] --> src/leptos.rs:1:17 [INFO] [stdout] | [INFO] [stdout] 1 | use actix_web::{web, App, HttpRequest, HttpServer, Result as AcResult}; [INFO] [stdout] | ^^^ ^^^ ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/api/api.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DynamicImage`, `GenericImageView`, and `RgbImage` [INFO] [stdout] --> src/led/dashboard.rs:16:13 [INFO] [stdout] | [INFO] [stdout] 16 | use image::{DynamicImage, GenericImageView, RgbImage}; [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/api/api.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::Rng` [INFO] [stdout] --> src/led/dashboard.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | use rand::Rng; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/dashboard.rs:18:29 [INFO] [stdout] | [INFO] [stdout] 18 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/led/dashboard.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs` [INFO] [stdout] --> src/led/dashboard.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | use std::fs; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/led/dashboard.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::api::football::FootballRes` [INFO] [stdout] --> src/led/football.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::api::football::FootballRes; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `football` and `weatherkit` [INFO] [stdout] --> src/led/football.rs:2:18 [INFO] [stdout] | [INFO] [stdout] 2 | use crate::api::{football, weatherkit}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime` and `Local` [INFO] [stdout] --> src/led/football.rs:3:14 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, Local}; [INFO] [stdout] | ^^^^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `ImageRawBE`, `ImageRaw`, `Image`, `Line`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, and `Rectangle` [INFO] [stdout] --> src/led/football.rs:5:13 [INFO] [stdout] | [INFO] [stdout] 5 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^ ^^^^^^^^ ^^^^^^^^^^ [INFO] [stdout] 6 | mono_font::{ [INFO] [stdout] 7 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 12 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DynamicImage`, `GenericImageView`, and `RgbImage` [INFO] [stdout] --> src/led/football.rs:16:13 [INFO] [stdout] | [INFO] [stdout] 16 | use image::{DynamicImage, GenericImageView, RgbImage}; [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/football.rs:17:29 [INFO] [stdout] | [INFO] [stdout] 17 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/led/football.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs` [INFO] [stdout] --> src/led/football.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | use std::fs; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/led/football.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Alignment`, `BinaryColor`, `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `Line`, `PrimitiveStyleBuilder`, `PrimitiveStyle`, and `Text` [INFO] [stdout] --> src/led/error.rs:3:22 [INFO] [stdout] | [INFO] [stdout] 3 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 6 | pixelcolor::{BinaryColor, Rgb888}, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 7 | prelude::*, [INFO] [stdout] 8 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 9 | text::{Alignment, Text}, [INFO] [stdout] | ^^^^^^^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/error.rs:17:29 [INFO] [stdout] | [INFO] [stdout] 17 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime` and `Local` [INFO] [stdout] --> src/led/start_screen.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Local}; [INFO] [stdout] | ^^^^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `FONT_10X20`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `Line`, `PrimitiveStyleBuilder`, and `Rectangle` [INFO] [stdout] --> src/led/start_screen.rs:4:22 [INFO] [stdout] | [INFO] [stdout] 4 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 9 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Canvas` [INFO] [stdout] --> src/led/start_screen.rs:13:21 [INFO] [stdout] | [INFO] [stdout] 13 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `core::panic` [INFO] [stdout] --> src/led/pong.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use core::panic; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_9X15`, `PrimitiveStyleBuilder`, and `Rectangle` [INFO] [stdout] --> src/led/pong.rs:5:22 [INFO] [stdout] | [INFO] [stdout] 5 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 10 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RGBMatrix` [INFO] [stdout] --> src/led/pong.rs:14:29 [INFO] [stdout] | [INFO] [stdout] 14 | use rpi_led_panel::{Canvas, RGBMatrix, RGBMatrixConfig}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::pong::BallPos` [INFO] [stdout] --> src/led/pong.rs:16:5 [INFO] [stdout] | [INFO] [stdout] 16 | use crate::pong::BallPos; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `super::led` [INFO] [stdout] --> src/led/pong.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | use super::led; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::sync::Arc` [INFO] [stdout] --> src/cron.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::sync::Arc; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::time::SystemTime` [INFO] [stdout] --> src/cron.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::time::SystemTime; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::Mutex` [INFO] [stdout] --> src/cron.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use tokio::sync::Mutex; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `uuid::Uuid` [INFO] [stdout] --> src/cron.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use uuid::Uuid; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Alignment`, `Circle`, `FONT_10X20`, `FONT_4X6`, `FONT_5X7`, `FONT_5X8`, `FONT_6X9`, `FONT_9X15`, `ImageRawBE`, `ImageRaw`, `Image`, `MonoTextStyle`, `PrimitiveStyleBuilder`, `Rectangle`, `Rgb565`, `Text`, and `pixelcolor::BinaryColor` [INFO] [stdout] --> src/fireplace.rs:3:13 [INFO] [stdout] | [INFO] [stdout] 3 | image::{Image, ImageRaw, ImageRawBE}, [INFO] [stdout] | ^^^^^ ^^^^^^^^ ^^^^^^^^^^ [INFO] [stdout] 4 | mono_font::{ [INFO] [stdout] 5 | iso_8859_1::{FONT_10X20, FONT_4X6, FONT_5X7, FONT_5X8, FONT_6X9, FONT_9X15}, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] 6 | MonoTextStyle, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 7 | }, [INFO] [stdout] 8 | pixelcolor::BinaryColor, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 9 | pixelcolor::{Rgb565, Rgb888}, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 10 | prelude::*, [INFO] [stdout] 11 | primitives::{Circle, Line, PrimitiveStyle, PrimitiveStyleBuilder, Rectangle}, [INFO] [stdout] | ^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] 12 | text::{Alignment, Text}, [INFO] [stdout] | ^^^^^^^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::seq::SliceRandom` [INFO] [stdout] --> src/fireplace.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use rand::seq::SliceRandom; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::f32::consts::PI` [INFO] [stdout] --> src/fireplace.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | use std::f32::consts::PI; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Local`, `NaiveDate`, and `TimeZone` [INFO] [stdout] --> src/tokens.rs:1:34 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Duration, Local, NaiveDate, TimeZone, Utc}; [INFO] [stdout] | ^^^^^ ^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::json` [INFO] [stdout] --> src/tokens.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use serde_json::json; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::led::weather::show_weather_forecast` [INFO] [stdout] --> src/main.rs:40:5 [INFO] [stdout] | [INFO] [stdout] 40 | use crate::led::weather::show_weather_forecast; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `OpenOptions` [INFO] [stdout] --> src/tokens.rs:4:31 [INFO] [stdout] | [INFO] [stdout] 4 | use std::fs::{metadata, File, OpenOptions}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `prelude::*` and `self` [INFO] [stdout] --> src/tokens.rs:5:15 [INFO] [stdout] | [INFO] [stdout] 5 | use std::io::{self, prelude::*, Read, Write}; [INFO] [stdout] | ^^^^ ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/tokens.rs:116:9 [INFO] [stdout] | [INFO] [stdout] 116 | / /// check if given token is in the list of tokens [INFO] [stdout] 117 | | /// and if the expiration date is not passed [INFO] [stdout] | |____________________________________________________^ [INFO] [stdout] ... [INFO] [stdout] 127 | / if token.token == given_token.token.to_string() { [INFO] [stdout] 128 | | /// expirated token is only deleted when it is used !! [INFO] [stdout] 129 | | if date_is_passed(token.expiration_date.as_ref().unwrap()) { [INFO] [stdout] 130 | | log::info!("token expired"); [INFO] [stdout] ... | [INFO] [stdout] 139 | | } [INFO] [stdout] | |_________- rustdoc does not generate documentation for expressions [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] = note: `#[warn(unused_doc_comments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/tokens.rs:128:13 [INFO] [stdout] | [INFO] [stdout] 128 | /// expirated token is only deleted when it is used !! [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 129 | / if date_is_passed(token.expiration_date.as_ref().unwrap()) { [INFO] [stdout] 130 | | log::info!("token expired"); [INFO] [stdout] 131 | | given_token.delete_token().expect("Failed to delete token"); [INFO] [stdout] 132 | | return Err(std::io::Error::new( [INFO] [stdout] ... | [INFO] [stdout] 135 | | )); [INFO] [stdout] 136 | | } [INFO] [stdout] | |_____________- rustdoc does not generate documentation for expressions [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/pong.rs:128:12 [INFO] [stdout] | [INFO] [stdout] 128 | if (self.ball_pos.x == self.player_x_pos [INFO] [stdout] | ^ [INFO] [stdout] ... [INFO] [stdout] 131 | || self.ball_pos.y == self.player_y_pos + 1)) [INFO] [stdout] | ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 128 ~ if self.ball_pos.x == self.player_x_pos [INFO] [stdout] 129 | && (self.ball_pos.y == self.player_y_pos [INFO] [stdout] 130 | || self.ball_pos.y == self.player_y_pos - 1 [INFO] [stdout] 131 ~ || self.ball_pos.y == self.player_y_pos + 1) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `App`, `HttpServer`, and `web` [INFO] [stdout] --> src/leptos.rs:1:17 [INFO] [stdout] | [INFO] [stdout] 1 | use actix_web::{web, App, HttpRequest, HttpServer, Result as AcResult}; [INFO] [stdout] | ^^^ ^^^ ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/api/api.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/api/api.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::led::weather::show_weather_forecast` [INFO] [stdout] --> src/main.rs:40:5 [INFO] [stdout] | [INFO] [stdout] 40 | use crate::led::weather::show_weather_forecast; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `server` [INFO] [stdout] --> src/main.rs:170:9 [INFO] [stdout] | [INFO] [stdout] 170 | let server = HttpServer::new(move || { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_server` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `server` [INFO] [stdout] --> src/main.rs:170:9 [INFO] [stdout] | [INFO] [stdout] 170 | let server = HttpServer::new(move || { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_server` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `job_history` [INFO] [stdout] --> src/main.rs:230:53 [INFO] [stdout] | [INFO] [stdout] 230 | async fn led_service(led_data: Arc>, job_history: Arc>) -> std::io::Result<()> { [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_job_history` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `job_history` [INFO] [stdout] --> src/main.rs:230:53 [INFO] [stdout] | [INFO] [stdout] 230 | async fn led_service(led_data: Arc>, job_history: Arc>) -> std::io::Result<()> { [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_job_history` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `step` [INFO] [stdout] --> src/main.rs:243:9 [INFO] [stdout] | [INFO] [stdout] 243 | for step in 0.. { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_step` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `step` [INFO] [stdout] --> src/main.rs:243:9 [INFO] [stdout] | [INFO] [stdout] 243 | for step in 0.. { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_step` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `now` [INFO] [stdout] --> src/main.rs:274:25 [INFO] [stdout] | [INFO] [stdout] 274 | let now = std::time::Instant::now(); [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_now` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `now` [INFO] [stdout] --> src/main.rs:274:25 [INFO] [stdout] | [INFO] [stdout] 274 | let now = std::time::Instant::now(); [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_now` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:240:22 [INFO] [stdout] | [INFO] [stdout] 240 | let (mut matrix, mut start_canvas) = [INFO] [stdout] | ----^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:240:22 [INFO] [stdout] | [INFO] [stdout] 240 | let (mut matrix, mut start_canvas) = [INFO] [stdout] | ----^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/football.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cols` [INFO] [stdout] --> src/led/football.rs:28:9 [INFO] [stdout] | [INFO] [stdout] 28 | let cols = config.cols as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_cols` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/football.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cols` [INFO] [stdout] --> src/led/football.rs:28:9 [INFO] [stdout] | [INFO] [stdout] 28 | let cols = config.cols as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_cols` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `date` [INFO] [stdout] --> src/http_endpoints.rs:193:9 [INFO] [stdout] | [INFO] [stdout] 193 | let date = Local::now(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_date` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `position` [INFO] [stdout] --> src/http_endpoints.rs:206:9 [INFO] [stdout] | [INFO] [stdout] 206 | let position = Some(Point::new((rgb_matrix_config.rows as i32) * 2 , (rgb_matrix_config.cols as i32) / 2)); [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_position` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `date` [INFO] [stdout] --> src/http_endpoints.rs:193:9 [INFO] [stdout] | [INFO] [stdout] 193 | let date = Local::now(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_date` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `position` [INFO] [stdout] --> src/http_endpoints.rs:206:9 [INFO] [stdout] | [INFO] [stdout] 206 | let position = Some(Point::new((rgb_matrix_config.rows as i32) * 2 , (rgb_matrix_config.cols as i32) / 2)); [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_position` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:195:23 [INFO] [stdout] | [INFO] [stdout] 195 | let (mut _matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:195:23 [INFO] [stdout] | [INFO] [stdout] 195 | let (mut _matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `led_func_data` [INFO] [stdout] --> src/led/clock.rs:16:5 [INFO] [stdout] | [INFO] [stdout] 16 | led_func_data: crate::LedFuncData, [INFO] [stdout] | ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_led_func_data` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `canvas` [INFO] [stdout] --> src/led/clock.rs:17:9 [INFO] [stdout] | [INFO] [stdout] 17 | mut canvas: Box, [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_canvas` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/led/clock.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | mut canvas: Box, [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `led_func_data` [INFO] [stdout] --> src/led/clock.rs:16:5 [INFO] [stdout] | [INFO] [stdout] 16 | led_func_data: crate::LedFuncData, [INFO] [stdout] | ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_led_func_data` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `canvas` [INFO] [stdout] --> src/led/clock.rs:17:9 [INFO] [stdout] | [INFO] [stdout] 17 | mut canvas: Box, [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_canvas` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/led/clock.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | mut canvas: Box, [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `req` [INFO] [stdout] --> src/http_endpoints.rs:400:25 [INFO] [stdout] | [INFO] [stdout] 400 | pub async fn delete_job(req: HttpRequest, data: web::Data) -> impl Responder { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_req` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `req` [INFO] [stdout] --> src/http_endpoints.rs:400:25 [INFO] [stdout] | [INFO] [stdout] 400 | pub async fn delete_job(req: HttpRequest, data: web::Data) -> impl Responder { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_req` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `content_type` [INFO] [stdout] --> src/http_endpoints.rs:412:12 [INFO] [stdout] | [INFO] [stdout] 412 | let content_type = field.content_disposition(); [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `content_type` [INFO] [stdout] --> src/http_endpoints.rs:412:12 [INFO] [stdout] | [INFO] [stdout] 412 | let content_type = field.content_disposition(); [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:411:22 [INFO] [stdout] | [INFO] [stdout] 411 | while let Ok(Some(mut field)) = payload.try_next().await { [INFO] [stdout] | ----^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:411:22 [INFO] [stdout] | [INFO] [stdout] 411 | while let Ok(Some(mut field)) = payload.try_next().await { [INFO] [stdout] | ----^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `date` [INFO] [stdout] --> src/http_endpoints.rs:494:13 [INFO] [stdout] | [INFO] [stdout] 494 | let date = Local::now(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_date` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `date` [INFO] [stdout] --> src/http_endpoints.rs:494:13 [INFO] [stdout] | [INFO] [stdout] 494 | let date = Local::now(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_date` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/run_text.rs:20:9 [INFO] [stdout] | [INFO] [stdout] 20 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/run_text.rs:20:9 [INFO] [stdout] | [INFO] [stdout] 20 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `date` [INFO] [stdout] --> src/http_endpoints.rs:532:9 [INFO] [stdout] | [INFO] [stdout] 532 | let date = Local::now(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_date` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `date` [INFO] [stdout] --> src/http_endpoints.rs:532:9 [INFO] [stdout] | [INFO] [stdout] 532 | let date = Local::now(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_date` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:534:23 [INFO] [stdout] | [INFO] [stdout] 534 | let (mut _matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:534:23 [INFO] [stdout] | [INFO] [stdout] 534 | let (mut _matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `text` [INFO] [stdout] --> src/led/bvg.rs:63:13 [INFO] [stdout] | [INFO] [stdout] 63 | let text = Text::with_alignment( [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_text` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `product_name` [INFO] [stdout] --> src/led/bvg.rs:95:13 [INFO] [stdout] | [INFO] [stdout] 95 | let product_name = departure [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_product_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `text` [INFO] [stdout] --> src/led/bvg.rs:116:13 [INFO] [stdout] | [INFO] [stdout] 116 | let text = Text::with_alignment( [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_text` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `text` [INFO] [stdout] --> src/led/bvg.rs:63:13 [INFO] [stdout] | [INFO] [stdout] 63 | let text = Text::with_alignment( [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_text` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `product_name` [INFO] [stdout] --> src/led/bvg.rs:95:13 [INFO] [stdout] | [INFO] [stdout] 95 | let product_name = departure [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_product_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `text` [INFO] [stdout] --> src/led/bvg.rs:116:13 [INFO] [stdout] | [INFO] [stdout] 116 | let text = Text::with_alignment( [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_text` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:601:19 [INFO] [stdout] | [INFO] [stdout] 601 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:601:19 [INFO] [stdout] | [INFO] [stdout] 601 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `data` [INFO] [stdout] --> src/http_endpoints.rs:661:54 [INFO] [stdout] | [INFO] [stdout] 661 | pub async fn update_scheduled_jobs(req: HttpRequest, data: web::Data) -> impl Responder { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_data` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `data` [INFO] [stdout] --> src/http_endpoints.rs:661:54 [INFO] [stdout] | [INFO] [stdout] 661 | pub async fn update_scheduled_jobs(req: HttpRequest, data: web::Data) -> impl Responder { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_data` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:728:19 [INFO] [stdout] | [INFO] [stdout] 728 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:728:19 [INFO] [stdout] | [INFO] [stdout] 728 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/fireplace.rs:25:9 [INFO] [stdout] | [INFO] [stdout] 25 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/fireplace.rs:25:9 [INFO] [stdout] | [INFO] [stdout] 25 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:766:19 [INFO] [stdout] | [INFO] [stdout] 766 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:766:19 [INFO] [stdout] | [INFO] [stdout] 766 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/led/dashboard.rs:66:9 [INFO] [stdout] | [INFO] [stdout] 66 | _ => Ok(()), [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/led/dashboard.rs:66:9 [INFO] [stdout] | [INFO] [stdout] 58 | DashboardWidgets::AutobahnInfo(i) => dashboard_autobahn( [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 63 | DashboardWidgets::WeatherInfo(i) => { [INFO] [stdout] | -------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 66 | _ => Ok(()), [INFO] [stdout] | ^ collectively making this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/led/dashboard.rs:66:9 [INFO] [stdout] | [INFO] [stdout] 66 | _ => Ok(()), [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/led/dashboard.rs:66:9 [INFO] [stdout] | [INFO] [stdout] 58 | DashboardWidgets::AutobahnInfo(i) => dashboard_autobahn( [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 63 | DashboardWidgets::WeatherInfo(i) => { [INFO] [stdout] | -------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 66 | _ => Ok(()), [INFO] [stdout] | ^ collectively making this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/dashboard.rs:28:9 [INFO] [stdout] | [INFO] [stdout] 28 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/led/dashboard.rs:58:40 [INFO] [stdout] | [INFO] [stdout] 58 | DashboardWidgets::AutobahnInfo(i) => dashboard_autobahn( [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/led/dashboard.rs:63:39 [INFO] [stdout] | [INFO] [stdout] 63 | DashboardWidgets::WeatherInfo(i) => { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/dashboard.rs:28:9 [INFO] [stdout] | [INFO] [stdout] 28 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/led/dashboard.rs:58:40 [INFO] [stdout] | [INFO] [stdout] 58 | DashboardWidgets::AutobahnInfo(i) => dashboard_autobahn( [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `i` [INFO] [stdout] --> src/led/dashboard.rs:63:39 [INFO] [stdout] | [INFO] [stdout] 63 | DashboardWidgets::WeatherInfo(i) => { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/http_endpoints.rs:848:9 [INFO] [stdout] | [INFO] [stdout] 848 | _ => {}, [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/http_endpoints.rs:848:9 [INFO] [stdout] | [INFO] [stdout] 808 | DashboardWidgets::AutobahnInfo(ref i) => { [INFO] [stdout] | ------------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 837 | DashboardWidgets::WeatherInfo(ref i) => { [INFO] [stdout] | ------------------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 848 | _ => {}, [INFO] [stdout] | ^ collectively making this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/http_endpoints.rs:848:9 [INFO] [stdout] | [INFO] [stdout] 848 | _ => {}, [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/http_endpoints.rs:848:9 [INFO] [stdout] | [INFO] [stdout] 808 | DashboardWidgets::AutobahnInfo(ref i) => { [INFO] [stdout] | ------------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 837 | DashboardWidgets::WeatherInfo(ref i) => { [INFO] [stdout] | ------------------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 848 | _ => {}, [INFO] [stdout] | ^ collectively making this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:862:19 [INFO] [stdout] | [INFO] [stdout] 862 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:864:9 [INFO] [stdout] | [INFO] [stdout] 864 | let mut canvas = dashboard::show_dashboard(led_func_data.clone(), canvas).await.0; [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:862:19 [INFO] [stdout] | [INFO] [stdout] 862 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:864:9 [INFO] [stdout] | [INFO] [stdout] 864 | let mut canvas = dashboard::show_dashboard(led_func_data.clone(), canvas).await.0; [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:893:19 [INFO] [stdout] | [INFO] [stdout] 893 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:901:9 [INFO] [stdout] | [INFO] [stdout] 901 | let mut canvas = crate::led::error::display_error(led_func_data.clone(), canvas).0; [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:893:19 [INFO] [stdout] | [INFO] [stdout] 893 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:901:9 [INFO] [stdout] | [INFO] [stdout] 901 | let mut canvas = crate::led::error::display_error(led_func_data.clone(), canvas).0; [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `now` [INFO] [stdout] --> src/led/pong.rs:24:9 [INFO] [stdout] | [INFO] [stdout] 24 | let now = std::time::Instant::now(); [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_now` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `now` [INFO] [stdout] --> src/led/pong.rs:24:9 [INFO] [stdout] | [INFO] [stdout] 24 | let now = std::time::Instant::now(); [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_now` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/pong.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/pong.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cols` [INFO] [stdout] --> src/led/pong.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | let cols = config.cols as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_cols` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cols` [INFO] [stdout] --> src/led/pong.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | let cols = config.cols as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_cols` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:964:19 [INFO] [stdout] | [INFO] [stdout] 964 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:966:9 [INFO] [stdout] | [INFO] [stdout] 966 | let mut canvas = crate::led::pong::show_pong_led(led_func_data.clone(), canvas).await.0; [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:964:19 [INFO] [stdout] | [INFO] [stdout] 964 | let (_matrix, mut canvas) = [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/http_endpoints.rs:966:9 [INFO] [stdout] | [INFO] [stdout] 966 | let mut canvas = crate::led::pong::show_pong_led(led_func_data.clone(), canvas).await.0; [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `StreamExt` [INFO] [stdout] --> src/http_endpoints.rs:4:15 [INFO] [stdout] | [INFO] [stdout] 4 | use futures::{StreamExt, TryStreamExt}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::prelude` [INFO] [stdout] --> src/http_endpoints.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | use std::io::prelude::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `StreamExt` [INFO] [stdout] --> src/http_endpoints.rs:4:15 [INFO] [stdout] | [INFO] [stdout] 4 | use futures::{StreamExt, TryStreamExt}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::prelude` [INFO] [stdout] --> src/http_endpoints.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | use std::io::prelude::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `matrix` [INFO] [stdout] --> src/led/image.rs:20:14 [INFO] [stdout] | [INFO] [stdout] 20 | let (mut matrix, mut canvas) = RGBMatrix::new(config, 0).expect("Matrix initialization failed"); [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_matrix` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/led/image.rs:20:10 [INFO] [stdout] | [INFO] [stdout] 20 | let (mut matrix, mut canvas) = RGBMatrix::new(config, 0).expect("Matrix initialization failed"); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/led.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `first_text` [INFO] [stdout] --> src/led/led.rs:58:9 [INFO] [stdout] | [INFO] [stdout] 58 | let first_text = Text::with_alignment( [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_first_text` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `led_func_data` [INFO] [stdout] --> src/led/led.rs:43:5 [INFO] [stdout] | [INFO] [stdout] 43 | led_func_data: crate::LedFuncData, [INFO] [stdout] | ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_led_func_data` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/weather.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cols` [INFO] [stdout] --> src/led/weather.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | let cols = config.cols as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_cols` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `forcast_date` is never read [INFO] [stdout] --> src/led/weather.rs:31:13 [INFO] [stdout] | [INFO] [stdout] 31 | let mut forcast_date: String = "".to_string(); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/error.rs:24:9 [INFO] [stdout] | [INFO] [stdout] 24 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cols` [INFO] [stdout] --> src/led/error.rs:25:9 [INFO] [stdout] | [INFO] [stdout] 25 | let cols = config.cols as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_cols` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `color` [INFO] [stdout] --> src/led/error.rs:26:13 [INFO] [stdout] | [INFO] [stdout] 26 | let mut color = Rgb888::CYAN; [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_color` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `text` [INFO] [stdout] --> src/led/error.rs:36:9 [INFO] [stdout] | [INFO] [stdout] 36 | let text = "Hello, World!\n\ [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_text` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/led/error.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | let mut color = Rgb888::CYAN; [INFO] [stdout] | ----^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `matrix` [INFO] [stdout] --> src/led/image.rs:20:14 [INFO] [stdout] | [INFO] [stdout] 20 | let (mut matrix, mut canvas) = RGBMatrix::new(config, 0).expect("Matrix initialization failed"); [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_matrix` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/led/image.rs:20:10 [INFO] [stdout] | [INFO] [stdout] 20 | let (mut matrix, mut canvas) = RGBMatrix::new(config, 0).expect("Matrix initialization failed"); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/led.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `first_text` [INFO] [stdout] --> src/led/led.rs:58:9 [INFO] [stdout] | [INFO] [stdout] 58 | let first_text = Text::with_alignment( [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_first_text` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `led_func_data` [INFO] [stdout] --> src/led/led.rs:43:5 [INFO] [stdout] | [INFO] [stdout] 43 | led_func_data: crate::LedFuncData, [INFO] [stdout] | ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_led_func_data` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/weather.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cols` [INFO] [stdout] --> src/led/weather.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | let cols = config.cols as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_cols` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `forcast_date` is never read [INFO] [stdout] --> src/led/weather.rs:31:13 [INFO] [stdout] | [INFO] [stdout] 31 | let mut forcast_date: String = "".to_string(); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `auth_token` [INFO] [stdout] --> src/cron.rs:9:65 [INFO] [stdout] | [INFO] [stdout] 9 | pub fn new_con_job(schedule_job: crate::config::ConfigSchedule, auth_token: &str, stop_id: &i32) { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_auth_token` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `stop_id` [INFO] [stdout] --> src/cron.rs:9:83 [INFO] [stdout] | [INFO] [stdout] 9 | pub fn new_con_job(schedule_job: crate::config::ConfigSchedule, auth_token: &str, stop_id: &i32) { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stop_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `y_start` is never read [INFO] [stdout] --> src/fireplace.rs:107:13 [INFO] [stdout] | [INFO] [stdout] 107 | let mut y_start = line.start.y; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `y_end` is never read [INFO] [stdout] --> src/fireplace.rs:108:13 [INFO] [stdout] | [INFO] [stdout] 108 | let mut y_end = line.end.y; [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/tokens.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 21 | mut expiration_date: Option>, [INFO] [stdout] | ----^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/tokens.rs:25:13 [INFO] [stdout] | [INFO] [stdout] 25 | let mut future_timestamp_string; [INFO] [stdout] | ----^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `file` [INFO] [stdout] --> src/tokens.rs:82:17 [INFO] [stdout] | [INFO] [stdout] 82 | let mut file = File::create(file_path).expect("to work"); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/tokens.rs:82:13 [INFO] [stdout] | [INFO] [stdout] 82 | let mut file = File::create(file_path).expect("to work"); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rows` [INFO] [stdout] --> src/led/error.rs:24:9 [INFO] [stdout] | [INFO] [stdout] 24 | let rows = config.rows as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_rows` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cols` [INFO] [stdout] --> src/led/error.rs:25:9 [INFO] [stdout] | [INFO] [stdout] 25 | let cols = config.cols as i32; [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_cols` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `color` [INFO] [stdout] --> src/led/error.rs:26:13 [INFO] [stdout] | [INFO] [stdout] 26 | let mut color = Rgb888::CYAN; [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_color` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `text` [INFO] [stdout] --> src/led/error.rs:36:9 [INFO] [stdout] | [INFO] [stdout] 36 | let text = "Hello, World!\n\ [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_text` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/led/error.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | let mut color = Rgb888::CYAN; [INFO] [stdout] | ----^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `auth_token` [INFO] [stdout] --> src/cron.rs:9:65 [INFO] [stdout] | [INFO] [stdout] 9 | pub fn new_con_job(schedule_job: crate::config::ConfigSchedule, auth_token: &str, stop_id: &i32) { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_auth_token` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `stop_id` [INFO] [stdout] --> src/cron.rs:9:83 [INFO] [stdout] | [INFO] [stdout] 9 | pub fn new_con_job(schedule_job: crate::config::ConfigSchedule, auth_token: &str, stop_id: &i32) { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stop_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `y_start` is never read [INFO] [stdout] --> src/fireplace.rs:107:13 [INFO] [stdout] | [INFO] [stdout] 107 | let mut y_start = line.start.y; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `y_end` is never read [INFO] [stdout] --> src/fireplace.rs:108:13 [INFO] [stdout] | [INFO] [stdout] 108 | let mut y_end = line.end.y; [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/tokens.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 21 | mut expiration_date: Option>, [INFO] [stdout] | ----^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/tokens.rs:25:13 [INFO] [stdout] | [INFO] [stdout] 25 | let mut future_timestamp_string; [INFO] [stdout] | ----^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `file` [INFO] [stdout] --> src/tokens.rs:82:17 [INFO] [stdout] | [INFO] [stdout] 82 | let mut file = File::create(file_path).expect("to work"); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/tokens.rs:82:13 [INFO] [stdout] | [INFO] [stdout] 82 | let mut file = File::create(file_path).expect("to work"); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `FileUpload` is never constructed [INFO] [stdout] --> src/http_endpoints.rs:54:12 [INFO] [stdout] | [INFO] [stdout] 54 | pub struct FileUpload { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `FileUpload` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `manual_hello` is never used [INFO] [stdout] --> src/http_endpoints.rs:124:14 [INFO] [stdout] | [INFO] [stdout] 124 | pub async fn manual_hello() -> impl Responder { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `save_file` is never used [INFO] [stdout] --> src/http_endpoints.rs:408:14 [INFO] [stdout] | [INFO] [stdout] 408 | pub async fn save_file(mut payload: Multipart, file_path: String) -> Option { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `show_status_bar` is never used [INFO] [stdout] --> src/led/led.rs:42:8 [INFO] [stdout] | [INFO] [stdout] 42 | pub fn show_status_bar( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `load_file` is never used [INFO] [stdout] --> src/led/weather.rs:275:4 [INFO] [stdout] | [INFO] [stdout] 275 | fn load_file(path: &str) -> std::io::Result> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `index` is never used [INFO] [stdout] --> src/leptos.rs:5:14 [INFO] [stdout] | [INFO] [stdout] 5 | pub async fn index() -> AcResult { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `outroute_js` is never used [INFO] [stdout] --> src/leptos.rs:11:14 [INFO] [stdout] | [INFO] [stdout] 11 | pub async fn outroute_js(req: HttpRequest) -> AcResult { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `outroute_wasm` is never used [INFO] [stdout] --> src/leptos.rs:16:14 [INFO] [stdout] | [INFO] [stdout] 16 | pub async fn outroute_wasm(req: HttpRequest) -> AcResult { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `outroute_css` is never used [INFO] [stdout] --> src/leptos.rs:21:14 [INFO] [stdout] | [INFO] [stdout] 21 | pub async fn outroute_css(req: HttpRequest) -> AcResult { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_path_to_dist_build` is never used [INFO] [stdout] --> src/leptos.rs:26:4 [INFO] [stdout] | [INFO] [stdout] 26 | fn get_path_to_dist_build(req:HttpRequest, file_ending: &str) -> PathBuf { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/main.rs:308:5 [INFO] [stdout] | [INFO] [stdout] 308 | dotenv::from_path("/home/pi/.config/ledcat/.env"); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 308 | let _ = dotenv::from_path("/home/pi/.config/ledcat/.env"); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/main.rs:342:5 [INFO] [stdout] | [INFO] [stdout] 342 | led_service(led_data.clone(), job_history.clone()).await; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 342 | let _ = led_service(led_data.clone(), job_history.clone()).await; [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `isBlocked` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:13:9 [INFO] [stdout] | [INFO] [stdout] 13 | pub isBlocked: String, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `is_blocked` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `startLcPosition` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:17:9 [INFO] [stdout] | [INFO] [stdout] 17 | pub startLcPosition: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `start_lc_position` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `startTimestamp` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 21 | pub startTimestamp: String, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `start_timestamp` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `routeRecommendation` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:24:9 [INFO] [stdout] | [INFO] [stdout] 24 | pub routeRecommendation: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `route_recommendation` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `lorryParkingFeatureIcons` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | pub lorryParkingFeatureIcons: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `lorry_parking_feature_icons` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `abnormalTrafficType` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | pub abnormalTrafficType: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `abnormal_traffic_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `delayTimeValue` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:28:9 [INFO] [stdout] | [INFO] [stdout] 28 | pub delayTimeValue: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `delay_time_value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `averageSpeed` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:29:9 [INFO] [stdout] | [INFO] [stdout] 29 | pub averageSpeed: Option, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `average_speed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Pollen` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | Pollen: DwdPollenContentPollen, [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `pollen` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Roggen` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | Roggen: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `roggen` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Birke` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | Birke: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^ help: convert the identifier to snake case: `birke` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Hasel` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | Hasel: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^ help: convert the identifier to snake case: `hasel` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Ambrosia` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Ambrosia: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `ambrosia` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Graeser` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | Graeser: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `graeser` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Beifuss` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:24:5 [INFO] [stdout] | [INFO] [stdout] 24 | Beifuss: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `beifuss` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Esche` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:25:5 [INFO] [stdout] | [INFO] [stdout] 25 | Esche: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^ help: convert the identifier to snake case: `esche` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Erle` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:26:5 [INFO] [stdout] | [INFO] [stdout] 26 | Erle: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^ help: convert the identifier to snake case: `erle` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `ISO3166_2_lvl4` should have a snake case name [INFO] [stdout] --> src/api/openstreetmap.rs:31:9 [INFO] [stdout] | [INFO] [stdout] 31 | pub ISO3166_2_lvl4: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `iso3166_2_lvl4` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastDaily` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:7:9 [INFO] [stdout] | [INFO] [stdout] 7 | pub forecastDaily: WeatherDailyForcast, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_daily` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastHourly` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:8:9 [INFO] [stdout] | [INFO] [stdout] 8 | pub forecastHourly: WeatherHourlyForcast, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_hourly` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `attributionURL` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:25:9 [INFO] [stdout] | [INFO] [stdout] 25 | pub attributionURL: String, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `attribution_url` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `expireTime` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | pub expireTime: String, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `expire_time` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `readTime` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:29:9 [INFO] [stdout] | [INFO] [stdout] 29 | pub readTime: String, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `read_time` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `reportedTime` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:30:9 [INFO] [stdout] | [INFO] [stdout] 30 | pub reportedTime: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `reported_time` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sourceType` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:33:9 [INFO] [stdout] | [INFO] [stdout] 33 | pub sourceType: String, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `source_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastStart` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:38:9 [INFO] [stdout] | [INFO] [stdout] 38 | pub forecastStart: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_start` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastEnd` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:39:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub forecastEnd: String, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_end` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `conditionCode` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:40:9 [INFO] [stdout] | [INFO] [stdout] 40 | pub conditionCode: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `condition_code` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `maxUvIndex` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:41:9 [INFO] [stdout] | [INFO] [stdout] 41 | pub maxUvIndex: f32, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `max_uv_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `moonPhase` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:42:9 [INFO] [stdout] | [INFO] [stdout] 42 | pub moonPhase: String, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `moon_phase` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:45:9 [INFO] [stdout] | [INFO] [stdout] 45 | pub precipitationAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationChance` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:46:9 [INFO] [stdout] | [INFO] [stdout] 46 | pub precipitationChance: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_chance` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationType` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | pub precipitationType: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `snowfallAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:48:9 [INFO] [stdout] | [INFO] [stdout] 48 | pub snowfallAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `snowfall_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `solarMidnight` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:49:9 [INFO] [stdout] | [INFO] [stdout] 49 | pub solarMidnight: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `solar_midnight` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `solarNoon` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:50:9 [INFO] [stdout] | [INFO] [stdout] 50 | pub solarNoon: String, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `solar_noon` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunriseCivil` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:52:9 [INFO] [stdout] | [INFO] [stdout] 52 | pub sunriseCivil: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `sunrise_civil` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunriseNautical` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:53:9 [INFO] [stdout] | [INFO] [stdout] 53 | pub sunriseNautical: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `sunrise_nautical` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunriseAstronomical` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:54:9 [INFO] [stdout] | [INFO] [stdout] 54 | pub sunriseAstronomical: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `sunrise_astronomical` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunsetCivil` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:56:9 [INFO] [stdout] | [INFO] [stdout] 56 | pub sunsetCivil: String, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `sunset_civil` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunsetNautical` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:57:9 [INFO] [stdout] | [INFO] [stdout] 57 | pub sunsetNautical: String, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `sunset_nautical` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunsetAstronomical` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:58:9 [INFO] [stdout] | [INFO] [stdout] 58 | pub sunsetAstronomical: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `sunset_astronomical` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:59:9 [INFO] [stdout] | [INFO] [stdout] 59 | pub temperatureMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureMin` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:60:9 [INFO] [stdout] | [INFO] [stdout] 60 | pub temperatureMin: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_min` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windGustSpeedMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:61:9 [INFO] [stdout] | [INFO] [stdout] 61 | pub windGustSpeedMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_gust_speed_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windSpeedAvg` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:62:9 [INFO] [stdout] | [INFO] [stdout] 62 | pub windSpeedAvg: f32, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_speed_avg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windSpeedMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:63:9 [INFO] [stdout] | [INFO] [stdout] 63 | pub windSpeedMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_speed_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `daytimeForecast` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:64:9 [INFO] [stdout] | [INFO] [stdout] 64 | pub daytimeForecast: DayliForcast, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `daytime_forecast` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `overnightForecast` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:65:9 [INFO] [stdout] | [INFO] [stdout] 65 | pub overnightForecast: DayliForcast, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `overnight_forecast` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastStart` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:70:9 [INFO] [stdout] | [INFO] [stdout] 70 | pub forecastStart: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_start` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `cloudCover` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:71:9 [INFO] [stdout] | [INFO] [stdout] 71 | pub cloudCover: f32, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `cloud_cover` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `conditionCode` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:72:9 [INFO] [stdout] | [INFO] [stdout] 72 | pub conditionCode: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `condition_code` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:75:9 [INFO] [stdout] | [INFO] [stdout] 75 | pub precipitationAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationIntensity` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:76:9 [INFO] [stdout] | [INFO] [stdout] 76 | pub precipitationIntensity: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_intensity` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationChance` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:77:9 [INFO] [stdout] | [INFO] [stdout] 77 | pub precipitationChance: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_chance` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationType` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:78:9 [INFO] [stdout] | [INFO] [stdout] 78 | pub precipitationType: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `pressureTrend` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:80:9 [INFO] [stdout] | [INFO] [stdout] 80 | pub pressureTrend: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `pressure_trend` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `snowfallIntensity` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:81:9 [INFO] [stdout] | [INFO] [stdout] 81 | pub snowfallIntensity: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `snowfall_intensity` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `snowfallAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:82:9 [INFO] [stdout] | [INFO] [stdout] 82 | pub snowfallAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `snowfall_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureApparent` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:84:9 [INFO] [stdout] | [INFO] [stdout] 84 | pub temperatureApparent: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_apparent` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureDewPoint` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:85:9 [INFO] [stdout] | [INFO] [stdout] 85 | pub temperatureDewPoint: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_dew_point` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `uvIndex` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:86:9 [INFO] [stdout] | [INFO] [stdout] 86 | pub uvIndex: f32, [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `uv_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windDirection` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:88:9 [INFO] [stdout] | [INFO] [stdout] 88 | pub windDirection: f32, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_direction` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windGust` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:89:9 [INFO] [stdout] | [INFO] [stdout] 89 | pub windGust: f32, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `wind_gust` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windSpeed` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:90:9 [INFO] [stdout] | [INFO] [stdout] 90 | pub windSpeed: f32, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `wind_speed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastStart` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:95:9 [INFO] [stdout] | [INFO] [stdout] 95 | pub forecastStart: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_start` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastEnd` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:96:9 [INFO] [stdout] | [INFO] [stdout] 96 | pub forecastEnd: String, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_end` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `cloudCover` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:97:9 [INFO] [stdout] | [INFO] [stdout] 97 | pub cloudCover: f32, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `cloud_cover` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `conditionCode` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:98:9 [INFO] [stdout] | [INFO] [stdout] 98 | pub conditionCode: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `condition_code` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:100:9 [INFO] [stdout] | [INFO] [stdout] 100 | pub precipitationAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationChance` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:101:9 [INFO] [stdout] | [INFO] [stdout] 101 | pub precipitationChance: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_chance` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationType` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:102:9 [INFO] [stdout] | [INFO] [stdout] 102 | pub precipitationType: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `snowfallAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:103:9 [INFO] [stdout] | [INFO] [stdout] 103 | pub snowfallAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `snowfall_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:104:9 [INFO] [stdout] | [INFO] [stdout] 104 | pub temperatureMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureMin` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:105:9 [INFO] [stdout] | [INFO] [stdout] 105 | pub temperatureMin: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_min` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windDirection` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:106:9 [INFO] [stdout] | [INFO] [stdout] 106 | pub windDirection: f32, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_direction` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windGustSpeedMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:107:9 [INFO] [stdout] | [INFO] [stdout] 107 | pub windGustSpeedMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_gust_speed_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windSpeed` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:108:9 [INFO] [stdout] | [INFO] [stdout] 108 | pub windSpeed: f32, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `wind_speed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windSpeedMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:109:9 [INFO] [stdout] | [INFO] [stdout] 109 | pub windSpeedMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_speed_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:7:9 [INFO] [stdout] | [INFO] [stdout] 7 | pub matchID: u64, [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `match_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchDateTime` should have a snake case name [INFO] [stdout] --> src/api/football.rs:8:9 [INFO] [stdout] | [INFO] [stdout] 8 | pub matchDateTime: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `match_date_time` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `timeZoneID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:9:9 [INFO] [stdout] | [INFO] [stdout] 9 | pub timeZoneID: String, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `time_zone_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `leagueId` should have a snake case name [INFO] [stdout] --> src/api/football.rs:10:9 [INFO] [stdout] | [INFO] [stdout] 10 | pub leagueId: u64, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `league_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `leagueName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | pub leagueName: String, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `league_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `leagueSeason` should have a snake case name [INFO] [stdout] --> src/api/football.rs:12:9 [INFO] [stdout] | [INFO] [stdout] 12 | pub leagueSeason: u64, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `league_season` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `leagueShortcut` should have a snake case name [INFO] [stdout] --> src/api/football.rs:13:9 [INFO] [stdout] | [INFO] [stdout] 13 | pub leagueShortcut: String, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `league_shortcut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchDateTimeUTC` should have a snake case name [INFO] [stdout] --> src/api/football.rs:14:9 [INFO] [stdout] | [INFO] [stdout] 14 | pub matchDateTimeUTC: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `match_date_time_utc` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `lastUpdateDateTime` should have a snake case name [INFO] [stdout] --> src/api/football.rs:18:9 [INFO] [stdout] | [INFO] [stdout] 18 | pub lastUpdateDateTime: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `last_update_date_time` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchIsFinished` should have a snake case name [INFO] [stdout] --> src/api/football.rs:19:9 [INFO] [stdout] | [INFO] [stdout] 19 | pub matchIsFinished: bool, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `match_is_finished` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchResults` should have a snake case name [INFO] [stdout] --> src/api/football.rs:20:9 [INFO] [stdout] | [INFO] [stdout] 20 | pub matchResults: Vec, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `match_results` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `numberOfViewers` should have a snake case name [INFO] [stdout] --> src/api/football.rs:23:9 [INFO] [stdout] | [INFO] [stdout] 23 | pub numberOfViewers: u64, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `number_of_viewers` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `groupName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:28:9 [INFO] [stdout] | [INFO] [stdout] 28 | pub groupName: String, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `group_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `groupOrderID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:29:9 [INFO] [stdout] | [INFO] [stdout] 29 | pub groupOrderID: u64, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `group_order_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `groupID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:30:9 [INFO] [stdout] | [INFO] [stdout] 30 | pub groupID: u64, [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `group_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `teamId` should have a snake case name [INFO] [stdout] --> src/api/football.rs:35:9 [INFO] [stdout] | [INFO] [stdout] 35 | pub teamId: u64, [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `team_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `teamName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:36:9 [INFO] [stdout] | [INFO] [stdout] 36 | pub teamName: String, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `team_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `shortName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:37:9 [INFO] [stdout] | [INFO] [stdout] 37 | pub shortName: String, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `short_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `teamIconUrl` should have a snake case name [INFO] [stdout] --> src/api/football.rs:38:9 [INFO] [stdout] | [INFO] [stdout] 38 | pub teamIconUrl: String, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `team_icon_url` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `teamGroupName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:39:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub teamGroupName: Option, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `team_group_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `resultID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:44:9 [INFO] [stdout] | [INFO] [stdout] 44 | pub resultID: u64, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `result_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `resultName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:45:9 [INFO] [stdout] | [INFO] [stdout] 45 | pub resultName: String, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `result_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `pointsTeam1` should have a snake case name [INFO] [stdout] --> src/api/football.rs:46:9 [INFO] [stdout] | [INFO] [stdout] 46 | pub pointsTeam1: u64, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `points_team1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `pointsTeam2` should have a snake case name [INFO] [stdout] --> src/api/football.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | pub pointsTeam2: u64, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `points_team2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `resultOrderID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:48:9 [INFO] [stdout] | [INFO] [stdout] 48 | pub resultOrderID: u64, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `result_order_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `resultTypeID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:49:9 [INFO] [stdout] | [INFO] [stdout] 49 | pub resultTypeID: u64, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `result_type_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `resultDescription` should have a snake case name [INFO] [stdout] --> src/api/football.rs:50:9 [INFO] [stdout] | [INFO] [stdout] 50 | pub resultDescription: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `result_description` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `goalID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:55:9 [INFO] [stdout] | [INFO] [stdout] 55 | pub goalID: u64, [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `goal_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `scoreTeam1` should have a snake case name [INFO] [stdout] --> src/api/football.rs:56:9 [INFO] [stdout] | [INFO] [stdout] 56 | pub scoreTeam1: u64, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `score_team1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `scoreTeam2` should have a snake case name [INFO] [stdout] --> src/api/football.rs:57:9 [INFO] [stdout] | [INFO] [stdout] 57 | pub scoreTeam2: u64, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `score_team2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchMinute` should have a snake case name [INFO] [stdout] --> src/api/football.rs:58:9 [INFO] [stdout] | [INFO] [stdout] 58 | pub matchMinute: u64, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `match_minute` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `goalGetterID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:59:9 [INFO] [stdout] | [INFO] [stdout] 59 | pub goalGetterID: u64, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `goal_getter_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `goalGetterName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:60:9 [INFO] [stdout] | [INFO] [stdout] 60 | pub goalGetterName: String, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `goal_getter_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `isPenalty` should have a snake case name [INFO] [stdout] --> src/api/football.rs:61:9 [INFO] [stdout] | [INFO] [stdout] 61 | pub isPenalty: bool, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `is_penalty` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `isOwnGoal` should have a snake case name [INFO] [stdout] --> src/api/football.rs:62:9 [INFO] [stdout] | [INFO] [stdout] 62 | pub isOwnGoal: bool, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `is_own_goal` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `isOvertime` should have a snake case name [INFO] [stdout] --> src/api/football.rs:63:9 [INFO] [stdout] | [INFO] [stdout] 63 | pub isOvertime: bool, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `is_overtime` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `locationID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:69:9 [INFO] [stdout] | [INFO] [stdout] 69 | pub locationID: u64, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `location_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `locationCity` should have a snake case name [INFO] [stdout] --> src/api/football.rs:70:9 [INFO] [stdout] | [INFO] [stdout] 70 | pub locationCity: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `location_city` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `locationStadium` should have a snake case name [INFO] [stdout] --> src/api/football.rs:71:9 [INFO] [stdout] | [INFO] [stdout] 71 | pub locationStadium: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `location_stadium` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `FileUpload` is never constructed [INFO] [stdout] --> src/http_endpoints.rs:54:12 [INFO] [stdout] | [INFO] [stdout] 54 | pub struct FileUpload { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `FileUpload` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `manual_hello` is never used [INFO] [stdout] --> src/http_endpoints.rs:124:14 [INFO] [stdout] | [INFO] [stdout] 124 | pub async fn manual_hello() -> impl Responder { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `save_file` is never used [INFO] [stdout] --> src/http_endpoints.rs:408:14 [INFO] [stdout] | [INFO] [stdout] 408 | pub async fn save_file(mut payload: Multipart, file_path: String) -> Option { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `show_status_bar` is never used [INFO] [stdout] --> src/led/led.rs:42:8 [INFO] [stdout] | [INFO] [stdout] 42 | pub fn show_status_bar( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `load_file` is never used [INFO] [stdout] --> src/led/weather.rs:275:4 [INFO] [stdout] | [INFO] [stdout] 275 | fn load_file(path: &str) -> std::io::Result> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `index` is never used [INFO] [stdout] --> src/leptos.rs:5:14 [INFO] [stdout] | [INFO] [stdout] 5 | pub async fn index() -> AcResult { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `outroute_js` is never used [INFO] [stdout] --> src/leptos.rs:11:14 [INFO] [stdout] | [INFO] [stdout] 11 | pub async fn outroute_js(req: HttpRequest) -> AcResult { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `outroute_wasm` is never used [INFO] [stdout] --> src/leptos.rs:16:14 [INFO] [stdout] | [INFO] [stdout] 16 | pub async fn outroute_wasm(req: HttpRequest) -> AcResult { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `outroute_css` is never used [INFO] [stdout] --> src/leptos.rs:21:14 [INFO] [stdout] | [INFO] [stdout] 21 | pub async fn outroute_css(req: HttpRequest) -> AcResult { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_path_to_dist_build` is never used [INFO] [stdout] --> src/leptos.rs:26:4 [INFO] [stdout] | [INFO] [stdout] 26 | fn get_path_to_dist_build(req:HttpRequest, file_ending: &str) -> PathBuf { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/main.rs:308:5 [INFO] [stdout] | [INFO] [stdout] 308 | dotenv::from_path("/home/pi/.config/ledcat/.env"); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 308 | let _ = dotenv::from_path("/home/pi/.config/ledcat/.env"); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/main.rs:342:5 [INFO] [stdout] | [INFO] [stdout] 342 | led_service(led_data.clone(), job_history.clone()).await; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 342 | let _ = led_service(led_data.clone(), job_history.clone()).await; [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `isBlocked` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:13:9 [INFO] [stdout] | [INFO] [stdout] 13 | pub isBlocked: String, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `is_blocked` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `startLcPosition` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:17:9 [INFO] [stdout] | [INFO] [stdout] 17 | pub startLcPosition: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `start_lc_position` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `startTimestamp` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 21 | pub startTimestamp: String, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `start_timestamp` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `routeRecommendation` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:24:9 [INFO] [stdout] | [INFO] [stdout] 24 | pub routeRecommendation: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `route_recommendation` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `lorryParkingFeatureIcons` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | pub lorryParkingFeatureIcons: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `lorry_parking_feature_icons` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `abnormalTrafficType` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 27 | pub abnormalTrafficType: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `abnormal_traffic_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `delayTimeValue` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:28:9 [INFO] [stdout] | [INFO] [stdout] 28 | pub delayTimeValue: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `delay_time_value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `averageSpeed` should have a snake case name [INFO] [stdout] --> src/api/autobahn.rs:29:9 [INFO] [stdout] | [INFO] [stdout] 29 | pub averageSpeed: Option, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `average_speed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Pollen` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | Pollen: DwdPollenContentPollen, [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `pollen` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Roggen` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 19 | Roggen: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `roggen` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Birke` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | Birke: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^ help: convert the identifier to snake case: `birke` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Hasel` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | Hasel: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^ help: convert the identifier to snake case: `hasel` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Ambrosia` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Ambrosia: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `ambrosia` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Graeser` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | Graeser: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `graeser` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Beifuss` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:24:5 [INFO] [stdout] | [INFO] [stdout] 24 | Beifuss: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `beifuss` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Esche` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:25:5 [INFO] [stdout] | [INFO] [stdout] 25 | Esche: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^^ help: convert the identifier to snake case: `esche` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `Erle` should have a snake case name [INFO] [stdout] --> src/api/dwd.rs:26:5 [INFO] [stdout] | [INFO] [stdout] 26 | Erle: DwdPollenContentPollenPreview, [INFO] [stdout] | ^^^^ help: convert the identifier to snake case: `erle` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `ISO3166_2_lvl4` should have a snake case name [INFO] [stdout] --> src/api/openstreetmap.rs:31:9 [INFO] [stdout] | [INFO] [stdout] 31 | pub ISO3166_2_lvl4: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `iso3166_2_lvl4` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastDaily` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:7:9 [INFO] [stdout] | [INFO] [stdout] 7 | pub forecastDaily: WeatherDailyForcast, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_daily` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastHourly` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:8:9 [INFO] [stdout] | [INFO] [stdout] 8 | pub forecastHourly: WeatherHourlyForcast, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_hourly` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `attributionURL` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:25:9 [INFO] [stdout] | [INFO] [stdout] 25 | pub attributionURL: String, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `attribution_url` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `expireTime` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:26:9 [INFO] [stdout] | [INFO] [stdout] 26 | pub expireTime: String, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `expire_time` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `readTime` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:29:9 [INFO] [stdout] | [INFO] [stdout] 29 | pub readTime: String, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `read_time` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `reportedTime` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:30:9 [INFO] [stdout] | [INFO] [stdout] 30 | pub reportedTime: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `reported_time` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sourceType` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:33:9 [INFO] [stdout] | [INFO] [stdout] 33 | pub sourceType: String, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `source_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastStart` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:38:9 [INFO] [stdout] | [INFO] [stdout] 38 | pub forecastStart: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_start` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastEnd` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:39:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub forecastEnd: String, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_end` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `conditionCode` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:40:9 [INFO] [stdout] | [INFO] [stdout] 40 | pub conditionCode: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `condition_code` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `maxUvIndex` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:41:9 [INFO] [stdout] | [INFO] [stdout] 41 | pub maxUvIndex: f32, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `max_uv_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `moonPhase` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:42:9 [INFO] [stdout] | [INFO] [stdout] 42 | pub moonPhase: String, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `moon_phase` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:45:9 [INFO] [stdout] | [INFO] [stdout] 45 | pub precipitationAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationChance` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:46:9 [INFO] [stdout] | [INFO] [stdout] 46 | pub precipitationChance: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_chance` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationType` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | pub precipitationType: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `snowfallAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:48:9 [INFO] [stdout] | [INFO] [stdout] 48 | pub snowfallAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `snowfall_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `solarMidnight` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:49:9 [INFO] [stdout] | [INFO] [stdout] 49 | pub solarMidnight: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `solar_midnight` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `solarNoon` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:50:9 [INFO] [stdout] | [INFO] [stdout] 50 | pub solarNoon: String, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `solar_noon` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunriseCivil` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:52:9 [INFO] [stdout] | [INFO] [stdout] 52 | pub sunriseCivil: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `sunrise_civil` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunriseNautical` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:53:9 [INFO] [stdout] | [INFO] [stdout] 53 | pub sunriseNautical: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `sunrise_nautical` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunriseAstronomical` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:54:9 [INFO] [stdout] | [INFO] [stdout] 54 | pub sunriseAstronomical: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `sunrise_astronomical` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunsetCivil` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:56:9 [INFO] [stdout] | [INFO] [stdout] 56 | pub sunsetCivil: String, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `sunset_civil` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunsetNautical` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:57:9 [INFO] [stdout] | [INFO] [stdout] 57 | pub sunsetNautical: String, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `sunset_nautical` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `sunsetAstronomical` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:58:9 [INFO] [stdout] | [INFO] [stdout] 58 | pub sunsetAstronomical: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `sunset_astronomical` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:59:9 [INFO] [stdout] | [INFO] [stdout] 59 | pub temperatureMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureMin` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:60:9 [INFO] [stdout] | [INFO] [stdout] 60 | pub temperatureMin: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_min` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windGustSpeedMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:61:9 [INFO] [stdout] | [INFO] [stdout] 61 | pub windGustSpeedMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_gust_speed_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windSpeedAvg` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:62:9 [INFO] [stdout] | [INFO] [stdout] 62 | pub windSpeedAvg: f32, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_speed_avg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windSpeedMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:63:9 [INFO] [stdout] | [INFO] [stdout] 63 | pub windSpeedMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_speed_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `daytimeForecast` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:64:9 [INFO] [stdout] | [INFO] [stdout] 64 | pub daytimeForecast: DayliForcast, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `daytime_forecast` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `overnightForecast` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:65:9 [INFO] [stdout] | [INFO] [stdout] 65 | pub overnightForecast: DayliForcast, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `overnight_forecast` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastStart` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:70:9 [INFO] [stdout] | [INFO] [stdout] 70 | pub forecastStart: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_start` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `cloudCover` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:71:9 [INFO] [stdout] | [INFO] [stdout] 71 | pub cloudCover: f32, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `cloud_cover` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `conditionCode` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:72:9 [INFO] [stdout] | [INFO] [stdout] 72 | pub conditionCode: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `condition_code` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:75:9 [INFO] [stdout] | [INFO] [stdout] 75 | pub precipitationAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationIntensity` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:76:9 [INFO] [stdout] | [INFO] [stdout] 76 | pub precipitationIntensity: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_intensity` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationChance` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:77:9 [INFO] [stdout] | [INFO] [stdout] 77 | pub precipitationChance: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_chance` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationType` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:78:9 [INFO] [stdout] | [INFO] [stdout] 78 | pub precipitationType: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `pressureTrend` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:80:9 [INFO] [stdout] | [INFO] [stdout] 80 | pub pressureTrend: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `pressure_trend` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `snowfallIntensity` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:81:9 [INFO] [stdout] | [INFO] [stdout] 81 | pub snowfallIntensity: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `snowfall_intensity` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `snowfallAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:82:9 [INFO] [stdout] | [INFO] [stdout] 82 | pub snowfallAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `snowfall_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureApparent` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:84:9 [INFO] [stdout] | [INFO] [stdout] 84 | pub temperatureApparent: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_apparent` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureDewPoint` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:85:9 [INFO] [stdout] | [INFO] [stdout] 85 | pub temperatureDewPoint: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_dew_point` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `uvIndex` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:86:9 [INFO] [stdout] | [INFO] [stdout] 86 | pub uvIndex: f32, [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `uv_index` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windDirection` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:88:9 [INFO] [stdout] | [INFO] [stdout] 88 | pub windDirection: f32, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_direction` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windGust` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:89:9 [INFO] [stdout] | [INFO] [stdout] 89 | pub windGust: f32, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `wind_gust` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windSpeed` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:90:9 [INFO] [stdout] | [INFO] [stdout] 90 | pub windSpeed: f32, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `wind_speed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastStart` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:95:9 [INFO] [stdout] | [INFO] [stdout] 95 | pub forecastStart: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_start` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `forecastEnd` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:96:9 [INFO] [stdout] | [INFO] [stdout] 96 | pub forecastEnd: String, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `forecast_end` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `cloudCover` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:97:9 [INFO] [stdout] | [INFO] [stdout] 97 | pub cloudCover: f32, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `cloud_cover` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `conditionCode` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:98:9 [INFO] [stdout] | [INFO] [stdout] 98 | pub conditionCode: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `condition_code` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:100:9 [INFO] [stdout] | [INFO] [stdout] 100 | pub precipitationAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationChance` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:101:9 [INFO] [stdout] | [INFO] [stdout] 101 | pub precipitationChance: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_chance` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `precipitationType` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:102:9 [INFO] [stdout] | [INFO] [stdout] 102 | pub precipitationType: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `precipitation_type` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `snowfallAmount` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:103:9 [INFO] [stdout] | [INFO] [stdout] 103 | pub snowfallAmount: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `snowfall_amount` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:104:9 [INFO] [stdout] | [INFO] [stdout] 104 | pub temperatureMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `temperatureMin` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:105:9 [INFO] [stdout] | [INFO] [stdout] 105 | pub temperatureMin: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `temperature_min` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windDirection` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:106:9 [INFO] [stdout] | [INFO] [stdout] 106 | pub windDirection: f32, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_direction` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windGustSpeedMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:107:9 [INFO] [stdout] | [INFO] [stdout] 107 | pub windGustSpeedMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_gust_speed_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windSpeed` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:108:9 [INFO] [stdout] | [INFO] [stdout] 108 | pub windSpeed: f32, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `wind_speed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `windSpeedMax` should have a snake case name [INFO] [stdout] --> src/api/weatherkit.rs:109:9 [INFO] [stdout] | [INFO] [stdout] 109 | pub windSpeedMax: f32, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `wind_speed_max` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:7:9 [INFO] [stdout] | [INFO] [stdout] 7 | pub matchID: u64, [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `match_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchDateTime` should have a snake case name [INFO] [stdout] --> src/api/football.rs:8:9 [INFO] [stdout] | [INFO] [stdout] 8 | pub matchDateTime: String, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `match_date_time` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `timeZoneID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:9:9 [INFO] [stdout] | [INFO] [stdout] 9 | pub timeZoneID: String, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `time_zone_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `leagueId` should have a snake case name [INFO] [stdout] --> src/api/football.rs:10:9 [INFO] [stdout] | [INFO] [stdout] 10 | pub leagueId: u64, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `league_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `leagueName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | pub leagueName: String, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `league_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `leagueSeason` should have a snake case name [INFO] [stdout] --> src/api/football.rs:12:9 [INFO] [stdout] | [INFO] [stdout] 12 | pub leagueSeason: u64, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `league_season` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `leagueShortcut` should have a snake case name [INFO] [stdout] --> src/api/football.rs:13:9 [INFO] [stdout] | [INFO] [stdout] 13 | pub leagueShortcut: String, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `league_shortcut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchDateTimeUTC` should have a snake case name [INFO] [stdout] --> src/api/football.rs:14:9 [INFO] [stdout] | [INFO] [stdout] 14 | pub matchDateTimeUTC: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `match_date_time_utc` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `lastUpdateDateTime` should have a snake case name [INFO] [stdout] --> src/api/football.rs:18:9 [INFO] [stdout] | [INFO] [stdout] 18 | pub lastUpdateDateTime: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `last_update_date_time` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchIsFinished` should have a snake case name [INFO] [stdout] --> src/api/football.rs:19:9 [INFO] [stdout] | [INFO] [stdout] 19 | pub matchIsFinished: bool, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `match_is_finished` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchResults` should have a snake case name [INFO] [stdout] --> src/api/football.rs:20:9 [INFO] [stdout] | [INFO] [stdout] 20 | pub matchResults: Vec, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `match_results` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `numberOfViewers` should have a snake case name [INFO] [stdout] --> src/api/football.rs:23:9 [INFO] [stdout] | [INFO] [stdout] 23 | pub numberOfViewers: u64, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `number_of_viewers` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `groupName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:28:9 [INFO] [stdout] | [INFO] [stdout] 28 | pub groupName: String, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `group_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `groupOrderID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:29:9 [INFO] [stdout] | [INFO] [stdout] 29 | pub groupOrderID: u64, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `group_order_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `groupID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:30:9 [INFO] [stdout] | [INFO] [stdout] 30 | pub groupID: u64, [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `group_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `teamId` should have a snake case name [INFO] [stdout] --> src/api/football.rs:35:9 [INFO] [stdout] | [INFO] [stdout] 35 | pub teamId: u64, [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `team_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `teamName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:36:9 [INFO] [stdout] | [INFO] [stdout] 36 | pub teamName: String, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `team_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `shortName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:37:9 [INFO] [stdout] | [INFO] [stdout] 37 | pub shortName: String, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `short_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `teamIconUrl` should have a snake case name [INFO] [stdout] --> src/api/football.rs:38:9 [INFO] [stdout] | [INFO] [stdout] 38 | pub teamIconUrl: String, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `team_icon_url` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `teamGroupName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:39:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub teamGroupName: Option, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `team_group_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `resultID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:44:9 [INFO] [stdout] | [INFO] [stdout] 44 | pub resultID: u64, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `result_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `resultName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:45:9 [INFO] [stdout] | [INFO] [stdout] 45 | pub resultName: String, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `result_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `pointsTeam1` should have a snake case name [INFO] [stdout] --> src/api/football.rs:46:9 [INFO] [stdout] | [INFO] [stdout] 46 | pub pointsTeam1: u64, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `points_team1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `pointsTeam2` should have a snake case name [INFO] [stdout] --> src/api/football.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | pub pointsTeam2: u64, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `points_team2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `resultOrderID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:48:9 [INFO] [stdout] | [INFO] [stdout] 48 | pub resultOrderID: u64, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `result_order_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `resultTypeID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:49:9 [INFO] [stdout] | [INFO] [stdout] 49 | pub resultTypeID: u64, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `result_type_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `resultDescription` should have a snake case name [INFO] [stdout] --> src/api/football.rs:50:9 [INFO] [stdout] | [INFO] [stdout] 50 | pub resultDescription: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `result_description` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `goalID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:55:9 [INFO] [stdout] | [INFO] [stdout] 55 | pub goalID: u64, [INFO] [stdout] | ^^^^^^ help: convert the identifier to snake case: `goal_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `scoreTeam1` should have a snake case name [INFO] [stdout] --> src/api/football.rs:56:9 [INFO] [stdout] | [INFO] [stdout] 56 | pub scoreTeam1: u64, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `score_team1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `scoreTeam2` should have a snake case name [INFO] [stdout] --> src/api/football.rs:57:9 [INFO] [stdout] | [INFO] [stdout] 57 | pub scoreTeam2: u64, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `score_team2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `matchMinute` should have a snake case name [INFO] [stdout] --> src/api/football.rs:58:9 [INFO] [stdout] | [INFO] [stdout] 58 | pub matchMinute: u64, [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to snake case: `match_minute` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `goalGetterID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:59:9 [INFO] [stdout] | [INFO] [stdout] 59 | pub goalGetterID: u64, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `goal_getter_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `goalGetterName` should have a snake case name [INFO] [stdout] --> src/api/football.rs:60:9 [INFO] [stdout] | [INFO] [stdout] 60 | pub goalGetterName: String, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `goal_getter_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `isPenalty` should have a snake case name [INFO] [stdout] --> src/api/football.rs:61:9 [INFO] [stdout] | [INFO] [stdout] 61 | pub isPenalty: bool, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `is_penalty` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `isOwnGoal` should have a snake case name [INFO] [stdout] --> src/api/football.rs:62:9 [INFO] [stdout] | [INFO] [stdout] 62 | pub isOwnGoal: bool, [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `is_own_goal` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `isOvertime` should have a snake case name [INFO] [stdout] --> src/api/football.rs:63:9 [INFO] [stdout] | [INFO] [stdout] 63 | pub isOvertime: bool, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `is_overtime` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `locationID` should have a snake case name [INFO] [stdout] --> src/api/football.rs:69:9 [INFO] [stdout] | [INFO] [stdout] 69 | pub locationID: u64, [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `location_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `locationCity` should have a snake case name [INFO] [stdout] --> src/api/football.rs:70:9 [INFO] [stdout] | [INFO] [stdout] 70 | pub locationCity: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to snake case: `location_city` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `locationStadium` should have a snake case name [INFO] [stdout] --> src/api/football.rs:71:9 [INFO] [stdout] | [INFO] [stdout] 71 | pub locationStadium: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `location_stadium` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 3m 37s [INFO] running `Command { std: "docker" "inspect" "f7408661307ccd4399394116a0b94a5ebce14cb4fb5aa46eb536edf4950b6c49", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f7408661307ccd4399394116a0b94a5ebce14cb4fb5aa46eb536edf4950b6c49", kill_on_drop: false }` [INFO] [stdout] f7408661307ccd4399394116a0b94a5ebce14cb4fb5aa46eb536edf4950b6c49