[INFO] fetching crate ecu_diagnostics 0.95.2...
[INFO] checking ecu_diagnostics-0.95.2 against master#30f74ff0dc4d66debc8b50724c446f817e5f75f4 for pr-121848-1
[INFO] extracting crate ecu_diagnostics 0.95.2 into /workspace/builds/worker-3-tc1/source
[INFO] validating manifest of crates.io crate ecu_diagnostics 0.95.2 on toolchain 30f74ff0dc4d66debc8b50724c446f817e5f75f4
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate ecu_diagnostics 0.95.2
[INFO] finished tweaking crates.io crate ecu_diagnostics 0.95.2
[INFO] tweaked toml for crates.io crate ecu_diagnostics 0.95.2 written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] crate crates.io crate ecu_diagnostics 0.95.2 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" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded automotive_diag v0.1.3
[INFO] [stderr]   Downloaded socketcan v1.7.0
[INFO] [stderr]   Downloaded displaydoc v0.2.3
[INFO] [stderr]   Downloaded enum2repr v0.1.14
[INFO] [stderr]   Downloaded j2534_rust v1.5.0
[INFO] [stderr]   Downloaded embedded-can v0.3.0
[INFO] [stderr]   Downloaded socketcan-isotp v1.0.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] fd01da81ffeda4439d11cddcc43e0c100120a31c6935ec2c5c21a6ea38bd81ed
[INFO] running `Command { std: "docker" "start" "-a" "fd01da81ffeda4439d11cddcc43e0c100120a31c6935ec2c5c21a6ea38bd81ed", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "fd01da81ffeda4439d11cddcc43e0c100120a31c6935ec2c5c21a6ea38bd81ed", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fd01da81ffeda4439d11cddcc43e0c100120a31c6935ec2c5c21a6ea38bd81ed", kill_on_drop: false }`
[INFO] [stdout] fd01da81ffeda4439d11cddcc43e0c100120a31c6935ec2c5c21a6ea38bd81ed
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5fb101cfd55d644b91caaff272baa5c8c0aa719bb06f78ed89e5c45ea36b7980
[INFO] running `Command { std: "docker" "start" "-a" "5fb101cfd55d644b91caaff272baa5c8c0aa719bb06f78ed89e5c45ea36b7980", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.141
[INFO] [stderr]    Compiling proc-macro2 v1.0.66
[INFO] [stderr]    Compiling unicode-ident v1.0.8
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling memoffset v0.6.5
[INFO] [stderr]    Compiling io-lifetimes v1.0.10
[INFO] [stderr]    Compiling rustix v0.37.11
[INFO] [stderr]    Compiling serde v1.0.160
[INFO] [stderr]    Compiling thiserror v1.0.44
[INFO] [stderr]    Compiling rustversion v1.0.12
[INFO] [stderr]     Checking linux-raw-sys v0.3.1
[INFO] [stderr]    Compiling serde_json v1.0.96
[INFO] [stderr]     Checking bitflags v0.4.0
[INFO] [stderr]     Checking nb v1.1.0
[INFO] [stderr]     Checking aho-corasick v0.7.20
[INFO] [stderr]     Checking regex-syntax v0.6.29
[INFO] [stderr]     Checking try_from v0.2.2
[INFO] [stderr]     Checking ryu v1.0.13
[INFO] [stderr]     Checking embedded-can v0.3.0
[INFO] [stderr]     Checking itertools v0.4.19
[INFO] [stderr]     Checking hex v0.2.0
[INFO] [stderr]     Checking itoa v1.0.6
[INFO] [stderr]     Checking libloading v0.7.4
[INFO] [stderr]     Checking j2534_rust v1.5.0
[INFO] [stderr]     Checking termcolor v1.2.0
[INFO] [stderr]     Checking strum v0.24.1
[INFO] [stderr]    Compiling quote v1.0.32
[INFO] [stderr]     Checking regex v1.7.3
[INFO] [stderr]    Compiling syn v2.0.28
[INFO] [stderr]     Checking dirs-sys v0.3.7
[INFO] [stderr]     Checking nix v0.24.3
[INFO] [stderr]     Checking nix v0.5.1
[INFO] [stderr]     Checking dirs v4.0.0
[INFO] [stderr]     Checking shellexpand v2.1.2
[INFO] [stderr]     Checking socketcan v1.7.0
[INFO] [stderr]     Checking is-terminal v0.4.7
[INFO] [stderr]     Checking env_logger v0.10.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.44
[INFO] [stderr]    Compiling displaydoc v0.2.3
[INFO] [stderr]    Compiling enum2repr v0.1.14
[INFO] [stderr]    Compiling strum_macros v0.24.3
[INFO] [stderr]     Checking automotive_diag v0.1.3
[INFO] [stderr]     Checking socketcan-isotp v1.0.1
[INFO] [stderr]     Checking ecu_diagnostics v0.95.2 (/opt/rustwide/workdir)
[INFO] [stdout] error: the item `Arc` is imported redundantly
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:3:30
[INFO] [stdout]    |
[INFO] [stdout] 3  | use std::sync::{mpsc, Mutex, Arc};
[INFO] [stdout]    |                              ^^^
[INFO] [stdout] ...
[INFO] [stdout] 12 | use crate::hardware::*;
[INFO] [stdout]    |     ------------------ the item `Arc` is already imported here
[INFO] [stdout]    |
[INFO] [stdout] note: the lint level is defined here
[INFO] [stdout]   --> src/lib.rs:7:5
[INFO] [stdout]    |
[INFO] [stdout] 7  |     unused_imports,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/sw_isotp.rs:478:40
[INFO] [stdout]     |
[INFO] [stdout] 478 |                     std::thread::sleep(std::time::Duration::from_millis(10));
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] note: the lint level is defined here
[INFO] [stdout]    --> src/lib.rs:9:5
[INFO] [stdout]     |
[INFO] [stdout] 9   |     unused_qualifications,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 478 -                     std::thread::sleep(std::time::Duration::from_millis(10));
[INFO] [stdout] 478 +                     std::thread::sleep(Duration::from_millis(10));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/sw_isotp.rs:480:40
[INFO] [stdout]     |
[INFO] [stdout] 480 |                     std::thread::sleep(std::time::Duration::from_millis(1));
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 480 -                     std::thread::sleep(std::time::Duration::from_millis(1));
[INFO] [stdout] 480 +                     std::thread::sleep(Duration::from_millis(1));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/mod.rs:284:39
[INFO] [stdout]     |
[INFO] [stdout] 284 |         let drv = Arc::new(Mutex::new(lib_funcs::PassthruDrv::load_lib(lib)?));
[INFO] [stdout]     |                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 284 -         let drv = Arc::new(Mutex::new(lib_funcs::PassthruDrv::load_lib(lib)?));
[INFO] [stdout] 284 +         let drv = Arc::new(Mutex::new(PassthruDrv::load_lib(lib)?));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ecu_reset::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub use ecu_reset::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `error::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub use error::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `message_transmission::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub use message_transmission::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_data_by_identifier::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:40:9
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub use read_data_by_identifier::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_memory_by_address::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub use read_memory_by_address::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_status_of_dtc::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub use read_status_of_dtc::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `security_access::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub use security_access::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `start_diagnostic_session::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:48:9
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub use start_diagnostic_session::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:38:32
[INFO] [stdout]    |
[INFO] [stdout] 38 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 38 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 38 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: the item `Arc` is imported redundantly
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:3:30
[INFO] [stdout]    |
[INFO] [stdout] 3  | use std::sync::{mpsc, Mutex, Arc};
[INFO] [stdout]    |                              ^^^
[INFO] [stdout] ...
[INFO] [stdout] 12 | use crate::hardware::*;
[INFO] [stdout]    |     ------------------ the item `Arc` is already imported here
[INFO] [stdout]    |
[INFO] [stdout] note: the lint level is defined here
[INFO] [stdout]   --> src/lib.rs:7:5
[INFO] [stdout]    |
[INFO] [stdout] 7  |     unused_imports,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:42:32
[INFO] [stdout]    |
[INFO] [stdout] 42 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 42 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 42 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:46:32
[INFO] [stdout]    |
[INFO] [stdout] 46 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 46 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 46 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/sw_isotp.rs:478:40
[INFO] [stdout]     |
[INFO] [stdout] 478 |                     std::thread::sleep(std::time::Duration::from_millis(10));
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] note: the lint level is defined here
[INFO] [stdout]    --> src/lib.rs:9:5
[INFO] [stdout]     |
[INFO] [stdout] 9   |     unused_qualifications,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 478 -                     std::thread::sleep(std::time::Duration::from_millis(10));
[INFO] [stdout] 478 +                     std::thread::sleep(Duration::from_millis(10));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:50:32
[INFO] [stdout]    |
[INFO] [stdout] 50 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 50 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 50 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/sw_isotp.rs:480:40
[INFO] [stdout]     |
[INFO] [stdout] 480 |                     std::thread::sleep(std::time::Duration::from_millis(1));
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 480 -                     std::thread::sleep(std::time::Duration::from_millis(1));
[INFO] [stdout] 480 +                     std::thread::sleep(Duration::from_millis(1));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ScalingType`
[INFO] [stdout]   --> src/uds/scaling_data.rs:11:50
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub use automotive_diag::uds::{ScalingExtension, ScalingType};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `access_timing_parameter::*`
[INFO] [stdout]   --> src/uds/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use access_timing_parameter::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `clear_diagnostic_information::*`
[INFO] [stdout]   --> src/uds/mod.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub use clear_diagnostic_information::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/mod.rs:284:39
[INFO] [stdout]     |
[INFO] [stdout] 284 |         let drv = Arc::new(Mutex::new(lib_funcs::PassthruDrv::load_lib(lib)?));
[INFO] [stdout]     |                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 284 -         let drv = Arc::new(Mutex::new(lib_funcs::PassthruDrv::load_lib(lib)?));
[INFO] [stdout] 284 +         let drv = Arc::new(Mutex::new(PassthruDrv::load_lib(lib)?));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `diagnostic_session_control::*`
[INFO] [stdout]   --> src/uds/mod.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub use diagnostic_session_control::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ecu_reset::*`
[INFO] [stdout]   --> src/uds/mod.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub use ecu_reset::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_dtc_information::*`
[INFO] [stdout]   --> src/uds/mod.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub use read_dtc_information::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `security_access::*`
[INFO] [stdout]   --> src/uds/mod.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub use security_access::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ecu_reset::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub use ecu_reset::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `error::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub use error::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `message_transmission::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub use message_transmission::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_data_by_identifier::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:40:9
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub use read_data_by_identifier::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_memory_by_address::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub use read_memory_by_address::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_status_of_dtc::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub use read_status_of_dtc::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `security_access::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub use security_access::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `start_diagnostic_session::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:48:9
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub use start_diagnostic_session::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:38:32
[INFO] [stdout]    |
[INFO] [stdout] 38 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 38 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 38 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:42:32
[INFO] [stdout]    |
[INFO] [stdout] 42 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 42 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 42 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:46:32
[INFO] [stdout]    |
[INFO] [stdout] 46 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 46 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 46 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:50:32
[INFO] [stdout]    |
[INFO] [stdout] 50 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 50 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 50 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ScalingType`
[INFO] [stdout]   --> src/uds/scaling_data.rs:11:50
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub use automotive_diag::uds::{ScalingExtension, ScalingType};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `access_timing_parameter::*`
[INFO] [stdout]   --> src/uds/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use access_timing_parameter::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `clear_diagnostic_information::*`
[INFO] [stdout]   --> src/uds/mod.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub use clear_diagnostic_information::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `diagnostic_session_control::*`
[INFO] [stdout]   --> src/uds/mod.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub use diagnostic_session_control::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ecu_reset::*`
[INFO] [stdout]   --> src/uds/mod.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub use ecu_reset::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_dtc_information::*`
[INFO] [stdout]   --> src/uds/mod.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub use read_dtc_information::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `security_access::*`
[INFO] [stdout]   --> src/uds/mod.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub use security_access::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `stop_filter_fn` is never read
[INFO] [stdout]    --> src/hardware/passthru/lib_funcs.rs:100:5
[INFO] [stdout]     |
[INFO] [stdout] 76  | pub struct PassthruDrv {
[INFO] [stdout]     |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 100 |     stop_filter_fn: PassThruStopMsgFilterFn,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `PassthruDrv` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `stop_msg_filter` is never used
[INFO] [stdout]    --> src/hardware/passthru/lib_funcs.rs:430:12
[INFO] [stdout]     |
[INFO] [stdout] 132 | impl PassthruDrv {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 430 |     pub fn stop_msg_filter(&self, channel_id: u32, filter_id: u32) -> PassthruResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ext_id` is never read
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:20:16
[INFO] [stdout]    |
[INFO] [stdout] 20 |     SendData { ext_id: Option<u8>, d: T },
[INFO] [stdout]    |     --------   ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ClearRx` is never constructed
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | enum ChannelMessage<T, X> {
[INFO] [stdout]    |      -------------- variant in this enum
[INFO] [stdout] 18 |     ClearRx,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ChannelMessage` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ext_addr` is never read
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 56 | struct IsoTpPayload {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub ext_addr: bool,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_packet` is never used
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:71:4
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn parse_packet(cf: &CanFrame, iso_tp_ext: bool) -> (u32, &[u8]) {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/uds/scaling_data.rs:26:19
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl ScalingData {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 25 |     /// Creates a new scaling data structure
[INFO] [stdout] 26 |     pub(crate) fn new(
[INFO] [stdout]    |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `stop_filter_fn` is never read
[INFO] [stdout]    --> src/hardware/passthru/lib_funcs.rs:100:5
[INFO] [stdout]     |
[INFO] [stdout] 76  | pub struct PassthruDrv {
[INFO] [stdout]     |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 100 |     stop_filter_fn: PassThruStopMsgFilterFn,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `PassthruDrv` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `stop_msg_filter` is never used
[INFO] [stdout]    --> src/hardware/passthru/lib_funcs.rs:430:12
[INFO] [stdout]     |
[INFO] [stdout] 132 | impl PassthruDrv {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 430 |     pub fn stop_msg_filter(&self, channel_id: u32, filter_id: u32) -> PassthruResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ext_id` is never read
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:20:16
[INFO] [stdout]    |
[INFO] [stdout] 20 |     SendData { ext_id: Option<u8>, d: T },
[INFO] [stdout]    |     --------   ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ClearRx` is never constructed
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | enum ChannelMessage<T, X> {
[INFO] [stdout]    |      -------------- variant in this enum
[INFO] [stdout] 18 |     ClearRx,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ChannelMessage` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ext_addr` is never read
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 56 | struct IsoTpPayload {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub ext_addr: bool,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_packet` is never used
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:71:4
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn parse_packet(cf: &CanFrame, iso_tp_ext: bool) -> (u32, &[u8]) {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_pid` is never used
[INFO] [stdout]   --> src/obd2/service01.rs:75:8
[INFO] [stdout]    |
[INFO] [stdout] 75 |     fn print_pid(v: DiagServerResult<ObdValue>) {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/uds/scaling_data.rs:26:19
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl ScalingData {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 25 |     /// Creates a new scaling data structure
[INFO] [stdout] 26 |     pub(crate) fn new(
[INFO] [stdout]    |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 23 previous errors; 7 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `ecu_diagnostics` (lib) due to 24 previous errors; 7 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error: aborting due to 23 previous errors; 8 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `ecu_diagnostics` (lib test) due to 24 previous errors; 8 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "5fb101cfd55d644b91caaff272baa5c8c0aa719bb06f78ed89e5c45ea36b7980", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5fb101cfd55d644b91caaff272baa5c8c0aa719bb06f78ed89e5c45ea36b7980", kill_on_drop: false }`
[INFO] [stdout] 5fb101cfd55d644b91caaff272baa5c8c0aa719bb06f78ed89e5c45ea36b7980
[INFO] checking ecu_diagnostics-0.95.2 against try#72eda894eb3548c7ba774079ce0afab42958d4ee for pr-121848-1
[INFO] extracting crate ecu_diagnostics 0.95.2 into /workspace/builds/worker-3-tc2/source
[INFO] validating manifest of crates.io crate ecu_diagnostics 0.95.2 on toolchain 72eda894eb3548c7ba774079ce0afab42958d4ee
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate ecu_diagnostics 0.95.2
[INFO] finished tweaking crates.io crate ecu_diagnostics 0.95.2
[INFO] tweaked toml for crates.io crate ecu_diagnostics 0.95.2 written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] crate crates.io crate ecu_diagnostics 0.95.2 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" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2adc950ea8df3f48a1d96977d342e1fe751623f1184529f00f7d0f645d20815d
[INFO] running `Command { std: "docker" "start" "-a" "2adc950ea8df3f48a1d96977d342e1fe751623f1184529f00f7d0f645d20815d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2adc950ea8df3f48a1d96977d342e1fe751623f1184529f00f7d0f645d20815d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2adc950ea8df3f48a1d96977d342e1fe751623f1184529f00f7d0f645d20815d", kill_on_drop: false }`
[INFO] [stdout] 2adc950ea8df3f48a1d96977d342e1fe751623f1184529f00f7d0f645d20815d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 3437fb3c264abfcc40686ecb7cb354b8fe2d5740df55ce7182e0e6eaf27d3a44
[INFO] running `Command { std: "docker" "start" "-a" "3437fb3c264abfcc40686ecb7cb354b8fe2d5740df55ce7182e0e6eaf27d3a44", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.141
[INFO] [stderr]    Compiling proc-macro2 v1.0.66
[INFO] [stderr]    Compiling unicode-ident v1.0.8
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling io-lifetimes v1.0.10
[INFO] [stderr]    Compiling thiserror v1.0.44
[INFO] [stderr]    Compiling serde v1.0.160
[INFO] [stderr]    Compiling rustix v0.37.11
[INFO] [stderr]    Compiling rustversion v1.0.12
[INFO] [stderr]    Compiling serde_json v1.0.96
[INFO] [stderr]     Checking linux-raw-sys v0.3.1
[INFO] [stderr]    Compiling memoffset v0.6.5
[INFO] [stderr]     Checking bitflags v0.4.0
[INFO] [stderr]     Checking nb v1.1.0
[INFO] [stderr]     Checking aho-corasick v0.7.20
[INFO] [stderr]     Checking hex v0.2.0
[INFO] [stderr]     Checking embedded-can v0.3.0
[INFO] [stderr]     Checking itoa v1.0.6
[INFO] [stderr]     Checking try_from v0.2.2
[INFO] [stderr]     Checking ryu v1.0.13
[INFO] [stderr]     Checking regex-syntax v0.6.29
[INFO] [stderr]     Checking itertools v0.4.19
[INFO] [stderr]     Checking j2534_rust v1.5.0
[INFO] [stderr]     Checking libloading v0.7.4
[INFO] [stderr]     Checking strum v0.24.1
[INFO] [stderr]     Checking termcolor v1.2.0
[INFO] [stderr]    Compiling quote v1.0.32
[INFO] [stderr]    Compiling syn v2.0.28
[INFO] [stderr]     Checking regex v1.7.3
[INFO] [stderr]     Checking dirs-sys v0.3.7
[INFO] [stderr]     Checking nix v0.5.1
[INFO] [stderr]     Checking nix v0.24.3
[INFO] [stderr]     Checking dirs v4.0.0
[INFO] [stderr]     Checking shellexpand v2.1.2
[INFO] [stderr]     Checking socketcan v1.7.0
[INFO] [stderr]     Checking is-terminal v0.4.7
[INFO] [stderr]     Checking env_logger v0.10.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.44
[INFO] [stderr]    Compiling displaydoc v0.2.3
[INFO] [stderr]    Compiling enum2repr v0.1.14
[INFO] [stderr]    Compiling strum_macros v0.24.3
[INFO] [stderr]     Checking automotive_diag v0.1.3
[INFO] [stderr]     Checking socketcan-isotp v1.0.1
[INFO] [stderr]     Checking ecu_diagnostics v0.95.2 (/opt/rustwide/workdir)
[INFO] [stdout] error: the item `Arc` is imported redundantly
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:3:30
[INFO] [stdout]    |
[INFO] [stdout] 3  | use std::sync::{mpsc, Mutex, Arc};
[INFO] [stdout]    |                              ^^^
[INFO] [stdout] ...
[INFO] [stdout] 12 | use crate::hardware::*;
[INFO] [stdout]    |     ------------------ the item `Arc` is already imported here
[INFO] [stdout]    |
[INFO] [stdout] note: the lint level is defined here
[INFO] [stdout]   --> src/lib.rs:7:5
[INFO] [stdout]    |
[INFO] [stdout] 7  |     unused_imports,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/sw_isotp.rs:478:40
[INFO] [stdout]     |
[INFO] [stdout] 478 |                     std::thread::sleep(std::time::Duration::from_millis(10));
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] note: the lint level is defined here
[INFO] [stdout]    --> src/lib.rs:9:5
[INFO] [stdout]     |
[INFO] [stdout] 9   |     unused_qualifications,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 478 -                     std::thread::sleep(std::time::Duration::from_millis(10));
[INFO] [stdout] 478 +                     std::thread::sleep(Duration::from_millis(10));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/sw_isotp.rs:480:40
[INFO] [stdout]     |
[INFO] [stdout] 480 |                     std::thread::sleep(std::time::Duration::from_millis(1));
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 480 -                     std::thread::sleep(std::time::Duration::from_millis(1));
[INFO] [stdout] 480 +                     std::thread::sleep(Duration::from_millis(1));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/mod.rs:284:39
[INFO] [stdout]     |
[INFO] [stdout] 284 |         let drv = Arc::new(Mutex::new(lib_funcs::PassthruDrv::load_lib(lib)?));
[INFO] [stdout]     |                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 284 -         let drv = Arc::new(Mutex::new(lib_funcs::PassthruDrv::load_lib(lib)?));
[INFO] [stdout] 284 +         let drv = Arc::new(Mutex::new(PassthruDrv::load_lib(lib)?));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ecu_reset::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub use ecu_reset::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `error::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub use error::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `message_transmission::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub use message_transmission::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_data_by_identifier::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:40:9
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub use read_data_by_identifier::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_memory_by_address::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub use read_memory_by_address::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_status_of_dtc::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub use read_status_of_dtc::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `security_access::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub use security_access::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `start_diagnostic_session::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:48:9
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub use start_diagnostic_session::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:38:32
[INFO] [stdout]    |
[INFO] [stdout] 38 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 38 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 38 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:42:32
[INFO] [stdout]    |
[INFO] [stdout] 42 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 42 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 42 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:46:32
[INFO] [stdout]    |
[INFO] [stdout] 46 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 46 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 46 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:50:32
[INFO] [stdout]    |
[INFO] [stdout] 50 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 50 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 50 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ScalingType`
[INFO] [stdout]   --> src/uds/scaling_data.rs:11:50
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub use automotive_diag::uds::{ScalingExtension, ScalingType};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `access_timing_parameter::*`
[INFO] [stdout]   --> src/uds/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use access_timing_parameter::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `clear_diagnostic_information::*`
[INFO] [stdout]   --> src/uds/mod.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub use clear_diagnostic_information::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `diagnostic_session_control::*`
[INFO] [stdout]   --> src/uds/mod.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub use diagnostic_session_control::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ecu_reset::*`
[INFO] [stdout]   --> src/uds/mod.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub use ecu_reset::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_dtc_information::*`
[INFO] [stdout]   --> src/uds/mod.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub use read_dtc_information::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `security_access::*`
[INFO] [stdout]   --> src/uds/mod.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub use security_access::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: the item `Arc` is imported redundantly
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:3:30
[INFO] [stdout]    |
[INFO] [stdout] 3  | use std::sync::{mpsc, Mutex, Arc};
[INFO] [stdout]    |                              ^^^
[INFO] [stdout] ...
[INFO] [stdout] 12 | use crate::hardware::*;
[INFO] [stdout]    |     ------------------ the item `Arc` is already imported here
[INFO] [stdout]    |
[INFO] [stdout] note: the lint level is defined here
[INFO] [stdout]   --> src/lib.rs:7:5
[INFO] [stdout]    |
[INFO] [stdout] 7  |     unused_imports,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/sw_isotp.rs:478:40
[INFO] [stdout]     |
[INFO] [stdout] 478 |                     std::thread::sleep(std::time::Duration::from_millis(10));
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] note: the lint level is defined here
[INFO] [stdout]    --> src/lib.rs:9:5
[INFO] [stdout]     |
[INFO] [stdout] 9   |     unused_qualifications,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 478 -                     std::thread::sleep(std::time::Duration::from_millis(10));
[INFO] [stdout] 478 +                     std::thread::sleep(Duration::from_millis(10));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/sw_isotp.rs:480:40
[INFO] [stdout]     |
[INFO] [stdout] 480 |                     std::thread::sleep(std::time::Duration::from_millis(1));
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 480 -                     std::thread::sleep(std::time::Duration::from_millis(1));
[INFO] [stdout] 480 +                     std::thread::sleep(Duration::from_millis(1));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]    --> src/hardware/passthru/mod.rs:284:39
[INFO] [stdout]     |
[INFO] [stdout] 284 |         let drv = Arc::new(Mutex::new(lib_funcs::PassthruDrv::load_lib(lib)?));
[INFO] [stdout]     |                                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]     |
[INFO] [stdout] 284 -         let drv = Arc::new(Mutex::new(lib_funcs::PassthruDrv::load_lib(lib)?));
[INFO] [stdout] 284 +         let drv = Arc::new(Mutex::new(PassthruDrv::load_lib(lib)?));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ecu_reset::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub use ecu_reset::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `error::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub use error::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `message_transmission::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub use message_transmission::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_data_by_identifier::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:40:9
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub use read_data_by_identifier::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_memory_by_address::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub use read_memory_by_address::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_status_of_dtc::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub use read_status_of_dtc::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `security_access::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub use security_access::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `start_diagnostic_session::*`
[INFO] [stdout]   --> src/kwp2000/mod.rs:48:9
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub use start_diagnostic_session::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:38:32
[INFO] [stdout]    |
[INFO] [stdout] 38 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 38 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 38 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:42:32
[INFO] [stdout]    |
[INFO] [stdout] 42 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 42 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 42 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:46:32
[INFO] [stdout]    |
[INFO] [stdout] 46 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 46 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 46 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unnecessary qualification
[INFO] [stdout]   --> src/obd2/enumerations.rs:50:32
[INFO] [stdout]    |
[INFO] [stdout] 50 |                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: remove the unnecessary path segments
[INFO] [stdout]    |
[INFO] [stdout] 50 -                 Standard(v) => std::fmt::Display::fmt(&v, f),
[INFO] [stdout] 50 +                 Standard(v) => Display::fmt(&v, f),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ScalingType`
[INFO] [stdout]   --> src/uds/scaling_data.rs:11:50
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub use automotive_diag::uds::{ScalingExtension, ScalingType};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `access_timing_parameter::*`
[INFO] [stdout]   --> src/uds/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use access_timing_parameter::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `clear_diagnostic_information::*`
[INFO] [stdout]   --> src/uds/mod.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub use clear_diagnostic_information::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `diagnostic_session_control::*`
[INFO] [stdout]   --> src/uds/mod.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub use diagnostic_session_control::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `ecu_reset::*`
[INFO] [stdout]   --> src/uds/mod.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub use ecu_reset::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `read_dtc_information::*`
[INFO] [stdout]   --> src/uds/mod.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub use read_dtc_information::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unused import: `security_access::*`
[INFO] [stdout]   --> src/uds/mod.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub use security_access::*;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `stop_filter_fn` is never read
[INFO] [stdout]    --> src/hardware/passthru/lib_funcs.rs:100:5
[INFO] [stdout]     |
[INFO] [stdout] 76  | pub struct PassthruDrv {
[INFO] [stdout]     |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 100 |     stop_filter_fn: PassThruStopMsgFilterFn,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `PassthruDrv` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `stop_msg_filter` is never used
[INFO] [stdout]    --> src/hardware/passthru/lib_funcs.rs:430:12
[INFO] [stdout]     |
[INFO] [stdout] 132 | impl PassthruDrv {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 430 |     pub fn stop_msg_filter(&self, channel_id: u32, filter_id: u32) -> PassthruResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ext_id` is never read
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:20:16
[INFO] [stdout]    |
[INFO] [stdout] 20 |     SendData { ext_id: Option<u8>, d: T },
[INFO] [stdout]    |     --------   ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ClearRx` is never constructed
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | enum ChannelMessage<T, X> {
[INFO] [stdout]    |      -------------- variant in this enum
[INFO] [stdout] 18 |     ClearRx,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ChannelMessage` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ext_addr` is never read
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 56 | struct IsoTpPayload {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub ext_addr: bool,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_packet` is never used
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:71:4
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn parse_packet(cf: &CanFrame, iso_tp_ext: bool) -> (u32, &[u8]) {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/uds/scaling_data.rs:26:19
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl ScalingData {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 25 |     /// Creates a new scaling data structure
[INFO] [stdout] 26 |     pub(crate) fn new(
[INFO] [stdout]    |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 23 previous errors; 7 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `ecu_diagnostics` (lib) due to 24 previous errors; 7 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] warning: field `stop_filter_fn` is never read
[INFO] [stdout]    --> src/hardware/passthru/lib_funcs.rs:100:5
[INFO] [stdout]     |
[INFO] [stdout] 76  | pub struct PassthruDrv {
[INFO] [stdout]     |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 100 |     stop_filter_fn: PassThruStopMsgFilterFn,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `PassthruDrv` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `stop_msg_filter` is never used
[INFO] [stdout]    --> src/hardware/passthru/lib_funcs.rs:430:12
[INFO] [stdout]     |
[INFO] [stdout] 132 | impl PassthruDrv {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 430 |     pub fn stop_msg_filter(&self, channel_id: u32, filter_id: u32) -> PassthruResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ext_id` is never read
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:20:16
[INFO] [stdout]    |
[INFO] [stdout] 20 |     SendData { ext_id: Option<u8>, d: T },
[INFO] [stdout]    |     --------   ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ClearRx` is never constructed
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | enum ChannelMessage<T, X> {
[INFO] [stdout]    |      -------------- variant in this enum
[INFO] [stdout] 18 |     ClearRx,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ChannelMessage` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ext_addr` is never read
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 56 | struct IsoTpPayload {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub ext_addr: bool,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_packet` is never used
[INFO] [stdout]   --> src/hardware/passthru/sw_isotp.rs:71:4
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn parse_packet(cf: &CanFrame, iso_tp_ext: bool) -> (u32, &[u8]) {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_pid` is never used
[INFO] [stdout]   --> src/obd2/service01.rs:75:8
[INFO] [stdout]    |
[INFO] [stdout] 75 |     fn print_pid(v: DiagServerResult<ObdValue>) {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/uds/scaling_data.rs:26:19
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl ScalingData {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 25 |     /// Creates a new scaling data structure
[INFO] [stdout] 26 |     pub(crate) fn new(
[INFO] [stdout]    |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 23 previous errors; 8 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `ecu_diagnostics` (lib test) due to 24 previous errors; 8 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "3437fb3c264abfcc40686ecb7cb354b8fe2d5740df55ce7182e0e6eaf27d3a44", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3437fb3c264abfcc40686ecb7cb354b8fe2d5740df55ce7182e0e6eaf27d3a44", kill_on_drop: false }`
[INFO] [stdout] 3437fb3c264abfcc40686ecb7cb354b8fe2d5740df55ce7182e0e6eaf27d3a44
