[INFO] cloning repository https://github.com/naiwwws/ipc_tracking [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/naiwwws/ipc_tracking" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnaiwwws%2Fipc_tracking", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnaiwwws%2Fipc_tracking'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 3962def8b4fe6fdddff9c42e0fb840f2b7ec6178 [INFO] testing naiwwws/ipc_tracking against try#16fbf98f22730e073c09e7b03f0eafb87a295545 for pr-145628 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnaiwwws%2Fipc_tracking" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/naiwwws/ipc_tracking [INFO] finished tweaking git repo https://github.com/naiwwws/ipc_tracking [INFO] tweaked toml for git repo https://github.com/naiwwws/ipc_tracking written to /workspace/builds/worker-5-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/naiwwws/ipc_tracking on toolchain 16fbf98f22730e073c09e7b03f0eafb87a295545 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+16fbf98f22730e073c09e7b03f0eafb87a295545" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/naiwwws/ipc_tracking 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" "+16fbf98f22730e073c09e7b03f0eafb87a295545" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] warning: /workspace/builds/worker-5-tc2/source/Cargo.toml: unused manifest key: target.aarch64-unknown-linux-gnu.ar [INFO] [stderr] warning: /workspace/builds/worker-5-tc2/source/Cargo.toml: unused manifest key: target.aarch64-unknown-linux-gnu.linker [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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+16fbf98f22730e073c09e7b03f0eafb87a295545" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] dd09a6c1dc3ea53665cc03cade5bb91c133ee02487c211a84bd6604e13809292 [INFO] running `Command { std: "docker" "start" "-a" "dd09a6c1dc3ea53665cc03cade5bb91c133ee02487c211a84bd6604e13809292", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "dd09a6c1dc3ea53665cc03cade5bb91c133ee02487c211a84bd6604e13809292", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "dd09a6c1dc3ea53665cc03cade5bb91c133ee02487c211a84bd6604e13809292", kill_on_drop: false }` [INFO] [stdout] dd09a6c1dc3ea53665cc03cade5bb91c133ee02487c211a84bd6604e13809292 [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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+16fbf98f22730e073c09e7b03f0eafb87a295545" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 8690094c4d0480b8c1ba4a5213ce8578a745f458515604c26a7e17501cd106c0 [INFO] running `Command { std: "docker" "start" "-a" "8690094c4d0480b8c1ba4a5213ce8578a745f458515604c26a7e17501cd106c0", kill_on_drop: false }` [INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: unused manifest key: target.aarch64-unknown-linux-gnu.ar [INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: unused manifest key: target.aarch64-unknown-linux-gnu.linker [INFO] [stderr] Compiling libc v0.2.163 [INFO] [stderr] Compiling cfg-if v1.0.1 [INFO] [stderr] Compiling pin-project-lite v0.2.16 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling scopeguard v1.2.0 [INFO] [stderr] Compiling lock_api v0.4.13 [INFO] [stderr] Compiling syn v2.0.103 [INFO] [stderr] Compiling futures-core v0.3.31 [INFO] [stderr] Compiling log v0.4.27 [INFO] [stderr] Compiling bytes v1.10.1 [INFO] [stderr] Compiling stable_deref_trait v1.2.0 [INFO] [stderr] Compiling parking_lot_core v0.9.11 [INFO] [stderr] Compiling once_cell v1.21.3 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling futures-sink v0.3.31 [INFO] [stderr] Compiling serde v1.0.219 [INFO] [stderr] Compiling memchr v2.7.5 [INFO] [stderr] Compiling foldhash v0.1.5 [INFO] [stderr] Compiling itoa v1.0.15 [INFO] [stderr] Compiling tracing-core v0.1.34 [INFO] [stderr] Compiling typenum v1.18.0 [INFO] [stderr] Compiling allocator-api2 v0.2.21 [INFO] [stderr] Compiling writeable v0.6.1 [INFO] [stderr] Compiling litemap v0.8.0 [INFO] [stderr] Compiling equivalent v1.0.2 [INFO] [stderr] Compiling hashbrown v0.15.4 [INFO] [stderr] Compiling generic-array v0.14.7 [INFO] [stderr] Compiling pin-utils v0.1.0 [INFO] [stderr] Compiling futures-io v0.3.31 [INFO] [stderr] Compiling mio v1.0.4 [INFO] [stderr] Compiling socket2 v0.5.8 [INFO] [stderr] Compiling parking_lot v0.12.4 [INFO] [stderr] Compiling signal-hook-registry v1.4.5 [INFO] [stderr] Compiling futures-task v0.3.31 [INFO] [stderr] Compiling slab v0.4.10 [INFO] [stderr] Compiling getrandom v0.3.3 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling icu_normalizer_data v2.0.0 [INFO] [stderr] Compiling icu_properties_data v2.0.1 [INFO] [stderr] Compiling openssl-src v300.5.1+3.5.1 [INFO] [stderr] Compiling zeroize v1.8.1 [INFO] [stderr] Compiling openssl-sys v0.9.109 [INFO] [stderr] Compiling rustls-pki-types v1.12.0 [INFO] [stderr] Compiling indexmap v2.9.0 [INFO] [stderr] Compiling crossbeam-utils v0.8.21 [INFO] [stderr] Compiling libsqlite3-sys v0.30.1 [INFO] [stderr] Compiling fnv v1.0.7 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling bitflags v2.9.1 [INFO] [stderr] Compiling percent-encoding v2.3.1 [INFO] [stderr] Compiling libm v0.2.15 [INFO] [stderr] Compiling http v0.2.12 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling crypto-common v0.1.6 [INFO] [stderr] Compiling block-buffer v0.10.4 [INFO] [stderr] Compiling getrandom v0.2.16 [INFO] [stderr] Compiling untrusted v0.9.0 [INFO] [stderr] Compiling form_urlencoded v1.2.1 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.0 [INFO] [stderr] Compiling zerovec-derive v0.11.1 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling tracing-attributes v0.1.30 [INFO] [stderr] Compiling tokio-macros v2.4.0 [INFO] [stderr] Compiling thiserror-impl v2.0.12 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.0 [INFO] [stderr] Compiling zerovec v0.11.2 [INFO] [stderr] Compiling tokio v1.42.1 [INFO] [stderr] Compiling zerotrie v0.2.2 [INFO] [stderr] Compiling tracing v0.1.41 [INFO] [stderr] Compiling tinystr v0.8.1 [INFO] [stderr] Compiling potential_utf v0.1.2 [INFO] [stderr] Compiling icu_locale_core v2.0.0 [INFO] [stderr] Compiling icu_collections v2.0.0 [INFO] [stderr] Compiling icu_provider v2.0.0 [INFO] [stderr] Compiling icu_properties v2.0.1 [INFO] [stderr] Compiling icu_normalizer v2.0.0 [INFO] [stderr] Compiling tokio-util v0.7.15 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling cpufeatures v0.2.17 [INFO] [stderr] Compiling utf8_iter v1.0.4 [INFO] [stderr] Compiling zerocopy v0.8.26 [INFO] [stderr] Compiling httparse v1.10.1 [INFO] [stderr] Compiling idna v1.0.3 [INFO] [stderr] Compiling rustls-webpki v0.103.4 [INFO] [stderr] Compiling rustls v0.23.31 [INFO] [stderr] Compiling concurrent-queue v2.5.0 [INFO] [stderr] Compiling webpki-roots v1.0.2 [INFO] [stderr] Compiling thiserror v2.0.12 [INFO] [stderr] Compiling foreign-types-shared v0.1.1 [INFO] [stderr] Compiling crc-catalog v2.4.0 [INFO] [stderr] Compiling subtle v2.6.1 [INFO] [stderr] Compiling iana-time-zone v0.1.63 [INFO] [stderr] Compiling openssl v0.10.73 [INFO] [stderr] Compiling ryu v1.0.20 [INFO] [stderr] Compiling parking v2.2.1 [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling event-listener v5.4.0 [INFO] [stderr] Compiling chrono v0.4.41 [INFO] [stderr] Compiling crc v3.3.0 [INFO] [stderr] Compiling foreign-types v0.3.2 [INFO] [stderr] Compiling webpki-roots v0.26.11 [INFO] [stderr] Compiling futures-intrusive v0.5.0 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Compiling url v2.5.4 [INFO] [stderr] Compiling tokio-stream v0.1.17 [INFO] [stderr] Compiling hashlink v0.10.0 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling crossbeam-queue v0.3.12 [INFO] [stderr] Compiling spin v0.9.8 [INFO] [stderr] Compiling futures-channel v0.3.31 [INFO] [stderr] Compiling uuid v1.17.0 [INFO] [stderr] Compiling local-waker v0.1.4 [INFO] [stderr] Compiling base64 v0.22.1 [INFO] [stderr] Compiling httpdate v1.0.3 [INFO] [stderr] Compiling crc32fast v1.5.0 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling sqlx-core v0.8.6 [INFO] [stderr] Compiling flume v0.11.1 [INFO] [stderr] Compiling futures-executor v0.3.31 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling atoi v2.0.0 [INFO] [stderr] Compiling rand_core v0.9.3 [INFO] [stderr] Compiling adler2 v2.0.1 [INFO] [stderr] Compiling openssl-probe v0.1.6 [INFO] [stderr] Compiling try-lock v0.2.5 [INFO] [stderr] Compiling want v0.3.1 [INFO] [stderr] Compiling derive_more-impl v2.0.1 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling serde_json v1.0.140 [INFO] [stderr] Compiling actix-utils v3.0.1 [INFO] [stderr] Compiling h2 v0.3.27 [INFO] [stderr] Compiling actix-rt v2.10.0 [INFO] [stderr] Compiling http-body v0.4.6 [INFO] [stderr] Compiling sqlx-sqlite v0.8.6 [INFO] [stderr] Compiling bytestring v1.4.0 [INFO] [stderr] Compiling actix-service v2.0.3 [INFO] [stderr] Compiling encoding_rs v0.8.35 [INFO] [stderr] Compiling mime v0.3.17 [INFO] [stderr] Compiling tower-service v0.3.3 [INFO] [stderr] Compiling byteorder v1.5.0 [INFO] [stderr] Compiling hex v0.4.3 [INFO] [stderr] Compiling regex-lite v0.1.6 [INFO] [stderr] Compiling heapless v0.8.0 [INFO] [stderr] Compiling dotenvy v0.15.7 [INFO] [stderr] Compiling powerfmt v0.2.0 [INFO] [stderr] Compiling sqlx-macros-core v0.8.6 [INFO] [stderr] Compiling deranged v0.4.0 [INFO] [stderr] Compiling actix-router v0.5.3 [INFO] [stderr] Compiling hyper v0.14.32 [INFO] [stderr] Compiling hash32 v0.3.1 [INFO] [stderr] Compiling derive_more v2.0.1 [INFO] [stderr] Compiling flate2 v1.1.2 [INFO] [stderr] Compiling rand v0.9.1 [INFO] [stderr] Compiling local-channel v0.1.5 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling sha1 v0.10.6 [INFO] [stderr] Compiling actix-codec v0.5.2 [INFO] [stderr] Compiling toml_write v0.1.2 [INFO] [stderr] Compiling minimal-lexical v0.2.1 [INFO] [stderr] Compiling language-tags v0.3.2 [INFO] [stderr] Compiling base64 v0.21.7 [INFO] [stderr] Compiling anstyle v1.0.11 [INFO] [stderr] Compiling winnow v0.7.12 [INFO] [stderr] Compiling bitflags v1.3.2 [INFO] [stderr] Compiling num-conv v0.1.0 [INFO] [stderr] Compiling clap_lex v0.7.5 [INFO] [stderr] Compiling time-core v0.1.4 [INFO] [stderr] Compiling time v0.3.41 [INFO] [stderr] Compiling toml_edit v0.22.27 [INFO] [stderr] Compiling clap_builder v4.5.40 [INFO] [stderr] Compiling nix v0.26.4 [INFO] [stderr] Compiling anyhow v1.0.98 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling actix-http v3.11.0 [INFO] [stderr] Compiling rustls-pemfile v1.0.4 [INFO] [stderr] Compiling nom v7.1.3 [INFO] [stderr] Compiling actix-web-codegen v4.3.0 [INFO] [stderr] Compiling sqlx-macros v0.8.6 [INFO] [stderr] Compiling actix-server v2.5.1 [INFO] [stderr] Compiling clap_derive v4.5.40 [INFO] [stderr] Compiling unescaper v0.1.6 [INFO] [stderr] Compiling actix-macros v0.2.4 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling is-terminal v0.4.16 [INFO] [stderr] Compiling arrayvec v0.7.6 [INFO] [stderr] Compiling impl-more v0.1.9 [INFO] [stderr] Compiling sync_wrapper v0.1.2 [INFO] [stderr] Compiling termcolor v1.4.1 [INFO] [stderr] Compiling ipnet v2.11.0 [INFO] [stderr] Compiling env_logger v0.10.2 [INFO] [stderr] Compiling actix-web v4.10.2 [INFO] [stderr] Compiling nmea v0.7.0 [INFO] [stderr] Compiling serialport v4.7.3-alpha.0 (/opt/rustwide/workdir/serialport-rs) [INFO] [stderr] Compiling clap v4.5.40 [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling async-trait v0.1.88 [INFO] [stderr] Compiling base64 v0.13.1 [INFO] [stderr] Compiling sqlx v0.8.6 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling hyper-tls v0.5.0 [INFO] [stderr] Compiling reqwest v0.11.27 [INFO] [stderr] Compiling ipc_dev_rust v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused imports: `DateTime` and `Utc` [INFO] [stdout] --> src/config/settings.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/config/settings.rs:3:31 [INFO] [stdout] | [INFO] [stdout] 3 | use log::{debug, error, info, warn}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/config/mqtt_handler.rs:1:17 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{info, warn, error}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `timeout` [INFO] [stdout] --> src/devices/gps/gps_service.rs:3:39 [INFO] [stdout] | [INFO] [stdout] 3 | use tokio::time::{Duration, interval, timeout}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::path::Path` [INFO] [stdout] --> src/services/data_service.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::path::Path; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::fs` [INFO] [stdout] --> src/services/data_service.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use tokio::fs; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `interval` and `sleep` [INFO] [stdout] --> src/services/data_service.rs:6:19 [INFO] [stdout] | [INFO] [stdout] 6 | use tokio::time::{sleep, interval, Duration}; [INFO] [stdout] | ^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::mpsc` [INFO] [stdout] --> src/services/data_service.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use tokio::sync::mpsc; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::json` [INFO] [stdout] --> src/services/data_service.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use serde_json::json; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `debug` and `warn` [INFO] [stdout] --> src/services/database_service.rs:1:24 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{info, error, warn, debug}; [INFO] [stdout] | ^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Duration` and `interval` [INFO] [stdout] --> src/services/database_service.rs:4:19 [INFO] [stdout] | [INFO] [stdout] 4 | use tokio::time::{interval, Duration}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/services/database_service.rs:5:14 [INFO] [stdout] | [INFO] [stdout] 5 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/services/api_service.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use log::{info, error, warn}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `MtwsField` [INFO] [stdout] --> src/services/mtws_service.rs:13:43 [INFO] [stdout] | [INFO] [stdout] 13 | use crate::storage::models::{MtwsPayload, MtwsField}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::Utc` [INFO] [stdout] --> src/output/formatters.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::Utc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::Value` [INFO] [stdout] --> src/output/formatters.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use serde_json::Value; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/output/formatters.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::utils::error::ModbusError` [INFO] [stdout] --> src/output/formatters.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::utils::error::ModbusError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/output/raw_sender.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use log::{info, error}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt` [INFO] [stdout] --> src/utils/error.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::fmt; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RpmReading` [INFO] [stdout] --> src/storage/sqlite_manager.rs:8:64 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::storage::models::{FlowmeterReading, FlowmeterStats, RpmReading, CombinedDeviceReading}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/storage/models.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `total_channels` [INFO] [stdout] --> src/services/data_service.rs:419:26 [INFO] [stdout] | [INFO] [stdout] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_total_channels` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `thresholds` [INFO] [stdout] --> src/services/data_service.rs:419:42 [INFO] [stdout] | [INFO] [stdout] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_thresholds` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Row` [INFO] [stdout] --> src/storage/sqlite_manager.rs:3:24 [INFO] [stdout] | [INFO] [stdout] 3 | use sqlx::{SqlitePool, Row}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/config/settings.rs:607:50 [INFO] [stdout] | [INFO] [stdout] 607 | pub fn create_new_device(&self, address: u8, device_id: String, device_type: String, name: String, location: String) -> DeviceConfig { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/config/dynamic_manager.rs:511:13 [INFO] [stdout] | [INFO] [stdout] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/config/dynamic_manager.rs:511:13 [INFO] [stdout] | [INFO] [stdout] 233 | ConfigTarget::System => { [INFO] [stdout] | -------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 264 | ConfigTarget::Monitoring => { [INFO] [stdout] | ------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 317 | ConfigTarget::Serial => { [INFO] [stdout] | -------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 344 | ConfigTarget::Gps => { [INFO] [stdout] | ----------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stdout] | ^ ...and 3 other patterns collectively make this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `mtws` [INFO] [stdout] --> src/services/data_service.rs:850:21 [INFO] [stdout] | [INFO] [stdout] 850 | if let Some(mtws) = &self.mtws_service { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_mtws` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `location` is never read [INFO] [stdout] --> src/devices/rpm.rs:242:5 [INFO] [stdout] | [INFO] [stdout] 239 | pub struct RpmDevice { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 242 | location: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `detect_channels` is never used [INFO] [stdout] --> src/devices/rpm.rs:296:14 [INFO] [stdout] | [INFO] [stdout] 252 | impl RpmDevice { [INFO] [stdout] | -------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 296 | async fn detect_channels(&self, client: &dyn ModbusClientTrait) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_address_from_uuid` is never used [INFO] [stdout] --> src/services/data_service.rs:634:8 [INFO] [stdout] | [INFO] [stdout] 71 | impl DataService { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 634 | fn get_address_from_uuid(&self, uuid: &str) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `shutdown_tx` is never read [INFO] [stdout] --> src/services/database_service.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 14 | pub struct DatabaseService { [INFO] [stdout] | --------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 19 | shutdown_tx: Option>, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DatabaseService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `endpoint_url` is never read [INFO] [stdout] --> src/services/mtws_service.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 16 | pub struct MtwsService { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 21 | endpoint_url: Arc>>, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `MtwsService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `send_mtws_http_request` is never used [INFO] [stdout] --> src/cli/commands.rs:708:10 [INFO] [stdout] | [INFO] [stdout] 708 | async fn send_mtws_http_request( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::path::Path` [INFO] [stdout] --> src/services/data_service.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::path::Path; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::fs` [INFO] [stdout] --> src/services/data_service.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use tokio::fs; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `interval` and `sleep` [INFO] [stdout] --> src/services/data_service.rs:6:19 [INFO] [stdout] | [INFO] [stdout] 6 | use tokio::time::{sleep, interval, Duration}; [INFO] [stdout] | ^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::mpsc` [INFO] [stdout] --> src/services/data_service.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use tokio::sync::mpsc; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::json` [INFO] [stdout] --> src/services/data_service.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use serde_json::json; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `debug` and `warn` [INFO] [stdout] --> src/services/database_service.rs:1:24 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{info, error, warn, debug}; [INFO] [stdout] | ^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Duration` and `interval` [INFO] [stdout] --> src/services/database_service.rs:4:19 [INFO] [stdout] | [INFO] [stdout] 4 | use tokio::time::{interval, Duration}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/services/database_service.rs:5:14 [INFO] [stdout] | [INFO] [stdout] 5 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/services/api_service.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use log::{info, error, warn}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `MtwsField` [INFO] [stdout] --> src/services/mtws_service.rs:13:43 [INFO] [stdout] | [INFO] [stdout] 13 | use crate::storage::models::{MtwsPayload, MtwsField}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `api_service::ApiServiceState` [INFO] [stdout] --> src/services/mod.rs:9:9 [INFO] [stdout] | [INFO] [stdout] 9 | pub use api_service::ApiServiceState; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime` and `Utc` [INFO] [stdout] --> src/config/settings.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/config/settings.rs:3:31 [INFO] [stdout] | [INFO] [stdout] 3 | use log::{debug, error, info, warn}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/config/mqtt_handler.rs:1:17 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{info, warn, error}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ApiServerConfig`, `DataCollectionConfig`, `FileOutputConfig`, `GpsConfig`, `HttpOutputConfig`, `MqttOutputConfig`, `OutputConfig`, `ParityConfig`, `RegisterConfig`, `SiteInfo`, and `SqliteConfig` [INFO] [stdout] --> src/config/mod.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | ParityConfig, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 10 | SiteInfo, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 11 | DataCollectionConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 12 | OutputConfig, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 13 | FileOutputConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 14 | HttpOutputConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 15 | MqttOutputConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 16 | DatabaseOutputConfig, [INFO] [stdout] 17 | SqliteConfig, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 18 | RegisterConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 19 | ApiServerConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] 20 | GpsConfig, // Add this [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ConfigCommandType`, `ConfigTarget`, `ConfigurationCommand`, and `ConfigurationResponse` [INFO] [stdout] --> src/config/mod.rs:25:5 [INFO] [stdout] | [INFO] [stdout] 25 | ConfigurationCommand, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 26 | ConfigurationResponse, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 27 | ConfigCommandType, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 28 | ConfigTarget [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `MqttConfigHandler`, `MqttConfigMessage`, and `MqttConfigResponse` [INFO] [stdout] --> src/config/mod.rs:31:24 [INFO] [stdout] | [INFO] [stdout] 31 | pub use mqtt_handler::{MqttConfigHandler, MqttConfigMessage, MqttConfigResponse}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ModbusRequest` and `ModbusResponse` [INFO] [stdout] --> src/modbus/mod.rs:6:20 [INFO] [stdout] | [INFO] [stdout] 6 | pub use protocol::{ModbusRequest, ModbusResponse}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crc::crc16_modbus` [INFO] [stdout] --> src/modbus/mod.rs:7:9 [INFO] [stdout] | [INFO] [stdout] 7 | pub use crc::crc16_modbus; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `timeout` [INFO] [stdout] --> src/devices/gps/gps_service.rs:3:39 [INFO] [stdout] | [INFO] [stdout] 3 | use tokio::time::{Duration, interval, timeout}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `FlowmeterData` [INFO] [stdout] --> src/devices/mod.rs:7:38 [INFO] [stdout] | [INFO] [stdout] 7 | pub use flowmeter::{FlowmeterDevice, FlowmeterData}; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GpsData` and `GpsService` [INFO] [stdout] --> src/devices/mod.rs:9:15 [INFO] [stdout] | [INFO] [stdout] 9 | pub use gps::{GpsService, GpsData}; [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt` [INFO] [stdout] --> src/utils/error.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::fmt; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::Utc` [INFO] [stdout] --> src/output/formatters.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::Utc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::Value` [INFO] [stdout] --> src/output/formatters.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use serde_json::Value; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/output/formatters.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::utils::error::ModbusError` [INFO] [stdout] --> src/output/formatters.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::utils::error::ModbusError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/output/raw_sender.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use log::{info, error}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `MqttSender`, `NetworkSender`, and `WebSocketSender` [INFO] [stdout] --> src/output/mod.rs:7:58 [INFO] [stdout] | [INFO] [stdout] 7 | pub use senders::{DataSender, ConsoleSender, FileSender, NetworkSender, MqttSender, WebSocketSender}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `RawDataFormat` and `RawDataSender` [INFO] [stdout] --> src/output/mod.rs:8:22 [INFO] [stdout] | [INFO] [stdout] 8 | pub use raw_sender::{RawDataSender, RawDataFormat}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RpmReading` [INFO] [stdout] --> src/storage/sqlite_manager.rs:8:64 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::storage::models::{FlowmeterReading, FlowmeterStats, RpmReading, CombinedDeviceReading}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/storage/models.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `EngineDurationHistory`, `EngineDuration`, `FlowmeterReading`, `FlowmeterStats`, `RpmReading`, and `RpmStats` [INFO] [stdout] --> src/storage/mod.rs:4:18 [INFO] [stdout] | [INFO] [stdout] 4 | pub use models::{EngineDuration, EngineDurationHistory, FlowmeterReading, FlowmeterStats, RpmReading, RpmStats}; [INFO] [stdout] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DatabaseStats` [INFO] [stdout] --> src/storage/mod.rs:5:26 [INFO] [stdout] | [INFO] [stdout] 5 | pub use sqlite_manager::{DatabaseStats, SqliteManager}; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ArgMatches` [INFO] [stdout] --> src/main.rs:11:37 [INFO] [stdout] | [INFO] [stdout] 11 | use clap::{Arg, Command, ArgAction, ArgMatches}; // Add ArgMatches here [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `total_channels` [INFO] [stdout] --> src/services/data_service.rs:419:26 [INFO] [stdout] | [INFO] [stdout] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_total_channels` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `thresholds` [INFO] [stdout] --> src/services/data_service.rs:419:42 [INFO] [stdout] | [INFO] [stdout] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_thresholds` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Row` [INFO] [stdout] --> src/storage/sqlite_manager.rs:3:24 [INFO] [stdout] | [INFO] [stdout] 3 | use sqlx::{SqlitePool, Row}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `mtws` [INFO] [stdout] --> src/services/data_service.rs:850:21 [INFO] [stdout] | [INFO] [stdout] 850 | if let Some(mtws) = &self.mtws_service { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_mtws` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/config/settings.rs:607:50 [INFO] [stdout] | [INFO] [stdout] 607 | pub fn create_new_device(&self, address: u8, device_id: String, device_type: String, name: String, location: String) -> DeviceConfig { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/config/dynamic_manager.rs:511:13 [INFO] [stdout] | [INFO] [stdout] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/config/dynamic_manager.rs:511:13 [INFO] [stdout] | [INFO] [stdout] 233 | ConfigTarget::System => { [INFO] [stdout] | -------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 264 | ConfigTarget::Monitoring => { [INFO] [stdout] | ------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 317 | ConfigTarget::Serial => { [INFO] [stdout] | -------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 344 | ConfigTarget::Gps => { [INFO] [stdout] | ----------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stdout] | ^ ...and 3 other patterns collectively make this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/services/data_service.rs:538:18 [INFO] [stdout] | [INFO] [stdout] 71 | impl DataService { [INFO] [stdout] | ---------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 538 | pub async fn get_engine_durations(&self) -> HashMap { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 564 | pub fn get_database_service_mut(&mut self) -> Option<&mut DatabaseService> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 568 | pub async fn check_database_health(&self) -> Result, ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 634 | fn get_address_from_uuid(&self, uuid: &str) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 742 | pub async fn refresh_gps_data(&self) -> Result, ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 780 | pub fn get_api_service(&self) -> Option<&crate::services::api_service::ApiService> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 837 | pub fn get_mtws_service_mut(&mut self) -> Option<&mut MtwsService> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 855 | pub fn has_mtws_service(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 860 | pub async fn get_current_device_data(&mut self) -> HashMap { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `is_running` and `shutdown_tx` are never read [INFO] [stdout] --> src/services/database_service.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 14 | pub struct DatabaseService { [INFO] [stdout] | --------------- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 18 | is_running: Arc>, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 19 | shutdown_tx: Option>, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DatabaseService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `flush_buffer` and `stop` are never used [INFO] [stdout] --> src/services/database_service.rs:123:18 [INFO] [stdout] | [INFO] [stdout] 22 | impl DatabaseService { [INFO] [stdout] | -------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 123 | pub async fn flush_buffer(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 136 | pub async fn stop(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `FlowType` is never used [INFO] [stdout] --> src/services/api_service.rs:15:10 [INFO] [stdout] | [INFO] [stdout] 15 | pub enum FlowType { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `sqlite_manager`, `config`, and `data_service` are never read [INFO] [stdout] --> src/services/api_service.rs:44:9 [INFO] [stdout] | [INFO] [stdout] 43 | pub struct ApiServiceState { [INFO] [stdout] | --------------- fields in this struct [INFO] [stdout] 44 | pub sqlite_manager: SqliteManager, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 45 | pub config: Config, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 46 | pub data_service: Option>, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ApiServiceState` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new`, `start_mtws_transmission`, `stop_mtws_transmission`, `send_mtws_payload`, and `get_mtws_status` are never used [INFO] [stdout] --> src/services/api_service.rs:78:12 [INFO] [stdout] | [INFO] [stdout] 77 | impl ApiService { [INFO] [stdout] | --------------- associated items in this implementation [INFO] [stdout] 78 | pub fn new(config: Config, sqlite_manager: SqliteManager) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 148 | pub async fn start_mtws_transmission(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 157 | pub async fn stop_mtws_transmission(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 166 | pub async fn send_mtws_payload(&self, endpoint_url: Option) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 179 | pub async fn get_mtws_status(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MtwsStatus` is never constructed [INFO] [stdout] --> src/services/api_service.rs:197:12 [INFO] [stdout] | [INFO] [stdout] 197 | pub struct MtwsStatus { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `endpoint_url` is never read [INFO] [stdout] --> src/services/mtws_service.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 16 | pub struct MtwsService { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 21 | endpoint_url: Arc>>, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `MtwsService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `set_transmission_interval`, `print_current_payload`, and `get_payload_summary` are never used [INFO] [stdout] --> src/services/mtws_service.rs:535:18 [INFO] [stdout] | [INFO] [stdout] 41 | impl MtwsService { [INFO] [stdout] | ---------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 535 | pub async fn set_transmission_interval(&self, seconds: u64) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 554 | pub async fn print_current_payload(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 574 | pub async fn get_payload_summary(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `send_mtws_http_request` is never used [INFO] [stdout] --> src/cli/commands.rs:708:10 [INFO] [stdout] | [INFO] [stdout] 708 | async fn send_mtws_http_request( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RegisterConfig` is never constructed [INFO] [stdout] --> src/config/settings.rs:266:12 [INFO] [stdout] | [INFO] [stdout] 266 | pub struct RegisterConfig { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_default_parameters_for_type` is never used [INFO] [stdout] --> src/config/settings.rs:409:4 [INFO] [stdout] | [INFO] [stdout] 409 | fn get_default_parameters_for_type(device_type: &str) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/config/settings.rs:587:12 [INFO] [stdout] | [INFO] [stdout] 432 | impl Config { [INFO] [stdout] | ----------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 587 | pub fn get_device_by_uuid(&self, uuid: &str) -> Option<&DeviceConfig> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 592 | pub fn get_device_by_name(&self, name: &str) -> Option<&DeviceConfig> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 597 | pub fn device_addresses(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 602 | pub fn sync_device_addresses(&mut self) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 607 | pub fn create_new_device(&self, address: u8, device_id: String, device_type: String, name: String, location: String) -> DeviceConfig { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 674 | pub fn get_rpm_outlier_settings(&self, address: u8) -> (u16, u16) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 692 | pub fn is_rpm_auto_detect_enabled(&self, address: u8) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 702 | pub fn get_enabled_flowmeter_devices(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 711 | pub fn validate_flowmeter_config(&self) -> Result<(), String> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 736 | pub fn validate_mtws_config(&self) -> Result<(), String> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MqttConfigMessage` is never constructed [INFO] [stdout] --> src/config/mqtt_handler.rs:12:12 [INFO] [stdout] | [INFO] [stdout] 12 | pub struct MqttConfigMessage { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MqttConfigResponse` is never constructed [INFO] [stdout] --> src/config/mqtt_handler.rs:20:12 [INFO] [stdout] | [INFO] [stdout] 20 | pub struct MqttConfigResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MqttConfigHandler` is never constructed [INFO] [stdout] --> src/config/mqtt_handler.rs:25:12 [INFO] [stdout] | [INFO] [stdout] 25 | pub struct MqttConfigHandler { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `MqttClientTrait` is never used [INFO] [stdout] --> src/config/mqtt_handler.rs:33:11 [INFO] [stdout] | [INFO] [stdout] 33 | pub trait MqttClientTrait: Send + Sync { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new`, `set_mqtt_client`, `start_listening`, `handle_mqtt_message`, and `create_command_message` are never used [INFO] [stdout] --> src/config/mqtt_handler.rs:39:12 [INFO] [stdout] | [INFO] [stdout] 38 | impl MqttConfigHandler { [INFO] [stdout] | ---------------------- associated items in this implementation [INFO] [stdout] 39 | pub fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 52 | pub fn set_mqtt_client(&mut self, client: Arc) { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 56 | pub async fn start_listening(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 80 | async fn handle_mqtt_message( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 114 | pub fn create_command_message( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MockMqttClient` is never constructed [INFO] [stdout] --> src/config/mqtt_handler.rs:131:12 [INFO] [stdout] | [INFO] [stdout] 131 | pub struct MockMqttClient; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `read_input_registers` and `read_discrete_inputs` are never used [INFO] [stdout] --> src/modbus/client.rs:23:14 [INFO] [stdout] | [INFO] [stdout] 14 | pub trait ModbusClientTrait: Send + Sync { [INFO] [stdout] | ----------------- methods in this trait [INFO] [stdout] ... [INFO] [stdout] 23 | async fn read_input_registers( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 38 | async fn read_discrete_inputs( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `ModbusRequest` is never used [INFO] [stdout] --> src/modbus/protocol.rs:2:10 [INFO] [stdout] | [INFO] [stdout] 2 | pub enum ModbusRequest { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `ModbusResponse` is never used [INFO] [stdout] --> src/modbus/protocol.rs:18:10 [INFO] [stdout] | [INFO] [stdout] 18 | pub enum ModbusResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `device_type` and `name` are never used [INFO] [stdout] --> src/devices/traits.rs:12:8 [INFO] [stdout] | [INFO] [stdout] 11 | pub trait Device: Send + Sync { [INFO] [stdout] | ------ methods in this trait [INFO] [stdout] 12 | fn device_type(&self) -> &str; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 13 | fn address(&self) -> u8; [INFO] [stdout] 14 | fn name(&self) -> &str; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `get_parameter`, `get_all_parameters`, `get_parameters_as_floats`, `device_type`, `device_name`, and `device_location` are never used [INFO] [stdout] --> src/devices/traits.rs:33:8 [INFO] [stdout] | [INFO] [stdout] 22 | pub trait DeviceData: Send + Sync { [INFO] [stdout] | ---------- methods in this trait [INFO] [stdout] ... [INFO] [stdout] 33 | fn get_parameter(&self, name: &str) -> Option; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 34 | fn get_all_parameters(&self) -> Vec<(String, String)>; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 37 | fn get_parameters_as_floats(&self) -> HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 38 | [INFO] [stdout] 39 | fn device_type(&self) -> String; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 40 | fn device_name(&self) -> String; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 41 | fn device_location(&self) -> String; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `read_data_with_raw` is never used [INFO] [stdout] --> src/devices/flowmeter.rs:48:18 [INFO] [stdout] | [INFO] [stdout] 25 | impl FlowmeterDevice { [INFO] [stdout] | -------------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 48 | pub async fn read_data_with_raw(&self, client: &dyn ModbusClientTrait) -> Result<(Box, FlowmeterRawPayload), ModbusEr... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `to_engineering_units` is never used [INFO] [stdout] --> src/devices/flowmeter.rs:351:12 [INFO] [stdout] | [INFO] [stdout] 293 | impl FlowmeterRawPayload { [INFO] [stdout] | ------------------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 351 | pub fn to_engineering_units(&self) -> FlowmeterData { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `get_primary_channel`, `get_channel`, `get_running_engines`, and `get_total_engine_minutes` are never used [INFO] [stdout] --> src/devices/rpm.rs:78:12 [INFO] [stdout] | [INFO] [stdout] 58 | impl RpmData { [INFO] [stdout] | ------------ methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 78 | pub fn get_primary_channel(&self) -> Option<&RpmChannelData> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 83 | pub fn get_channel(&self, channel_id: u8) -> Option<&RpmChannelData> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 88 | pub fn get_running_engines(&self) -> Vec<&RpmChannelData> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 93 | pub fn get_total_engine_minutes(&self) -> f32 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `location` is never read [INFO] [stdout] --> src/devices/rpm.rs:242:5 [INFO] [stdout] | [INFO] [stdout] 239 | pub struct RpmDevice { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 242 | location: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `detect_channels` is never used [INFO] [stdout] --> src/devices/rpm.rs:296:14 [INFO] [stdout] | [INFO] [stdout] 252 | impl RpmDevice { [INFO] [stdout] | -------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 296 | async fn detect_channels(&self, client: &dyn ModbusClientTrait) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `ConfigError` is never constructed [INFO] [stdout] --> src/utils/error.rs:34:5 [INFO] [stdout] | [INFO] [stdout] 5 | pub enum ModbusError { [INFO] [stdout] | ----------- variant in this enum [INFO] [stdout] ... [INFO] [stdout] 34 | ConfigError(String), [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ModbusError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `format_single_device` and `format_header` are never used [INFO] [stdout] --> src/output/formatters.rs:9:8 [INFO] [stdout] | [INFO] [stdout] 8 | pub trait DataFormatter: Send + Sync { [INFO] [stdout] | ------------- methods in this trait [INFO] [stdout] 9 | fn format_single_device(&self, addr: u8, data: &dyn DeviceData) -> String; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 10 | fn format_header(&self) -> String; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `send` and `destination` are never used [INFO] [stdout] --> src/output/senders.rs:12:14 [INFO] [stdout] | [INFO] [stdout] 11 | pub trait DataSender: Send + Sync { [INFO] [stdout] | ---------- methods in this trait [INFO] [stdout] 12 | async fn send(&self, data: &str) -> Result<(), ModbusError>; [INFO] [stdout] | ^^^^ [INFO] [stdout] 13 | fn sender_type(&self) -> &str; [INFO] [stdout] 14 | fn destination(&self) -> &str; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `file_path` and `append` are never read [INFO] [stdout] --> src/output/senders.rs:36:5 [INFO] [stdout] | [INFO] [stdout] 35 | pub struct FileSender { [INFO] [stdout] | ---------- fields in this struct [INFO] [stdout] 36 | file_path: String, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 37 | append: bool, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `NetworkSender` is never constructed [INFO] [stdout] --> src/output/senders.rs:91:12 [INFO] [stdout] | [INFO] [stdout] 91 | pub struct NetworkSender { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/output/senders.rs:96:12 [INFO] [stdout] | [INFO] [stdout] 95 | impl NetworkSender { [INFO] [stdout] | ------------------ associated function in this implementation [INFO] [stdout] 96 | pub fn new(endpoint: String) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MqttSender` is never constructed [INFO] [stdout] --> src/output/senders.rs:138:12 [INFO] [stdout] | [INFO] [stdout] 138 | pub struct MqttSender { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/output/senders.rs:144:12 [INFO] [stdout] | [INFO] [stdout] 143 | impl MqttSender { [INFO] [stdout] | --------------- associated function in this implementation [INFO] [stdout] 144 | pub fn new(broker_url: String, topic: String) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `WebSocketSender` is never constructed [INFO] [stdout] --> src/output/senders.rs:184:12 [INFO] [stdout] | [INFO] [stdout] 184 | pub struct WebSocketSender { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/output/senders.rs:189:12 [INFO] [stdout] | [INFO] [stdout] 188 | impl WebSocketSender { [INFO] [stdout] | -------------------- associated function in this implementation [INFO] [stdout] 189 | pub fn new(ws_url: String) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `insert_combined_reading`, `cleanup_old_data`, `get_database_stats`, and `close` are never used [INFO] [stdout] --> src/storage/sqlite_manager.rs:470:18 [INFO] [stdout] | [INFO] [stdout] 17 | impl SqliteManager { [INFO] [stdout] | ------------------ methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 470 | pub async fn insert_combined_reading(&self, reading: &CombinedDeviceReading) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 501 | pub async fn cleanup_old_data(&self, hours_to_keep: i64) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 535 | pub async fn get_database_stats(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 557 | pub async fn close(&self) { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `DatabaseStats` is never constructed [INFO] [stdout] --> src/storage/sqlite_manager.rs:564:12 [INFO] [stdout] | [INFO] [stdout] 564 | pub struct DatabaseStats { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RpmReading` is never constructed [INFO] [stdout] --> src/storage/models.rs:27:12 [INFO] [stdout] | [INFO] [stdout] 27 | pub struct RpmReading { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `from_rpm_data` is never used [INFO] [stdout] --> src/storage/models.rs:44:12 [INFO] [stdout] | [INFO] [stdout] 43 | impl RpmReading { [INFO] [stdout] | --------------- associated function in this implementation [INFO] [stdout] 44 | pub fn from_rpm_data(device_address: u8, rpm_data: &RpmChannelData, engine_duration: u64) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RpmStats` is never constructed [INFO] [stdout] --> src/storage/models.rs:72:12 [INFO] [stdout] | [INFO] [stdout] 72 | pub struct RpmStats { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/storage/models.rs:131:12 [INFO] [stdout] | [INFO] [stdout] 130 | impl MtwsField { [INFO] [stdout] | -------------- associated function in this implementation [INFO] [stdout] 131 | pub fn new(name: String, value: String) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CombinedDeviceReading` is never constructed [INFO] [stdout] --> src/storage/models.rs:154:12 [INFO] [stdout] | [INFO] [stdout] 154 | pub struct CombinedDeviceReading { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `EngineDuration` is never constructed [INFO] [stdout] --> src/storage/models.rs:193:12 [INFO] [stdout] | [INFO] [stdout] 193 | pub struct EngineDuration { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new`, `duration_minutes`, and `duration_hours` are never used [INFO] [stdout] --> src/storage/models.rs:208:12 [INFO] [stdout] | [INFO] [stdout] 207 | impl EngineDuration { [INFO] [stdout] | ------------------- associated items in this implementation [INFO] [stdout] 208 | pub fn new(device_address: u8, channel_id: u8, engine_type: String, rpm_threshold: u16) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 225 | pub fn duration_minutes(&self) -> u64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 229 | pub fn duration_hours(&self) -> f32 { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `EngineDurationHistory` is never constructed [INFO] [stdout] --> src/storage/models.rs:235:12 [INFO] [stdout] | [INFO] [stdout] 235 | pub struct EngineDurationHistory { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MtwsConfig` is never constructed [INFO] [stdout] --> src/storage/models.rs:249:12 [INFO] [stdout] | [INFO] [stdout] 249 | pub struct MtwsConfig { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [optimized + debuginfo] target(s) in 14m 46s [INFO] running `Command { std: "docker" "inspect" "8690094c4d0480b8c1ba4a5213ce8578a745f458515604c26a7e17501cd106c0", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8690094c4d0480b8c1ba4a5213ce8578a745f458515604c26a7e17501cd106c0", kill_on_drop: false }` [INFO] [stdout] 8690094c4d0480b8c1ba4a5213ce8578a745f458515604c26a7e17501cd106c0 [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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+16fbf98f22730e073c09e7b03f0eafb87a295545" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] c26142c6b69cfd5714db5f0b303fd27862d45ceba1e5d836f644fcac8da54958 [INFO] running `Command { std: "docker" "start" "-a" "c26142c6b69cfd5714db5f0b303fd27862d45ceba1e5d836f644fcac8da54958", kill_on_drop: false }` [INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: unused manifest key: target.aarch64-unknown-linux-gnu.ar [INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: unused manifest key: target.aarch64-unknown-linux-gnu.linker [INFO] [stdout] warning: unused imports: `DateTime` and `Utc` [INFO] [stdout] --> src/config/settings.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/config/settings.rs:3:31 [INFO] [stdout] | [INFO] [stdout] 3 | use log::{debug, error, info, warn}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/config/mqtt_handler.rs:1:17 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{info, warn, error}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `timeout` [INFO] [stdout] --> src/devices/gps/gps_service.rs:3:39 [INFO] [stdout] | [INFO] [stdout] 3 | use tokio::time::{Duration, interval, timeout}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::path::Path` [INFO] [stdout] --> src/services/data_service.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::path::Path; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::fs` [INFO] [stdout] --> src/services/data_service.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use tokio::fs; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `interval` and `sleep` [INFO] [stdout] --> src/services/data_service.rs:6:19 [INFO] [stdout] | [INFO] [stdout] 6 | use tokio::time::{sleep, interval, Duration}; [INFO] [stdout] | ^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::mpsc` [INFO] [stdout] --> src/services/data_service.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use tokio::sync::mpsc; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::json` [INFO] [stdout] --> src/services/data_service.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use serde_json::json; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `debug` and `warn` [INFO] [stdout] --> src/services/database_service.rs:1:24 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{info, error, warn, debug}; [INFO] [stdout] | ^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Duration` and `interval` [INFO] [stdout] --> src/services/database_service.rs:4:19 [INFO] [stdout] | [INFO] [stdout] 4 | use tokio::time::{interval, Duration}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/services/database_service.rs:5:14 [INFO] [stdout] | [INFO] [stdout] 5 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/services/api_service.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use log::{info, error, warn}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `MtwsField` [INFO] [stdout] --> src/services/mtws_service.rs:13:43 [INFO] [stdout] | [INFO] [stdout] 13 | use crate::storage::models::{MtwsPayload, MtwsField}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::Utc` [INFO] [stdout] --> src/output/formatters.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::Utc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::Value` [INFO] [stdout] --> src/output/formatters.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use serde_json::Value; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/output/formatters.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::utils::error::ModbusError` [INFO] [stdout] --> src/output/formatters.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::utils::error::ModbusError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/output/raw_sender.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use log::{info, error}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt` [INFO] [stdout] --> src/utils/error.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::fmt; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RpmReading` [INFO] [stdout] --> src/storage/sqlite_manager.rs:8:64 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::storage::models::{FlowmeterReading, FlowmeterStats, RpmReading, CombinedDeviceReading}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/storage/models.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `total_channels` [INFO] [stdout] --> src/services/data_service.rs:419:26 [INFO] [stdout] | [INFO] [stdout] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_total_channels` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `thresholds` [INFO] [stdout] --> src/services/data_service.rs:419:42 [INFO] [stdout] | [INFO] [stdout] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_thresholds` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Row` [INFO] [stdout] --> src/storage/sqlite_manager.rs:3:24 [INFO] [stdout] | [INFO] [stdout] 3 | use sqlx::{SqlitePool, Row}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/config/settings.rs:607:50 [INFO] [stdout] | [INFO] [stdout] 607 | pub fn create_new_device(&self, address: u8, device_id: String, device_type: String, name: String, location: String) -> DeviceConfig { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/config/dynamic_manager.rs:511:13 [INFO] [stdout] | [INFO] [stdout] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/config/dynamic_manager.rs:511:13 [INFO] [stdout] | [INFO] [stdout] 233 | ConfigTarget::System => { [INFO] [stdout] | -------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 264 | ConfigTarget::Monitoring => { [INFO] [stdout] | ------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 317 | ConfigTarget::Serial => { [INFO] [stdout] | -------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 344 | ConfigTarget::Gps => { [INFO] [stdout] | ----------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stdout] | ^ ...and 3 other patterns collectively make this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `mtws` [INFO] [stdout] --> src/services/data_service.rs:850:21 [INFO] [stdout] | [INFO] [stdout] 850 | if let Some(mtws) = &self.mtws_service { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_mtws` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `location` is never read [INFO] [stdout] --> src/devices/rpm.rs:242:5 [INFO] [stdout] | [INFO] [stdout] 239 | pub struct RpmDevice { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 242 | location: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `detect_channels` is never used [INFO] [stdout] --> src/devices/rpm.rs:296:14 [INFO] [stdout] | [INFO] [stdout] 252 | impl RpmDevice { [INFO] [stdout] | -------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 296 | async fn detect_channels(&self, client: &dyn ModbusClientTrait) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_address_from_uuid` is never used [INFO] [stdout] --> src/services/data_service.rs:634:8 [INFO] [stdout] | [INFO] [stdout] 71 | impl DataService { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 634 | fn get_address_from_uuid(&self, uuid: &str) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `shutdown_tx` is never read [INFO] [stdout] --> src/services/database_service.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 14 | pub struct DatabaseService { [INFO] [stdout] | --------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 19 | shutdown_tx: Option>, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DatabaseService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `endpoint_url` is never read [INFO] [stdout] --> src/services/mtws_service.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 16 | pub struct MtwsService { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 21 | endpoint_url: Arc>>, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `MtwsService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `send_mtws_http_request` is never used [INFO] [stdout] --> src/cli/commands.rs:708:10 [INFO] [stdout] | [INFO] [stdout] 708 | async fn send_mtws_http_request( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling ipc_dev_rust v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused imports: `DateTime` and `Utc` [INFO] [stdout] --> src/config/settings.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/config/settings.rs:3:31 [INFO] [stdout] | [INFO] [stdout] 3 | use log::{debug, error, info, warn}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/config/mqtt_handler.rs:1:17 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{info, warn, error}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `timeout` [INFO] [stdout] --> src/devices/gps/gps_service.rs:3:39 [INFO] [stdout] | [INFO] [stdout] 3 | use tokio::time::{Duration, interval, timeout}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::path::Path` [INFO] [stdout] --> src/services/data_service.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::path::Path; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::fs` [INFO] [stdout] --> src/services/data_service.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use tokio::fs; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `interval` and `sleep` [INFO] [stdout] --> src/services/data_service.rs:6:19 [INFO] [stdout] | [INFO] [stdout] 6 | use tokio::time::{sleep, interval, Duration}; [INFO] [stdout] | ^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::mpsc` [INFO] [stdout] --> src/services/data_service.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use tokio::sync::mpsc; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::json` [INFO] [stdout] --> src/services/data_service.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use serde_json::json; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `debug` and `warn` [INFO] [stdout] --> src/services/database_service.rs:1:24 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{info, error, warn, debug}; [INFO] [stdout] | ^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Duration` and `interval` [INFO] [stdout] --> src/services/database_service.rs:4:19 [INFO] [stdout] | [INFO] [stdout] 4 | use tokio::time::{interval, Duration}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/services/database_service.rs:5:14 [INFO] [stdout] | [INFO] [stdout] 5 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/services/api_service.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use log::{info, error, warn}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `MtwsField` [INFO] [stdout] --> src/services/mtws_service.rs:13:43 [INFO] [stdout] | [INFO] [stdout] 13 | use crate::storage::models::{MtwsPayload, MtwsField}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::Utc` [INFO] [stdout] --> src/output/formatters.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::Utc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::Value` [INFO] [stdout] --> src/output/formatters.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use serde_json::Value; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/output/formatters.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::utils::error::ModbusError` [INFO] [stdout] --> src/output/formatters.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::utils::error::ModbusError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/output/raw_sender.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use log::{info, error}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt` [INFO] [stdout] --> src/utils/error.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::fmt; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RpmReading` [INFO] [stdout] --> src/storage/sqlite_manager.rs:8:64 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::storage::models::{FlowmeterReading, FlowmeterStats, RpmReading, CombinedDeviceReading}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/storage/models.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::path::Path` [INFO] [stdout] --> src/services/data_service.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::path::Path; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::fs` [INFO] [stdout] --> src/services/data_service.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use tokio::fs; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `interval` and `sleep` [INFO] [stdout] --> src/services/data_service.rs:6:19 [INFO] [stdout] | [INFO] [stdout] 6 | use tokio::time::{sleep, interval, Duration}; [INFO] [stdout] | ^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::mpsc` [INFO] [stdout] --> src/services/data_service.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use tokio::sync::mpsc; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::json` [INFO] [stdout] --> src/services/data_service.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use serde_json::json; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `debug` and `warn` [INFO] [stdout] --> src/services/database_service.rs:1:24 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{info, error, warn, debug}; [INFO] [stdout] | ^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Duration` and `interval` [INFO] [stdout] --> src/services/database_service.rs:4:19 [INFO] [stdout] | [INFO] [stdout] 4 | use tokio::time::{interval, Duration}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/services/database_service.rs:5:14 [INFO] [stdout] | [INFO] [stdout] 5 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/services/api_service.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use log::{info, error, warn}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `MtwsField` [INFO] [stdout] --> src/services/mtws_service.rs:13:43 [INFO] [stdout] | [INFO] [stdout] 13 | use crate::storage::models::{MtwsPayload, MtwsField}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `api_service::ApiServiceState` [INFO] [stdout] --> src/services/mod.rs:9:9 [INFO] [stdout] | [INFO] [stdout] 9 | pub use api_service::ApiServiceState; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime` and `Utc` [INFO] [stdout] --> src/config/settings.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/config/settings.rs:3:31 [INFO] [stdout] | [INFO] [stdout] 3 | use log::{debug, error, info, warn}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/config/mqtt_handler.rs:1:17 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{info, warn, error}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ApiServerConfig`, `DataCollectionConfig`, `FileOutputConfig`, `GpsConfig`, `HttpOutputConfig`, `MqttOutputConfig`, `OutputConfig`, `ParityConfig`, `RegisterConfig`, `SiteInfo`, and `SqliteConfig` [INFO] [stdout] --> src/config/mod.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | ParityConfig, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 10 | SiteInfo, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 11 | DataCollectionConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 12 | OutputConfig, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 13 | FileOutputConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 14 | HttpOutputConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 15 | MqttOutputConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 16 | DatabaseOutputConfig, [INFO] [stdout] 17 | SqliteConfig, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 18 | RegisterConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 19 | ApiServerConfig, [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] 20 | GpsConfig, // Add this [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ConfigCommandType`, `ConfigTarget`, `ConfigurationCommand`, and `ConfigurationResponse` [INFO] [stdout] --> src/config/mod.rs:25:5 [INFO] [stdout] | [INFO] [stdout] 25 | ConfigurationCommand, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 26 | ConfigurationResponse, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 27 | ConfigCommandType, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 28 | ConfigTarget [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `MqttConfigHandler`, `MqttConfigMessage`, and `MqttConfigResponse` [INFO] [stdout] --> src/config/mod.rs:31:24 [INFO] [stdout] | [INFO] [stdout] 31 | pub use mqtt_handler::{MqttConfigHandler, MqttConfigMessage, MqttConfigResponse}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ModbusRequest` and `ModbusResponse` [INFO] [stdout] --> src/modbus/mod.rs:6:20 [INFO] [stdout] | [INFO] [stdout] 6 | pub use protocol::{ModbusRequest, ModbusResponse}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crc::crc16_modbus` [INFO] [stdout] --> src/modbus/mod.rs:7:9 [INFO] [stdout] | [INFO] [stdout] 7 | pub use crc::crc16_modbus; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `timeout` [INFO] [stdout] --> src/devices/gps/gps_service.rs:3:39 [INFO] [stdout] | [INFO] [stdout] 3 | use tokio::time::{Duration, interval, timeout}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `FlowmeterData` [INFO] [stdout] --> src/devices/mod.rs:7:38 [INFO] [stdout] | [INFO] [stdout] 7 | pub use flowmeter::{FlowmeterDevice, FlowmeterData}; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GpsData` and `GpsService` [INFO] [stdout] --> src/devices/mod.rs:9:15 [INFO] [stdout] | [INFO] [stdout] 9 | pub use gps::{GpsService, GpsData}; [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt` [INFO] [stdout] --> src/utils/error.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::fmt; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::Utc` [INFO] [stdout] --> src/output/formatters.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::Utc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::Value` [INFO] [stdout] --> src/output/formatters.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use serde_json::Value; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/output/formatters.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::utils::error::ModbusError` [INFO] [stdout] --> src/output/formatters.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::utils::error::ModbusError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/output/raw_sender.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use log::{info, error}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `MqttSender`, `NetworkSender`, and `WebSocketSender` [INFO] [stdout] --> src/output/mod.rs:7:58 [INFO] [stdout] | [INFO] [stdout] 7 | pub use senders::{DataSender, ConsoleSender, FileSender, NetworkSender, MqttSender, WebSocketSender}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `RawDataFormat` and `RawDataSender` [INFO] [stdout] --> src/output/mod.rs:8:22 [INFO] [stdout] | [INFO] [stdout] 8 | pub use raw_sender::{RawDataSender, RawDataFormat}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `RpmReading` [INFO] [stdout] --> src/storage/sqlite_manager.rs:8:64 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::storage::models::{FlowmeterReading, FlowmeterStats, RpmReading, CombinedDeviceReading}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/storage/models.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `EngineDurationHistory`, `EngineDuration`, `FlowmeterReading`, `FlowmeterStats`, `RpmReading`, and `RpmStats` [INFO] [stdout] --> src/storage/mod.rs:4:18 [INFO] [stdout] | [INFO] [stdout] 4 | pub use models::{EngineDuration, EngineDurationHistory, FlowmeterReading, FlowmeterStats, RpmReading, RpmStats}; [INFO] [stdout] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DatabaseStats` [INFO] [stdout] --> src/storage/mod.rs:5:26 [INFO] [stdout] | [INFO] [stdout] 5 | pub use sqlite_manager::{DatabaseStats, SqliteManager}; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ArgMatches` [INFO] [stdout] --> src/main.rs:11:37 [INFO] [stdout] | [INFO] [stdout] 11 | use clap::{Arg, Command, ArgAction, ArgMatches}; // Add ArgMatches here [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `total_channels` [INFO] [stdout] --> src/services/data_service.rs:419:26 [INFO] [stdout] | [INFO] [stdout] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_total_channels` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `thresholds` [INFO] [stdout] --> src/services/data_service.rs:419:42 [INFO] [stdout] | [INFO] [stdout] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_thresholds` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `total_channels` [INFO] [stdout] --> src/services/data_service.rs:419:26 [INFO] [stdout] | [INFO] [stdout] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_total_channels` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `thresholds` [INFO] [stdout] --> src/services/data_service.rs:419:42 [INFO] [stdout] | [INFO] [stdout] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_thresholds` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Row` [INFO] [stdout] --> src/storage/sqlite_manager.rs:3:24 [INFO] [stdout] | [INFO] [stdout] 3 | use sqlx::{SqlitePool, Row}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Row` [INFO] [stdout] --> src/storage/sqlite_manager.rs:3:24 [INFO] [stdout] | [INFO] [stdout] 3 | use sqlx::{SqlitePool, Row}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `mtws` [INFO] [stdout] --> src/services/data_service.rs:850:21 [INFO] [stdout] | [INFO] [stdout] 850 | if let Some(mtws) = &self.mtws_service { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_mtws` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/config/settings.rs:607:50 [INFO] [stdout] | [INFO] [stdout] 607 | pub fn create_new_device(&self, address: u8, device_id: String, device_type: String, name: String, location: String) -> DeviceConfig { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/config/dynamic_manager.rs:511:13 [INFO] [stdout] | [INFO] [stdout] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/config/dynamic_manager.rs:511:13 [INFO] [stdout] | [INFO] [stdout] 233 | ConfigTarget::System => { [INFO] [stdout] | -------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 264 | ConfigTarget::Monitoring => { [INFO] [stdout] | ------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 317 | ConfigTarget::Serial => { [INFO] [stdout] | -------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 344 | ConfigTarget::Gps => { [INFO] [stdout] | ----------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stdout] | ^ ...and 3 other patterns collectively make this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/config/settings.rs:607:50 [INFO] [stdout] | [INFO] [stdout] 607 | pub fn create_new_device(&self, address: u8, device_id: String, device_type: String, name: String, location: String) -> DeviceConfig { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/config/dynamic_manager.rs:511:13 [INFO] [stdout] | [INFO] [stdout] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/config/dynamic_manager.rs:511:13 [INFO] [stdout] | [INFO] [stdout] 233 | ConfigTarget::System => { [INFO] [stdout] | -------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 264 | ConfigTarget::Monitoring => { [INFO] [stdout] | ------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 317 | ConfigTarget::Serial => { [INFO] [stdout] | -------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 344 | ConfigTarget::Gps => { [INFO] [stdout] | ----------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stdout] | ^ ...and 3 other patterns collectively make this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `mtws` [INFO] [stdout] --> src/services/data_service.rs:850:21 [INFO] [stdout] | [INFO] [stdout] 850 | if let Some(mtws) = &self.mtws_service { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_mtws` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `location` is never read [INFO] [stdout] --> src/devices/rpm.rs:242:5 [INFO] [stdout] | [INFO] [stdout] 239 | pub struct RpmDevice { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 242 | location: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `detect_channels` is never used [INFO] [stdout] --> src/devices/rpm.rs:296:14 [INFO] [stdout] | [INFO] [stdout] 252 | impl RpmDevice { [INFO] [stdout] | -------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 296 | async fn detect_channels(&self, client: &dyn ModbusClientTrait) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_address_from_uuid` is never used [INFO] [stdout] --> src/services/data_service.rs:634:8 [INFO] [stdout] | [INFO] [stdout] 71 | impl DataService { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 634 | fn get_address_from_uuid(&self, uuid: &str) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `shutdown_tx` is never read [INFO] [stdout] --> src/services/database_service.rs:19:5 [INFO] [stdout] | [INFO] [stdout] 14 | pub struct DatabaseService { [INFO] [stdout] | --------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 19 | shutdown_tx: Option>, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DatabaseService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `endpoint_url` is never read [INFO] [stdout] --> src/services/mtws_service.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 16 | pub struct MtwsService { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 21 | endpoint_url: Arc>>, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `MtwsService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `send_mtws_http_request` is never used [INFO] [stdout] --> src/cli/commands.rs:708:10 [INFO] [stdout] | [INFO] [stdout] 708 | async fn send_mtws_http_request( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/services/data_service.rs:538:18 [INFO] [stdout] | [INFO] [stdout] 71 | impl DataService { [INFO] [stdout] | ---------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 538 | pub async fn get_engine_durations(&self) -> HashMap { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 564 | pub fn get_database_service_mut(&mut self) -> Option<&mut DatabaseService> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 568 | pub async fn check_database_health(&self) -> Result, ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 634 | fn get_address_from_uuid(&self, uuid: &str) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 742 | pub async fn refresh_gps_data(&self) -> Result, ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 780 | pub fn get_api_service(&self) -> Option<&crate::services::api_service::ApiService> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 837 | pub fn get_mtws_service_mut(&mut self) -> Option<&mut MtwsService> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 855 | pub fn has_mtws_service(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 860 | pub async fn get_current_device_data(&mut self) -> HashMap { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `is_running` and `shutdown_tx` are never read [INFO] [stdout] --> src/services/database_service.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 14 | pub struct DatabaseService { [INFO] [stdout] | --------------- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 18 | is_running: Arc>, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 19 | shutdown_tx: Option>, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DatabaseService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `flush_buffer` and `stop` are never used [INFO] [stdout] --> src/services/database_service.rs:123:18 [INFO] [stdout] | [INFO] [stdout] 22 | impl DatabaseService { [INFO] [stdout] | -------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 123 | pub async fn flush_buffer(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 136 | pub async fn stop(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `FlowType` is never used [INFO] [stdout] --> src/services/api_service.rs:15:10 [INFO] [stdout] | [INFO] [stdout] 15 | pub enum FlowType { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `sqlite_manager`, `config`, and `data_service` are never read [INFO] [stdout] --> src/services/api_service.rs:44:9 [INFO] [stdout] | [INFO] [stdout] 43 | pub struct ApiServiceState { [INFO] [stdout] | --------------- fields in this struct [INFO] [stdout] 44 | pub sqlite_manager: SqliteManager, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 45 | pub config: Config, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 46 | pub data_service: Option>, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ApiServiceState` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new`, `start_mtws_transmission`, `stop_mtws_transmission`, `send_mtws_payload`, and `get_mtws_status` are never used [INFO] [stdout] --> src/services/api_service.rs:78:12 [INFO] [stdout] | [INFO] [stdout] 77 | impl ApiService { [INFO] [stdout] | --------------- associated items in this implementation [INFO] [stdout] 78 | pub fn new(config: Config, sqlite_manager: SqliteManager) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 148 | pub async fn start_mtws_transmission(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 157 | pub async fn stop_mtws_transmission(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 166 | pub async fn send_mtws_payload(&self, endpoint_url: Option) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 179 | pub async fn get_mtws_status(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MtwsStatus` is never constructed [INFO] [stdout] --> src/services/api_service.rs:197:12 [INFO] [stdout] | [INFO] [stdout] 197 | pub struct MtwsStatus { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `endpoint_url` is never read [INFO] [stdout] --> src/services/mtws_service.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 16 | pub struct MtwsService { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 21 | endpoint_url: Arc>>, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `MtwsService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `set_transmission_interval`, `print_current_payload`, and `get_payload_summary` are never used [INFO] [stdout] --> src/services/mtws_service.rs:535:18 [INFO] [stdout] | [INFO] [stdout] 41 | impl MtwsService { [INFO] [stdout] | ---------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 535 | pub async fn set_transmission_interval(&self, seconds: u64) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 554 | pub async fn print_current_payload(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 574 | pub async fn get_payload_summary(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `send_mtws_http_request` is never used [INFO] [stdout] --> src/cli/commands.rs:708:10 [INFO] [stdout] | [INFO] [stdout] 708 | async fn send_mtws_http_request( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RegisterConfig` is never constructed [INFO] [stdout] --> src/config/settings.rs:266:12 [INFO] [stdout] | [INFO] [stdout] 266 | pub struct RegisterConfig { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_default_parameters_for_type` is never used [INFO] [stdout] --> src/config/settings.rs:409:4 [INFO] [stdout] | [INFO] [stdout] 409 | fn get_default_parameters_for_type(device_type: &str) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/config/settings.rs:587:12 [INFO] [stdout] | [INFO] [stdout] 432 | impl Config { [INFO] [stdout] | ----------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 587 | pub fn get_device_by_uuid(&self, uuid: &str) -> Option<&DeviceConfig> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 592 | pub fn get_device_by_name(&self, name: &str) -> Option<&DeviceConfig> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 597 | pub fn device_addresses(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 602 | pub fn sync_device_addresses(&mut self) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 607 | pub fn create_new_device(&self, address: u8, device_id: String, device_type: String, name: String, location: String) -> DeviceConfig { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 674 | pub fn get_rpm_outlier_settings(&self, address: u8) -> (u16, u16) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 692 | pub fn is_rpm_auto_detect_enabled(&self, address: u8) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 702 | pub fn get_enabled_flowmeter_devices(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 711 | pub fn validate_flowmeter_config(&self) -> Result<(), String> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 736 | pub fn validate_mtws_config(&self) -> Result<(), String> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MqttConfigMessage` is never constructed [INFO] [stdout] --> src/config/mqtt_handler.rs:12:12 [INFO] [stdout] | [INFO] [stdout] 12 | pub struct MqttConfigMessage { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MqttConfigResponse` is never constructed [INFO] [stdout] --> src/config/mqtt_handler.rs:20:12 [INFO] [stdout] | [INFO] [stdout] 20 | pub struct MqttConfigResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MqttConfigHandler` is never constructed [INFO] [stdout] --> src/config/mqtt_handler.rs:25:12 [INFO] [stdout] | [INFO] [stdout] 25 | pub struct MqttConfigHandler { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `MqttClientTrait` is never used [INFO] [stdout] --> src/config/mqtt_handler.rs:33:11 [INFO] [stdout] | [INFO] [stdout] 33 | pub trait MqttClientTrait: Send + Sync { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new`, `set_mqtt_client`, `start_listening`, `handle_mqtt_message`, and `create_command_message` are never used [INFO] [stdout] --> src/config/mqtt_handler.rs:39:12 [INFO] [stdout] | [INFO] [stdout] 38 | impl MqttConfigHandler { [INFO] [stdout] | ---------------------- associated items in this implementation [INFO] [stdout] 39 | pub fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 52 | pub fn set_mqtt_client(&mut self, client: Arc) { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 56 | pub async fn start_listening(&self) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 80 | async fn handle_mqtt_message( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 114 | pub fn create_command_message( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MockMqttClient` is never constructed [INFO] [stdout] --> src/config/mqtt_handler.rs:131:12 [INFO] [stdout] | [INFO] [stdout] 131 | pub struct MockMqttClient; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `read_input_registers` and `read_discrete_inputs` are never used [INFO] [stdout] --> src/modbus/client.rs:23:14 [INFO] [stdout] | [INFO] [stdout] 14 | pub trait ModbusClientTrait: Send + Sync { [INFO] [stdout] | ----------------- methods in this trait [INFO] [stdout] ... [INFO] [stdout] 23 | async fn read_input_registers( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 38 | async fn read_discrete_inputs( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `ModbusRequest` is never used [INFO] [stdout] --> src/modbus/protocol.rs:2:10 [INFO] [stdout] | [INFO] [stdout] 2 | pub enum ModbusRequest { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `ModbusResponse` is never used [INFO] [stdout] --> src/modbus/protocol.rs:18:10 [INFO] [stdout] | [INFO] [stdout] 18 | pub enum ModbusResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `device_type` and `name` are never used [INFO] [stdout] --> src/devices/traits.rs:12:8 [INFO] [stdout] | [INFO] [stdout] 11 | pub trait Device: Send + Sync { [INFO] [stdout] | ------ methods in this trait [INFO] [stdout] 12 | fn device_type(&self) -> &str; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 13 | fn address(&self) -> u8; [INFO] [stdout] 14 | fn name(&self) -> &str; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `get_parameter`, `get_all_parameters`, `get_parameters_as_floats`, `device_type`, `device_name`, and `device_location` are never used [INFO] [stdout] --> src/devices/traits.rs:33:8 [INFO] [stdout] | [INFO] [stdout] 22 | pub trait DeviceData: Send + Sync { [INFO] [stdout] | ---------- methods in this trait [INFO] [stdout] ... [INFO] [stdout] 33 | fn get_parameter(&self, name: &str) -> Option; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 34 | fn get_all_parameters(&self) -> Vec<(String, String)>; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 37 | fn get_parameters_as_floats(&self) -> HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 38 | [INFO] [stdout] 39 | fn device_type(&self) -> String; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 40 | fn device_name(&self) -> String; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 41 | fn device_location(&self) -> String; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `read_data_with_raw` is never used [INFO] [stdout] --> src/devices/flowmeter.rs:48:18 [INFO] [stdout] | [INFO] [stdout] 25 | impl FlowmeterDevice { [INFO] [stdout] | -------------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 48 | pub async fn read_data_with_raw(&self, client: &dyn ModbusClientTrait) -> Result<(Box, FlowmeterRawPayload), ModbusEr... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `to_engineering_units` is never used [INFO] [stdout] --> src/devices/flowmeter.rs:351:12 [INFO] [stdout] | [INFO] [stdout] 293 | impl FlowmeterRawPayload { [INFO] [stdout] | ------------------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 351 | pub fn to_engineering_units(&self) -> FlowmeterData { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `get_primary_channel`, `get_channel`, `get_running_engines`, and `get_total_engine_minutes` are never used [INFO] [stdout] --> src/devices/rpm.rs:78:12 [INFO] [stdout] | [INFO] [stdout] 58 | impl RpmData { [INFO] [stdout] | ------------ methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 78 | pub fn get_primary_channel(&self) -> Option<&RpmChannelData> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 83 | pub fn get_channel(&self, channel_id: u8) -> Option<&RpmChannelData> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 88 | pub fn get_running_engines(&self) -> Vec<&RpmChannelData> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 93 | pub fn get_total_engine_minutes(&self) -> f32 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `location` is never read [INFO] [stdout] --> src/devices/rpm.rs:242:5 [INFO] [stdout] | [INFO] [stdout] 239 | pub struct RpmDevice { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 242 | location: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `detect_channels` is never used [INFO] [stdout] --> src/devices/rpm.rs:296:14 [INFO] [stdout] | [INFO] [stdout] 252 | impl RpmDevice { [INFO] [stdout] | -------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 296 | async fn detect_channels(&self, client: &dyn ModbusClientTrait) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `ConfigError` is never constructed [INFO] [stdout] --> src/utils/error.rs:34:5 [INFO] [stdout] | [INFO] [stdout] 5 | pub enum ModbusError { [INFO] [stdout] | ----------- variant in this enum [INFO] [stdout] ... [INFO] [stdout] 34 | ConfigError(String), [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ModbusError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `format_single_device` and `format_header` are never used [INFO] [stdout] --> src/output/formatters.rs:9:8 [INFO] [stdout] | [INFO] [stdout] 8 | pub trait DataFormatter: Send + Sync { [INFO] [stdout] | ------------- methods in this trait [INFO] [stdout] 9 | fn format_single_device(&self, addr: u8, data: &dyn DeviceData) -> String; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 10 | fn format_header(&self) -> String; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `send` and `destination` are never used [INFO] [stdout] --> src/output/senders.rs:12:14 [INFO] [stdout] | [INFO] [stdout] 11 | pub trait DataSender: Send + Sync { [INFO] [stdout] | ---------- methods in this trait [INFO] [stdout] 12 | async fn send(&self, data: &str) -> Result<(), ModbusError>; [INFO] [stdout] | ^^^^ [INFO] [stdout] 13 | fn sender_type(&self) -> &str; [INFO] [stdout] 14 | fn destination(&self) -> &str; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `file_path` and `append` are never read [INFO] [stdout] --> src/output/senders.rs:36:5 [INFO] [stdout] | [INFO] [stdout] 35 | pub struct FileSender { [INFO] [stdout] | ---------- fields in this struct [INFO] [stdout] 36 | file_path: String, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 37 | append: bool, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `NetworkSender` is never constructed [INFO] [stdout] --> src/output/senders.rs:91:12 [INFO] [stdout] | [INFO] [stdout] 91 | pub struct NetworkSender { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/output/senders.rs:96:12 [INFO] [stdout] | [INFO] [stdout] 95 | impl NetworkSender { [INFO] [stdout] | ------------------ associated function in this implementation [INFO] [stdout] 96 | pub fn new(endpoint: String) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MqttSender` is never constructed [INFO] [stdout] --> src/output/senders.rs:138:12 [INFO] [stdout] | [INFO] [stdout] 138 | pub struct MqttSender { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/output/senders.rs:144:12 [INFO] [stdout] | [INFO] [stdout] 143 | impl MqttSender { [INFO] [stdout] | --------------- associated function in this implementation [INFO] [stdout] 144 | pub fn new(broker_url: String, topic: String) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `WebSocketSender` is never constructed [INFO] [stdout] --> src/output/senders.rs:184:12 [INFO] [stdout] | [INFO] [stdout] 184 | pub struct WebSocketSender { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/output/senders.rs:189:12 [INFO] [stdout] | [INFO] [stdout] 188 | impl WebSocketSender { [INFO] [stdout] | -------------------- associated function in this implementation [INFO] [stdout] 189 | pub fn new(ws_url: String) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `insert_combined_reading`, `cleanup_old_data`, `get_database_stats`, and `close` are never used [INFO] [stdout] --> src/storage/sqlite_manager.rs:470:18 [INFO] [stdout] | [INFO] [stdout] 17 | impl SqliteManager { [INFO] [stdout] | ------------------ methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 470 | pub async fn insert_combined_reading(&self, reading: &CombinedDeviceReading) -> Result<(), ModbusError> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 501 | pub async fn cleanup_old_data(&self, hours_to_keep: i64) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 535 | pub async fn get_database_stats(&self) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 557 | pub async fn close(&self) { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `DatabaseStats` is never constructed [INFO] [stdout] --> src/storage/sqlite_manager.rs:564:12 [INFO] [stdout] | [INFO] [stdout] 564 | pub struct DatabaseStats { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RpmReading` is never constructed [INFO] [stdout] --> src/storage/models.rs:27:12 [INFO] [stdout] | [INFO] [stdout] 27 | pub struct RpmReading { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `from_rpm_data` is never used [INFO] [stdout] --> src/storage/models.rs:44:12 [INFO] [stdout] | [INFO] [stdout] 43 | impl RpmReading { [INFO] [stdout] | --------------- associated function in this implementation [INFO] [stdout] 44 | pub fn from_rpm_data(device_address: u8, rpm_data: &RpmChannelData, engine_duration: u64) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RpmStats` is never constructed [INFO] [stdout] --> src/storage/models.rs:72:12 [INFO] [stdout] | [INFO] [stdout] 72 | pub struct RpmStats { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/storage/models.rs:131:12 [INFO] [stdout] | [INFO] [stdout] 130 | impl MtwsField { [INFO] [stdout] | -------------- associated function in this implementation [INFO] [stdout] 131 | pub fn new(name: String, value: String) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CombinedDeviceReading` is never constructed [INFO] [stdout] --> src/storage/models.rs:154:12 [INFO] [stdout] | [INFO] [stdout] 154 | pub struct CombinedDeviceReading { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `EngineDuration` is never constructed [INFO] [stdout] --> src/storage/models.rs:193:12 [INFO] [stdout] | [INFO] [stdout] 193 | pub struct EngineDuration { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new`, `duration_minutes`, and `duration_hours` are never used [INFO] [stdout] --> src/storage/models.rs:208:12 [INFO] [stdout] | [INFO] [stdout] 207 | impl EngineDuration { [INFO] [stdout] | ------------------- associated items in this implementation [INFO] [stdout] 208 | pub fn new(device_address: u8, channel_id: u8, engine_type: String, rpm_threshold: u16) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 225 | pub fn duration_minutes(&self) -> u64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 229 | pub fn duration_hours(&self) -> f32 { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `EngineDurationHistory` is never constructed [INFO] [stdout] --> src/storage/models.rs:235:12 [INFO] [stdout] | [INFO] [stdout] 235 | pub struct EngineDurationHistory { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MtwsConfig` is never constructed [INFO] [stdout] --> src/storage/models.rs:249:12 [INFO] [stdout] | [INFO] [stdout] 249 | pub struct MtwsConfig { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [optimized + debuginfo] target(s) in 10.53s [INFO] running `Command { std: "docker" "inspect" "c26142c6b69cfd5714db5f0b303fd27862d45ceba1e5d836f644fcac8da54958", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c26142c6b69cfd5714db5f0b303fd27862d45ceba1e5d836f644fcac8da54958", kill_on_drop: false }` [INFO] [stdout] c26142c6b69cfd5714db5f0b303fd27862d45ceba1e5d836f644fcac8da54958 [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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+16fbf98f22730e073c09e7b03f0eafb87a295545" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 390f73071539979c2dc57ab4f366552c76341c7252585ddd19c18963817faa1d [INFO] running `Command { std: "docker" "start" "-a" "390f73071539979c2dc57ab4f366552c76341c7252585ddd19c18963817faa1d", kill_on_drop: false }` [INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: unused manifest key: target.aarch64-unknown-linux-gnu.ar [INFO] [stderr] warning: /opt/rustwide/workdir/Cargo.toml: unused manifest key: target.aarch64-unknown-linux-gnu.linker [INFO] [stderr] warning: unused imports: `DateTime` and `Utc` [INFO] [stderr] --> src/config/settings.rs:1:14 [INFO] [stderr] | [INFO] [stderr] 1 | use chrono::{DateTime, Utc}; [INFO] [stderr] | ^^^^^^^^ ^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `warn` [INFO] [stderr] --> src/config/settings.rs:3:31 [INFO] [stderr] | [INFO] [stderr] 3 | use log::{debug, error, info, warn}; [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `warn` [INFO] [stderr] --> src/config/mqtt_handler.rs:1:17 [INFO] [stderr] | [INFO] [stderr] 1 | use log::{info, warn, error}; [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `timeout` [INFO] [stderr] --> src/devices/gps/gps_service.rs:3:39 [INFO] [stderr] | [INFO] [stderr] 3 | use tokio::time::{Duration, interval, timeout}; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::path::Path` [INFO] [stderr] --> src/services/data_service.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::path::Path; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::fs` [INFO] [stderr] --> src/services/data_service.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use tokio::fs; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `interval` and `sleep` [INFO] [stderr] --> src/services/data_service.rs:6:19 [INFO] [stderr] | [INFO] [stderr] 6 | use tokio::time::{sleep, interval, Duration}; [INFO] [stderr] | ^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::sync::mpsc` [INFO] [stderr] --> src/services/data_service.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use tokio::sync::mpsc; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `serde_json::json` [INFO] [stderr] --> src/services/data_service.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | use serde_json::json; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `debug` and `warn` [INFO] [stderr] --> src/services/database_service.rs:1:24 [INFO] [stderr] | [INFO] [stderr] 1 | use log::{info, error, warn, debug}; [INFO] [stderr] | ^^^^ ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Duration` and `interval` [INFO] [stderr] --> src/services/database_service.rs:4:19 [INFO] [stderr] | [INFO] [stderr] 4 | use tokio::time::{interval, Duration}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `DateTime` [INFO] [stderr] --> src/services/database_service.rs:5:14 [INFO] [stderr] | [INFO] [stderr] 5 | use chrono::{DateTime, Utc}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `error` [INFO] [stderr] --> src/services/api_service.rs:2:17 [INFO] [stderr] | [INFO] [stderr] 2 | use log::{info, error, warn}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `MtwsField` [INFO] [stderr] --> src/services/mtws_service.rs:13:43 [INFO] [stderr] | [INFO] [stderr] 13 | use crate::storage::models::{MtwsPayload, MtwsField}; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `chrono::Utc` [INFO] [stderr] --> src/output/formatters.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use chrono::Utc; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `serde_json::Value` [INFO] [stderr] --> src/output/formatters.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use serde_json::Value; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::collections::HashMap` [INFO] [stderr] --> src/output/formatters.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::collections::HashMap; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `crate::utils::error::ModbusError` [INFO] [stderr] --> src/output/formatters.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use crate::utils::error::ModbusError; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `error` [INFO] [stderr] --> src/output/raw_sender.rs:2:17 [INFO] [stderr] | [INFO] [stderr] 2 | use log::{info, error}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fmt` [INFO] [stderr] --> src/utils/error.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::fmt; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `RpmReading` [INFO] [stderr] --> src/storage/sqlite_manager.rs:8:64 [INFO] [stderr] | [INFO] [stderr] 8 | use crate::storage::models::{FlowmeterReading, FlowmeterStats, RpmReading, CombinedDeviceReading}; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `DateTime` [INFO] [stderr] --> src/storage/models.rs:1:14 [INFO] [stderr] | [INFO] [stderr] 1 | use chrono::{DateTime, Utc}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `total_channels` [INFO] [stderr] --> src/services/data_service.rs:419:26 [INFO] [stderr] | [INFO] [stderr] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stderr] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_total_channels` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `thresholds` [INFO] [stderr] --> src/services/data_service.rs:419:42 [INFO] [stderr] | [INFO] [stderr] 419 | let (total_channels, thresholds) = self.config.get_rpm_channel_config(device_config.address); [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_thresholds` [INFO] [stderr] [INFO] [stderr] warning: unused import: `Row` [INFO] [stderr] --> src/storage/sqlite_manager.rs:3:24 [INFO] [stderr] | [INFO] [stderr] 3 | use sqlx::{SqlitePool, Row}; [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `device_id` [INFO] [stderr] --> src/config/settings.rs:607:50 [INFO] [stderr] | [INFO] [stderr] 607 | pub fn create_new_device(&self, address: u8, device_id: String, device_type: String, name: String, location: String) -> DeviceConfig { [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/config/dynamic_manager.rs:511:13 [INFO] [stderr] | [INFO] [stderr] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stderr] | ^ no value can reach this [INFO] [stderr] | [INFO] [stderr] note: multiple earlier patterns match some of the same values [INFO] [stderr] --> src/config/dynamic_manager.rs:511:13 [INFO] [stderr] | [INFO] [stderr] 233 | ConfigTarget::System => { [INFO] [stderr] | -------------------- matches some of the same values [INFO] [stderr] ... [INFO] [stderr] 264 | ConfigTarget::Monitoring => { [INFO] [stderr] | ------------------------ matches some of the same values [INFO] [stderr] ... [INFO] [stderr] 317 | ConfigTarget::Serial => { [INFO] [stderr] | -------------------- matches some of the same values [INFO] [stderr] ... [INFO] [stderr] 344 | ConfigTarget::Gps => { [INFO] [stderr] | ----------------- matches some of the same values [INFO] [stderr] ... [INFO] [stderr] 511 | _ => return Err(ModbusError::InvalidData(format!("Unsupported target for SET command: {:?}", command.target))), [INFO] [stderr] | ^ ...and 3 other patterns collectively make this unreachable [INFO] [stderr] = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `mtws` [INFO] [stderr] --> src/services/data_service.rs:850:21 [INFO] [stderr] | [INFO] [stderr] 850 | if let Some(mtws) = &self.mtws_service { [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_mtws` [INFO] [stderr] [INFO] [stderr] warning: field `location` is never read [INFO] [stderr] --> src/devices/rpm.rs:242:5 [INFO] [stderr] | [INFO] [stderr] 239 | pub struct RpmDevice { [INFO] [stderr] | --------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 242 | location: String, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: method `detect_channels` is never used [INFO] [stderr] --> src/devices/rpm.rs:296:14 [INFO] [stderr] | [INFO] [stderr] 252 | impl RpmDevice { [INFO] [stderr] | -------------- method in this implementation [INFO] [stderr] ... [INFO] [stderr] 296 | async fn detect_channels(&self, client: &dyn ModbusClientTrait) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method `get_address_from_uuid` is never used [INFO] [stderr] --> src/services/data_service.rs:634:8 [INFO] [stderr] | [INFO] [stderr] 71 | impl DataService { [INFO] [stderr] | ---------------- method in this implementation [INFO] [stderr] ... [INFO] [stderr] 634 | fn get_address_from_uuid(&self, uuid: &str) -> Option { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `shutdown_tx` is never read [INFO] [stderr] --> src/services/database_service.rs:19:5 [INFO] [stderr] | [INFO] [stderr] 14 | pub struct DatabaseService { [INFO] [stderr] | --------------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 19 | shutdown_tx: Option>, [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `DatabaseService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: field `endpoint_url` is never read [INFO] [stderr] --> src/services/mtws_service.rs:21:5 [INFO] [stderr] | [INFO] [stderr] 16 | pub struct MtwsService { [INFO] [stderr] | ----------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 21 | endpoint_url: Arc>>, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `MtwsService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: function `send_mtws_http_request` is never used [INFO] [stderr] --> src/cli/commands.rs:708:10 [INFO] [stderr] | [INFO] [stderr] 708 | async fn send_mtws_http_request( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `ipc_dev_rust` (lib) generated 34 warnings (run `cargo fix --lib -p ipc_dev_rust` to apply 22 suggestions) [INFO] [stderr] warning: `ipc_dev_rust` (lib test) generated 34 warnings (34 duplicates) [INFO] [stderr] warning: unused import: `std::path::Path` [INFO] [stderr] --> src/services/data_service.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::path::Path; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `api_service::ApiServiceState` [INFO] [stderr] --> src/services/mod.rs:9:9 [INFO] [stderr] | [INFO] [stderr] 9 | pub use api_service::ApiServiceState; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DateTime` and `Utc` [INFO] [stderr] --> src/config/settings.rs:1:14 [INFO] [stderr] | [INFO] [stderr] 1 | use chrono::{DateTime, Utc}; [INFO] [stderr] | ^^^^^^^^ ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `ApiServerConfig`, `DataCollectionConfig`, `FileOutputConfig`, `GpsConfig`, `HttpOutputConfig`, `MqttOutputConfig`, `OutputConfig`, `ParityConfig`, `RegisterConfig`, `SiteInfo`, and `SqliteConfig` [INFO] [stderr] --> src/config/mod.rs:9:5 [INFO] [stderr] | [INFO] [stderr] 9 | ParityConfig, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] 10 | SiteInfo, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] 11 | DataCollectionConfig, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 12 | OutputConfig, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] 13 | FileOutputConfig, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] 14 | HttpOutputConfig, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] 15 | MqttOutputConfig, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] 16 | DatabaseOutputConfig, [INFO] [stderr] 17 | SqliteConfig, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] 18 | RegisterConfig, [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] 19 | ApiServerConfig, [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] 20 | GpsConfig, // Add this [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `ConfigCommandType`, `ConfigTarget`, `ConfigurationCommand`, and `ConfigurationResponse` [INFO] [stderr] --> src/config/mod.rs:25:5 [INFO] [stderr] | [INFO] [stderr] 25 | ConfigurationCommand, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 26 | ConfigurationResponse, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 27 | ConfigCommandType, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] 28 | ConfigTarget [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `MqttConfigHandler`, `MqttConfigMessage`, and `MqttConfigResponse` [INFO] [stderr] --> src/config/mod.rs:31:24 [INFO] [stderr] | [INFO] [stderr] 31 | pub use mqtt_handler::{MqttConfigHandler, MqttConfigMessage, MqttConfigResponse}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `ModbusRequest` and `ModbusResponse` [INFO] [stderr] --> src/modbus/mod.rs:6:20 [INFO] [stderr] | [INFO] [stderr] 6 | pub use protocol::{ModbusRequest, ModbusResponse}; [INFO] [stderr] | ^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `crc::crc16_modbus` [INFO] [stderr] --> src/modbus/mod.rs:7:9 [INFO] [stderr] | [INFO] [stderr] 7 | pub use crc::crc16_modbus; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `FlowmeterData` [INFO] [stderr] --> src/devices/mod.rs:7:38 [INFO] [stderr] | [INFO] [stderr] 7 | pub use flowmeter::{FlowmeterDevice, FlowmeterData}; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `GpsData` and `GpsService` [INFO] [stderr] --> src/devices/mod.rs:9:15 [INFO] [stderr] | [INFO] [stderr] 9 | pub use gps::{GpsService, GpsData}; [INFO] [stderr] | ^^^^^^^^^^ ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `MqttSender`, `NetworkSender`, and `WebSocketSender` [INFO] [stderr] --> src/output/mod.rs:7:58 [INFO] [stderr] | [INFO] [stderr] 7 | pub use senders::{DataSender, ConsoleSender, FileSender, NetworkSender, MqttSender, WebSocketSender}; [INFO] [stderr] | ^^^^^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `RawDataFormat` and `RawDataSender` [INFO] [stderr] --> src/output/mod.rs:8:22 [INFO] [stderr] | [INFO] [stderr] 8 | pub use raw_sender::{RawDataSender, RawDataFormat}; [INFO] [stderr] | ^^^^^^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `EngineDurationHistory`, `EngineDuration`, `FlowmeterReading`, `FlowmeterStats`, `RpmReading`, and `RpmStats` [INFO] [stderr] --> src/storage/mod.rs:4:18 [INFO] [stderr] | [INFO] [stderr] 4 | pub use models::{EngineDuration, EngineDurationHistory, FlowmeterReading, FlowmeterStats, RpmReading, RpmStats}; [INFO] [stderr] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `DatabaseStats` [INFO] [stderr] --> src/storage/mod.rs:5:26 [INFO] [stderr] | [INFO] [stderr] 5 | pub use sqlite_manager::{DatabaseStats, SqliteManager}; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `ArgMatches` [INFO] [stderr] --> src/main.rs:11:37 [INFO] [stderr] | [INFO] [stderr] 11 | use clap::{Arg, Command, ArgAction, ArgMatches}; // Add ArgMatches here [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: multiple methods are never used [INFO] [stderr] --> src/services/data_service.rs:538:18 [INFO] [stderr] | [INFO] [stderr] 71 | impl DataService { [INFO] [stderr] | ---------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 538 | pub async fn get_engine_durations(&self) -> HashMap { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 564 | pub fn get_database_service_mut(&mut self) -> Option<&mut DatabaseService> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 568 | pub async fn check_database_health(&self) -> Result, ModbusError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 634 | fn get_address_from_uuid(&self, uuid: &str) -> Option { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 742 | pub async fn refresh_gps_data(&self) -> Result, ModbusError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 780 | pub fn get_api_service(&self) -> Option<&crate::services::api_service::ApiService> { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 837 | pub fn get_mtws_service_mut(&mut self) -> Option<&mut MtwsService> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 855 | pub fn has_mtws_service(&self) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 860 | pub async fn get_current_device_data(&mut self) -> HashMap { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: fields `is_running` and `shutdown_tx` are never read [INFO] [stderr] --> src/services/database_service.rs:18:5 [INFO] [stderr] | [INFO] [stderr] 14 | pub struct DatabaseService { [INFO] [stderr] | --------------- fields in this struct [INFO] [stderr] ... [INFO] [stderr] 18 | is_running: Arc>, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] 19 | shutdown_tx: Option>, [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `DatabaseService` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: methods `flush_buffer` and `stop` are never used [INFO] [stderr] --> src/services/database_service.rs:123:18 [INFO] [stderr] | [INFO] [stderr] 22 | impl DatabaseService { [INFO] [stderr] | -------------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 123 | pub async fn flush_buffer(&self) -> Result<(), ModbusError> { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 136 | pub async fn stop(&self) -> Result<(), ModbusError> { [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum `FlowType` is never used [INFO] [stderr] --> src/services/api_service.rs:15:10 [INFO] [stderr] | [INFO] [stderr] 15 | pub enum FlowType { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `sqlite_manager`, `config`, and `data_service` are never read [INFO] [stderr] --> src/services/api_service.rs:44:9 [INFO] [stderr] | [INFO] [stderr] 43 | pub struct ApiServiceState { [INFO] [stderr] | --------------- fields in this struct [INFO] [stderr] 44 | pub sqlite_manager: SqliteManager, [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] 45 | pub config: Config, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] 46 | pub data_service: Option>, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `ApiServiceState` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: associated items `new`, `start_mtws_transmission`, `stop_mtws_transmission`, `send_mtws_payload`, and `get_mtws_status` are never used [INFO] [stderr] --> src/services/api_service.rs:78:12 [INFO] [stderr] | [INFO] [stderr] 77 | impl ApiService { [INFO] [stderr] | --------------- associated items in this implementation [INFO] [stderr] 78 | pub fn new(config: Config, sqlite_manager: SqliteManager) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 148 | pub async fn start_mtws_transmission(&self) -> Result<(), ModbusError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 157 | pub async fn stop_mtws_transmission(&self) -> Result<(), ModbusError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 166 | pub async fn send_mtws_payload(&self, endpoint_url: Option) -> Result<(), ModbusError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 179 | pub async fn get_mtws_status(&self) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `MtwsStatus` is never constructed [INFO] [stderr] --> src/services/api_service.rs:197:12 [INFO] [stderr] | [INFO] [stderr] 197 | pub struct MtwsStatus { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `set_transmission_interval`, `print_current_payload`, and `get_payload_summary` are never used [INFO] [stderr] --> src/services/mtws_service.rs:535:18 [INFO] [stderr] | [INFO] [stderr] 41 | impl MtwsService { [INFO] [stderr] | ---------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 535 | pub async fn set_transmission_interval(&self, seconds: u64) -> Result<(), ModbusError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 554 | pub async fn print_current_payload(&self) -> Result<(), ModbusError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 574 | pub async fn get_payload_summary(&self) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `RegisterConfig` is never constructed [INFO] [stderr] --> src/config/settings.rs:266:12 [INFO] [stderr] | [INFO] [stderr] 266 | pub struct RegisterConfig { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `get_default_parameters_for_type` is never used [INFO] [stderr] --> src/config/settings.rs:409:4 [INFO] [stderr] | [INFO] [stderr] 409 | fn get_default_parameters_for_type(device_type: &str) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: multiple methods are never used [INFO] [stderr] --> src/config/settings.rs:587:12 [INFO] [stderr] | [INFO] [stderr] 432 | impl Config { [INFO] [stderr] | ----------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 587 | pub fn get_device_by_uuid(&self, uuid: &str) -> Option<&DeviceConfig> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 592 | pub fn get_device_by_name(&self, name: &str) -> Option<&DeviceConfig> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 597 | pub fn device_addresses(&self) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 602 | pub fn sync_device_addresses(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 607 | pub fn create_new_device(&self, address: u8, device_id: String, device_type: String, name: String, location: String) -> DeviceConfig { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 674 | pub fn get_rpm_outlier_settings(&self, address: u8) -> (u16, u16) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 692 | pub fn is_rpm_auto_detect_enabled(&self, address: u8) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 702 | pub fn get_enabled_flowmeter_devices(&self) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 711 | pub fn validate_flowmeter_config(&self) -> Result<(), String> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 736 | pub fn validate_mtws_config(&self) -> Result<(), String> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `MqttConfigMessage` is never constructed [INFO] [stderr] --> src/config/mqtt_handler.rs:12:12 [INFO] [stderr] | [INFO] [stderr] 12 | pub struct MqttConfigMessage { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `MqttConfigResponse` is never constructed [INFO] [stderr] --> src/config/mqtt_handler.rs:20:12 [INFO] [stderr] | [INFO] [stderr] 20 | pub struct MqttConfigResponse { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `MqttConfigHandler` is never constructed [INFO] [stderr] --> src/config/mqtt_handler.rs:25:12 [INFO] [stderr] | [INFO] [stderr] 25 | pub struct MqttConfigHandler { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait `MqttClientTrait` is never used [INFO] [stderr] --> src/config/mqtt_handler.rs:33:11 [INFO] [stderr] | [INFO] [stderr] 33 | pub trait MqttClientTrait: Send + Sync { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated items `new`, `set_mqtt_client`, `start_listening`, `handle_mqtt_message`, and `create_command_message` are never used [INFO] [stderr] --> src/config/mqtt_handler.rs:39:12 [INFO] [stderr] | [INFO] [stderr] 38 | impl MqttConfigHandler { [INFO] [stderr] | ---------------------- associated items in this implementation [INFO] [stderr] 39 | pub fn new( [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 52 | pub fn set_mqtt_client(&mut self, client: Arc) { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 56 | pub async fn start_listening(&self) -> Result<(), ModbusError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 80 | async fn handle_mqtt_message( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 114 | pub fn create_command_message( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `MockMqttClient` is never constructed [INFO] [stderr] --> src/config/mqtt_handler.rs:131:12 [INFO] [stderr] | [INFO] [stderr] 131 | pub struct MockMqttClient; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `read_input_registers` and `read_discrete_inputs` are never used [INFO] [stderr] --> src/modbus/client.rs:23:14 [INFO] [stderr] | [INFO] [stderr] 14 | pub trait ModbusClientTrait: Send + Sync { [INFO] [stderr] | ----------------- methods in this trait [INFO] [stderr] ... [INFO] [stderr] 23 | async fn read_input_registers( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 38 | async fn read_discrete_inputs( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum `ModbusRequest` is never used [INFO] [stderr] --> src/modbus/protocol.rs:2:10 [INFO] [stderr] | [INFO] [stderr] 2 | pub enum ModbusRequest { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum `ModbusResponse` is never used [INFO] [stderr] --> src/modbus/protocol.rs:18:10 [INFO] [stderr] | [INFO] [stderr] 18 | pub enum ModbusResponse { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `device_type` and `name` are never used [INFO] [stderr] --> src/devices/traits.rs:12:8 [INFO] [stderr] | [INFO] [stderr] 11 | pub trait Device: Send + Sync { [INFO] [stderr] | ------ methods in this trait [INFO] [stderr] 12 | fn device_type(&self) -> &str; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] 13 | fn address(&self) -> u8; [INFO] [stderr] 14 | fn name(&self) -> &str; [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `get_parameter`, `get_all_parameters`, `get_parameters_as_floats`, `device_type`, `device_name`, and `device_location` are never used [INFO] [stderr] --> src/devices/traits.rs:33:8 [INFO] [stderr] | [INFO] [stderr] 22 | pub trait DeviceData: Send + Sync { [INFO] [stderr] | ---------- methods in this trait [INFO] [stderr] ... [INFO] [stderr] 33 | fn get_parameter(&self, name: &str) -> Option; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] 34 | fn get_all_parameters(&self) -> Vec<(String, String)>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 37 | fn get_parameters_as_floats(&self) -> HashMap; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 38 | [INFO] [stderr] 39 | fn device_type(&self) -> String; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] 40 | fn device_name(&self) -> String; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] 41 | fn device_location(&self) -> String; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method `read_data_with_raw` is never used [INFO] [stderr] --> src/devices/flowmeter.rs:48:18 [INFO] [stderr] | [INFO] [stderr] 25 | impl FlowmeterDevice { [INFO] [stderr] | -------------------- method in this implementation [INFO] [stderr] ... [INFO] [stderr] 48 | pub async fn read_data_with_raw(&self, client: &dyn ModbusClientTrait) -> Result<(Box, FlowmeterRawPayload), ModbusEr... [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method `to_engineering_units` is never used [INFO] [stderr] --> src/devices/flowmeter.rs:351:12 [INFO] [stderr] | [INFO] [stderr] 293 | impl FlowmeterRawPayload { [INFO] [stderr] | ------------------------ method in this implementation [INFO] [stderr] ... [INFO] [stderr] 351 | pub fn to_engineering_units(&self) -> FlowmeterData { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `get_primary_channel`, `get_channel`, `get_running_engines`, and `get_total_engine_minutes` are never used [INFO] [stderr] --> src/devices/rpm.rs:78:12 [INFO] [stderr] | [INFO] [stderr] 58 | impl RpmData { [INFO] [stderr] | ------------ methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 78 | pub fn get_primary_channel(&self) -> Option<&RpmChannelData> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 83 | pub fn get_channel(&self, channel_id: u8) -> Option<&RpmChannelData> { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 88 | pub fn get_running_engines(&self) -> Vec<&RpmChannelData> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 93 | pub fn get_total_engine_minutes(&self) -> f32 { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `location` is never read [INFO] [stderr] --> src/devices/rpm.rs:242:5 [INFO] [stderr] | [INFO] [stderr] 239 | pub struct RpmDevice { [INFO] [stderr] | --------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 242 | location: String, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant `ConfigError` is never constructed [INFO] [stderr] --> src/utils/error.rs:34:5 [INFO] [stderr] | [INFO] [stderr] 5 | pub enum ModbusError { [INFO] [stderr] | ----------- variant in this enum [INFO] [stderr] ... [INFO] [stderr] 34 | ConfigError(String), [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `ModbusError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: methods `format_single_device` and `format_header` are never used [INFO] [stderr] --> src/output/formatters.rs:9:8 [INFO] [stderr] | [INFO] [stderr] 8 | pub trait DataFormatter: Send + Sync { [INFO] [stderr] | ------------- methods in this trait [INFO] [stderr] 9 | fn format_single_device(&self, addr: u8, data: &dyn DeviceData) -> String; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 10 | fn format_header(&self) -> String; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `send` and `destination` are never used [INFO] [stderr] --> src/output/senders.rs:12:14 [INFO] [stderr] | [INFO] [stderr] 11 | pub trait DataSender: Send + Sync { [INFO] [stderr] | ---------- methods in this trait [INFO] [stderr] 12 | async fn send(&self, data: &str) -> Result<(), ModbusError>; [INFO] [stderr] | ^^^^ [INFO] [stderr] 13 | fn sender_type(&self) -> &str; [INFO] [stderr] 14 | fn destination(&self) -> &str; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `file_path` and `append` are never read [INFO] [stderr] --> src/output/senders.rs:36:5 [INFO] [stderr] | [INFO] [stderr] 35 | pub struct FileSender { [INFO] [stderr] | ---------- fields in this struct [INFO] [stderr] 36 | file_path: String, [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] 37 | append: bool, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `NetworkSender` is never constructed [INFO] [stderr] --> src/output/senders.rs:91:12 [INFO] [stderr] | [INFO] [stderr] 91 | pub struct NetworkSender { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `new` is never used [INFO] [stderr] --> src/output/senders.rs:96:12 [INFO] [stderr] | [INFO] [stderr] 95 | impl NetworkSender { [INFO] [stderr] | ------------------ associated function in this implementation [INFO] [stderr] 96 | pub fn new(endpoint: String) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `MqttSender` is never constructed [INFO] [stderr] --> src/output/senders.rs:138:12 [INFO] [stderr] | [INFO] [stderr] 138 | pub struct MqttSender { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `new` is never used [INFO] [stderr] --> src/output/senders.rs:144:12 [INFO] [stderr] | [INFO] [stderr] 143 | impl MqttSender { [INFO] [stderr] | --------------- associated function in this implementation [INFO] [stderr] 144 | pub fn new(broker_url: String, topic: String) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `WebSocketSender` is never constructed [INFO] [stderr] --> src/output/senders.rs:184:12 [INFO] [stderr] | [INFO] [stderr] 184 | pub struct WebSocketSender { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `new` is never used [INFO] [stderr] --> src/output/senders.rs:189:12 [INFO] [stderr] | [INFO] [stderr] 188 | impl WebSocketSender { [INFO] [stderr] | -------------------- associated function in this implementation [INFO] [stderr] 189 | pub fn new(ws_url: String) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `insert_combined_reading`, `cleanup_old_data`, `get_database_stats`, and `close` are never used [INFO] [stderr] --> src/storage/sqlite_manager.rs:470:18 [INFO] [stderr] | [INFO] [stderr] 17 | impl SqliteManager { [INFO] [stderr] | ------------------ methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 470 | pub async fn insert_combined_reading(&self, reading: &CombinedDeviceReading) -> Result<(), ModbusError> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 501 | pub async fn cleanup_old_data(&self, hours_to_keep: i64) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 535 | pub async fn get_database_stats(&self) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 557 | pub async fn close(&self) { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `DatabaseStats` is never constructed [INFO] [stderr] --> src/storage/sqlite_manager.rs:564:12 [INFO] [stderr] | [INFO] [stderr] 564 | pub struct DatabaseStats { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `RpmReading` is never constructed [INFO] [stderr] --> src/storage/models.rs:27:12 [INFO] [stderr] | [INFO] [stderr] 27 | pub struct RpmReading { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `from_rpm_data` is never used [INFO] [stderr] --> src/storage/models.rs:44:12 [INFO] [stderr] | [INFO] [stderr] 43 | impl RpmReading { [INFO] [stderr] | --------------- associated function in this implementation [INFO] [stderr] 44 | pub fn from_rpm_data(device_address: u8, rpm_data: &RpmChannelData, engine_duration: u64) -> Self { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `RpmStats` is never constructed [INFO] [stderr] --> src/storage/models.rs:72:12 [INFO] [stderr] | [INFO] [stderr] 72 | pub struct RpmStats { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `new` is never used [INFO] [stderr] --> src/storage/models.rs:131:12 [INFO] [stderr] | [INFO] [stderr] 130 | impl MtwsField { [INFO] [stderr] | -------------- associated function in this implementation [INFO] [stderr] 131 | pub fn new(name: String, value: String) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `CombinedDeviceReading` is never constructed [INFO] [stderr] --> src/storage/models.rs:154:12 [INFO] [stderr] | [INFO] [stderr] 154 | pub struct CombinedDeviceReading { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `EngineDuration` is never constructed [INFO] [stderr] --> src/storage/models.rs:193:12 [INFO] [stderr] | [INFO] [stderr] 193 | pub struct EngineDuration { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated items `new`, `duration_minutes`, and `duration_hours` are never used [INFO] [stderr] --> src/storage/models.rs:208:12 [INFO] [stderr] | [INFO] [stderr] 207 | impl EngineDuration { [INFO] [stderr] | ------------------- associated items in this implementation [INFO] [stderr] 208 | pub fn new(device_address: u8, channel_id: u8, engine_type: String, rpm_threshold: u16) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 225 | pub fn duration_minutes(&self) -> u64 { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 229 | pub fn duration_hours(&self) -> f32 { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `EngineDurationHistory` is never constructed [INFO] [stderr] --> src/storage/models.rs:235:12 [INFO] [stderr] | [INFO] [stderr] 235 | pub struct EngineDurationHistory { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `MtwsConfig` is never constructed [INFO] [stderr] --> src/storage/models.rs:249:12 [INFO] [stderr] | [INFO] [stderr] 249 | pub struct MtwsConfig { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `ipc_dev_rust` (bin "ipc_dev_rust" test) generated 91 warnings (29 duplicates) (run `cargo fix --bin "ipc_dev_rust" --tests` to apply 15 suggestions) [INFO] [stderr] Finished `test` profile [optimized + debuginfo] target(s) in 0.51s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/ipc_dev_rust-219dafed3e9f33c7) [INFO] [stdout] [INFO] [stdout] running 1 test [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/ipc_dev_rust-16523aad71cfab38) [INFO] [stdout] test modbus::crc::tests::test_crc16_modbus ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 1 test [INFO] [stdout] test modbus::crc::tests::test_crc16_modbus ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.16s [INFO] [stdout] [INFO] [stderr] Doc-tests ipc_dev_rust [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "390f73071539979c2dc57ab4f366552c76341c7252585ddd19c18963817faa1d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "390f73071539979c2dc57ab4f366552c76341c7252585ddd19c18963817faa1d", kill_on_drop: false }` [INFO] [stdout] 390f73071539979c2dc57ab4f366552c76341c7252585ddd19c18963817faa1d