[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 try#44f3504e96c944ae54fc72b5f5008f53f7eda001 for pr-136776
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBrownymister%2Fled-cat-server" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/Brownymister/led-cat-server on toolchain 44f3504e96c944ae54fc72b5f5008f53f7eda001
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "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-5-tc2/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" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:3959728d45483eb673ba100a951a6b9f5012970368db2a9e08e0ac9b67c8a5ad" "/opt/rustwide/cargo-home/bin/cargo" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] e949b2691c38dd088b93a4492aec4c42b6a4d16f84c68f87bb4748914e8b9774
[INFO] running `Command { std: "docker" "start" "-a" "e949b2691c38dd088b93a4492aec4c42b6a4d16f84c68f87bb4748914e8b9774", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "e949b2691c38dd088b93a4492aec4c42b6a4d16f84c68f87bb4748914e8b9774", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e949b2691c38dd088b93a4492aec4c42b6a4d16f84c68f87bb4748914e8b9774", kill_on_drop: false }`
[INFO] [stdout] e949b2691c38dd088b93a4492aec4c42b6a4d16f84c68f87bb4748914e8b9774
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:3959728d45483eb673ba100a951a6b9f5012970368db2a9e08e0ac9b67c8a5ad" "/opt/rustwide/cargo-home/bin/cargo" "+44f3504e96c944ae54fc72b5f5008f53f7eda001" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cad75b1b38c10e8829941504d003965cc6dda07ecb243e3bc49ef6e08f4cb3a3
[INFO] running `Command { std: "docker" "start" "-a" "cad75b1b38c10e8829941504d003965cc6dda07ecb243e3bc49ef6e08f4cb3a3", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.78
[INFO] [stderr]    Compiling libc v0.2.152
[INFO] [stderr]    Compiling serde v1.0.196
[INFO] [stderr]     Checking smallvec v1.13.1
[INFO] [stderr]     Checking futures-io v0.3.30
[INFO] [stderr]     Checking futures-task v0.3.30
[INFO] [stderr]     Checking futures-channel v0.3.30
[INFO] [stderr]     Checking indexmap v2.2.1
[INFO] [stderr]    Compiling wasm-bindgen-shared v0.2.93
[INFO] [stderr]    Compiling thiserror v1.0.57
[INFO] [stderr]    Compiling bumpalo v3.14.0
[INFO] [stderr]    Compiling wasm-bindgen v0.2.93
[INFO] [stderr]    Compiling serde_json v1.0.113
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]     Checking bitflags v2.4.2
[INFO] [stderr]    Compiling tracing-core v0.1.32
[INFO] [stderr]    Compiling unicode-xid v0.2.6
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling memchr v2.7.1
[INFO] [stderr]     Checking flate2 v1.0.28
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]     Checking half v2.3.1
[INFO] [stderr]    Compiling anyhow v1.0.80
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling proc-macro2-diagnostics v0.10.1
[INFO] [stderr]    Compiling xxhash-rust v0.8.12
[INFO] [stderr]    Compiling az v1.2.1
[INFO] [stderr]    Compiling time-macros v0.2.18
[INFO] [stderr]    Compiling unicase v2.7.0
[INFO] [stderr]    Compiling slotmap v1.0.7
[INFO] [stderr]    Compiling openssl v0.10.64
[INFO] [stderr]     Checking cpufeatures v0.2.12
[INFO] [stderr]     Checking ciborium-io v0.2.2
[INFO] [stderr]    Compiling camino v1.1.9
[INFO] [stderr]    Compiling lock_api v0.4.11
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking http v1.1.0
[INFO] [stderr]    Compiling aho-corasick v1.1.2
[INFO] [stderr]    Compiling convert_case v0.6.0
[INFO] [stderr]     Checking ciborium-ll v0.2.2
[INFO] [stderr]     Checking winnow v0.6.18
[INFO] [stderr]    Compiling hashbrown v0.14.3
[INFO] [stderr]    Compiling interpolator v0.5.0
[INFO] [stderr]    Compiling collection_literals v1.0.1
[INFO] [stderr]    Compiling native-tls v0.2.11
[INFO] [stderr]    Compiling prettyplease v0.2.17
[INFO] [stderr]    Compiling strsim v0.10.0
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking parking_lot_core v0.9.9
[INFO] [stderr]    Compiling quote v1.0.35
[INFO] [stderr]    Compiling jobserver v0.1.27
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking signal-hook-registry v1.4.1
[INFO] [stderr]    Compiling syn v2.0.48
[INFO] [stderr]    Compiling cc v1.0.83
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking socket2 v0.5.5
[INFO] [stderr]     Checking getrandom v0.2.12
[INFO] [stderr]    Compiling proc-macro-utils v0.8.0
[INFO] [stderr]    Compiling proc-macro-utils v0.10.0
[INFO] [stderr]     Checking float-cmp v0.9.0
[INFO] [stderr]    Compiling const_format_proc_macros v0.2.33
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]    Compiling proc-macro-error-attr2 v2.0.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking ahash v0.8.7
[INFO] [stderr]    Compiling manyhow-macros v0.10.4
[INFO] [stderr]    Compiling regex-automata v0.4.5
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking dashmap v5.5.3
[INFO] [stderr]    Compiling const_format v0.2.33
[INFO] [stderr]     Checking rayon v1.8.1
[INFO] [stderr]     Checking send_wrapper v0.6.0
[INFO] [stderr]     Checking time v0.3.36
[INFO] [stderr]    Compiling rustversion v1.0.14
[INFO] [stderr]     Checking self_cell v1.0.4
[INFO] [stderr]    Compiling openssl-src v300.2.1+3.2.0
[INFO] [stderr]     Checking embedded-graphics-core v0.4.0
[INFO] [stderr]    Compiling utf8-width v0.1.7
[INFO] [stderr]    Compiling either v1.9.0
[INFO] [stderr]    Compiling rustix v0.38.31
[INFO] [stderr]     Checking micromath v2.1.0
[INFO] [stderr]    Compiling html-escape v0.2.13
[INFO] [stderr]    Compiling uuid v1.7.0
[INFO] [stderr]    Compiling proc-macro-error2 v2.0.1
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling itertools v0.12.1
[INFO] [stderr]     Checking http-body v0.4.6
[INFO] [stderr]     Checking spin v0.9.8
[INFO] [stderr]     Checking weezl v0.1.8
[INFO] [stderr]     Checking tower-service v0.3.2
[INFO] [stderr]     Checking pathdiff v0.2.1
[INFO] [stderr]     Checking embedded-graphics v0.8.1
[INFO] [stderr]     Checking linux-raw-sys v0.4.13
[INFO] [stderr]     Checking destructure_traitobject v0.2.0
[INFO] [stderr]    Compiling v_htmlescape v0.15.8
[INFO] [stderr]     Checking unsafe-any-ors v1.0.0
[INFO] [stderr]     Checking flume v0.11.0
[INFO] [stderr]    Compiling zstd-sys v2.0.9+zstd.1.5.5
[INFO] [stderr]    Compiling openssl-sys v0.9.101
[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 parse-size v1.0.0
[INFO] [stderr]     Checking fastrand v2.0.1
[INFO] [stderr]     Checking iana-time-zone v0.1.60
[INFO] [stderr]     Checking bytemuck v1.14.3
[INFO] [stderr]     Checking drain_filter_polyfill v0.1.3
[INFO] [stderr]     Checking lebe v0.5.2
[INFO] [stderr]     Checking unsafe-libyaml v0.2.10
[INFO] [stderr]     Checking color_quant v1.1.0
[INFO] [stderr]     Checking inventory v0.3.15
[INFO] [stderr]     Checking pad-adapter v0.1.1
[INFO] [stderr]     Checking chrono v0.4.38
[INFO] [stderr]     Checking gif v0.12.0
[INFO] [stderr]     Checking qoi v0.4.1
[INFO] [stderr]     Checking png v0.17.11
[INFO] [stderr]     Checking exr v1.72.0
[INFO] [stderr]     Checking typemap-ors v1.0.0
[INFO] [stderr]     Checking memmap2 v0.9.4
[INFO] [stderr]    Compiling regex v1.10.3
[INFO] [stderr]     Checking cookie v0.16.2
[INFO] [stderr]     Checking thread-id v4.2.1
[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 arc-swap v1.6.0
[INFO] [stderr]     Checking ipnet v2.9.0
[INFO] [stderr]     Checking object-chain v0.1.3
[INFO] [stderr]     Checking humantime v2.1.0
[INFO] [stderr]     Checking log-mdc v0.1.0
[INFO] [stderr]     Checking jpeg-decoder v0.3.1
[INFO] [stderr]     Checking http-range v0.1.5
[INFO] [stderr]     Checking sysinfo v0.30.5
[INFO] [stderr]     Checking embedded-text v0.7.2
[INFO] [stderr]     Checking tinytga v0.5.0
[INFO] [stderr]     Checking dotenv v0.15.0
[INFO] [stderr]    Compiling derive_more v0.99.17
[INFO] [stderr]    Compiling derivative v2.2.0
[INFO] [stderr]     Checking tempfile v3.10.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 wasm-bindgen-macro-support v0.2.93
[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]     Checking futures-util v0.3.30
[INFO] [stderr]    Compiling syn_derive v0.1.8
[INFO] [stderr]    Compiling derive-where v1.2.7
[INFO] [stderr]    Compiling actix-macros v0.2.4
[INFO] [stderr]    Compiling server_fn_macro_default v0.6.15
[INFO] [stderr]    Compiling tracing v0.1.40
[INFO] [stderr]    Compiling quote-use v0.8.4
[INFO] [stderr]    Compiling darling_macro v0.20.5
[INFO] [stderr]    Compiling attribute-derive-macro v0.9.2
[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]    Compiling darling v0.20.5
[INFO] [stderr]     Checking image v0.24.8
[INFO] [stderr]    Compiling actix-multipart-derive v0.6.1
[INFO] [stderr]    Compiling rstml v0.11.2
[INFO] [stderr]    Compiling wasm-bindgen-macro v0.2.93
[INFO] [stderr]     Checking pin-project v1.1.5
[INFO] [stderr]     Checking js-sys v0.3.70
[INFO] [stderr]    Compiling attribute-derive v0.9.2
[INFO] [stderr]     Checking typed-builder v0.18.2
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]    Compiling zstd-safe v7.0.0
[INFO] [stderr]     Checking zstd v0.13.0
[INFO] [stderr]     Checking log v0.4.20
[INFO] [stderr]     Checking serde_spanned v0.6.7
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking toml_datetime v0.6.8
[INFO] [stderr]     Checking serde_qs v0.12.0
[INFO] [stderr]     Checking oco_ref v0.1.1
[INFO] [stderr]     Checking ciborium v0.2.2
[INFO] [stderr]     Checking argh_shared v0.1.12
[INFO] [stderr]     Checking serde_yaml v0.9.32
[INFO] [stderr]     Checking serde-value v0.7.0
[INFO] [stderr]     Checking serde_plain v1.0.2
[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]     Checking actix-router v0.5.2
[INFO] [stderr]     Checking tokio v1.38.0
[INFO] [stderr]    Compiling leptos_hot_reload v0.6.15
[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 argh_derive v0.1.12
[INFO] [stderr]     Checking log4rs v1.3.0
[INFO] [stderr]    Compiling actix-web-codegen v4.2.2
[INFO] [stderr]    Compiling leptos_macro v0.6.15
[INFO] [stderr]     Checking toml v0.8.19
[INFO] [stderr]     Checking argh v0.1.12
[INFO] [stderr]     Checking rpi-led-panel v0.5.1
[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 actix-files v0.6.6
[INFO] [stderr]     Checking actix-cors v0.7.0
[INFO] [stderr]     Checking actix-multipart v0.6.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_dom v0.6.15
[INFO] [stderr]     Checking leptos_server v0.6.15
[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 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 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 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: `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 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 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: `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 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: `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: `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: `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 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 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 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 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: `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 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 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: `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 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: `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: `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: `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: `job_history`
[INFO] [stdout]    --> src/main.rs:230:53
[INFO] [stdout]     |
[INFO] [stdout] 230 | async fn led_service(led_data: Arc<Mutex<LedData>>, job_history: Arc<Mutex<JobHistory>>) -> 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: `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: `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: 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: `job_history`
[INFO] [stdout]    --> src/main.rs:230:53
[INFO] [stdout]     |
[INFO] [stdout] 230 | async fn led_service(led_data: Arc<Mutex<LedData>>, job_history: Arc<Mutex<JobHistory>>) -> 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: `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: 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: 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: `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: 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<Canvas>,
[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<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<Canvas>,
[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<Canvas>,
[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<crate::AppState>) -> 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: 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: `req`
[INFO] [stdout]    --> src/http_endpoints.rs:400:25
[INFO] [stdout]     |
[INFO] [stdout] 400 | pub async fn delete_job(req: HttpRequest, data: web::Data<crate::AppState>) -> impl Responder {
[INFO] [stdout]     |                         ^^^ help: if this is intentional, prefix it with an underscore: `_req`
[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: `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: 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: 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: `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: `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: 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<crate::AppState>) -> impl Responder {
[INFO] [stdout]     |                                                      ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[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: 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: 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: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: 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: 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: 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: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: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: 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<crate::AppState>) -> impl Responder {
[INFO] [stdout]     |                                                      ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[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: `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: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: 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: 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: 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: 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: `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: 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: `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<DateTime<Utc>>,
[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 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: `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<DateTime<Utc>>,
[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<bool> {
[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<Vec<u8>> {
[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<NamedFile> {
[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<NamedFile> {
[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<NamedFile> {
[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<NamedFile> {
[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<String>,
[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<String>,
[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<String>,
[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<String>,
[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<String>,
[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<String>,
[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<String>,
[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<String>,
[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<MatchResult>,
[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<String>,
[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<bool> {
[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<Vec<u8>> {
[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<NamedFile> {
[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<NamedFile> {
[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<NamedFile> {
[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<NamedFile> {
[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<String>,
[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<String>,
[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<String>,
[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<String>,
[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<String>,
[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<String>,
[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<String>,
[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<String>,
[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<MatchResult>,
[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<String>,
[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 1m 36s
[INFO] running `Command { std: "docker" "inspect" "cad75b1b38c10e8829941504d003965cc6dda07ecb243e3bc49ef6e08f4cb3a3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cad75b1b38c10e8829941504d003965cc6dda07ecb243e3bc49ef6e08f4cb3a3", kill_on_drop: false }`
[INFO] [stdout] cad75b1b38c10e8829941504d003965cc6dda07ecb243e3bc49ef6e08f4cb3a3
