[INFO] fetching crate pitot 0.0.1...
[INFO] testing pitot-0.0.1 against beta-2025-10-28 for beta-1.92-2
[INFO] extracting crate pitot 0.0.1 into /workspace/builds/worker-4-tc2/source
[INFO] started tweaking crates.io crate pitot 0.0.1
[INFO] finished tweaking crates.io crate pitot 0.0.1
[INFO] tweaked toml for crates.io crate pitot 0.0.1 written to /workspace/builds/worker-4-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate pitot 0.0.1 on toolchain beta-2025-10-28
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-10-28" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-10-28" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 75 packages to latest compatible versions
[INFO] [stderr]       Adding chrono v0.3.0 (available: v0.4.42)
[INFO] [stderr]       Adding env_logger v0.3.5 (available: v0.11.8)
[INFO] [stderr]       Adding inotify v0.4.2 (available: v0.11.0)
[INFO] [stderr]       Adding log v0.3.9 (available: v0.4.28)
[INFO] [stderr]       Adding nom v3.2.1 (available: v8.0.0)
[INFO] [stderr]       Adding serial v0.3.4 (available: v0.4.0)
[INFO] [stderr]       Adding time v0.1.45 (available: v0.3.44)
[INFO] [stderr]       Adding wasi v0.10.0+wasi-snapshot-preview1 (available: v0.10.2+wasi-snapshot-preview1)
[INFO] [stderr]       Adding ws v0.7.9 (available: v0.9.2)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-10-28" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-10-28" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 4e924f17408cb929ad550faa33ee967e6f81726e9e68994571a0615023a8a2ae
[INFO] running `Command { std: "docker" "start" "-a" "4e924f17408cb929ad550faa33ee967e6f81726e9e68994571a0615023a8a2ae", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4e924f17408cb929ad550faa33ee967e6f81726e9e68994571a0615023a8a2ae", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4e924f17408cb929ad550faa33ee967e6f81726e9e68994571a0615023a8a2ae", kill_on_drop: false }`
[INFO] [stdout] 4e924f17408cb929ad550faa33ee967e6f81726e9e68994571a0615023a8a2ae
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-10-28" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] bda99750d799eed5658c5fe69dfcc890c5a5bc41c464b3277fdb8d6110c4aa27
[INFO] running `Command { std: "docker" "start" "-a" "bda99750d799eed5658c5fe69dfcc890c5a5bc41c464b3277fdb8d6110c4aa27", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]    Compiling libc v0.2.177
[INFO] [stderr]    Compiling lazycell v1.3.0
[INFO] [stderr]    Compiling sha1_smol v1.0.1
[INFO] [stderr]    Compiling bitflags v0.9.1
[INFO] [stderr]    Compiling url v1.7.2
[INFO] [stderr]    Compiling num-iter v0.1.45
[INFO] [stderr]    Compiling sha1 v0.6.1
[INFO] [stderr]    Compiling num v0.1.43
[INFO] [stderr]    Compiling iovec v0.1.4
[INFO] [stderr]    Compiling memchr v0.1.11
[INFO] [stderr]    Compiling thread-id v2.0.0
[INFO] [stderr]    Compiling net2 v0.2.39
[INFO] [stderr]    Compiling time v0.1.45
[INFO] [stderr]    Compiling ioctl-rs v0.1.6
[INFO] [stderr]    Compiling inotify-sys v0.1.5
[INFO] [stderr]    Compiling memchr v1.0.2
[INFO] [stderr]    Compiling termios v0.2.2
[INFO] [stderr]    Compiling rand v0.4.6
[INFO] [stderr]    Compiling thread_local v0.2.7
[INFO] [stderr]    Compiling aho-corasick v0.5.3
[INFO] [stderr]    Compiling serial v0.3.4
[INFO] [stderr]    Compiling bytes v0.4.12
[INFO] [stderr]    Compiling inotify v0.4.2
[INFO] [stderr]    Compiling nom v3.2.1
[INFO] [stderr]    Compiling chrono v0.3.0
[INFO] [stderr]    Compiling regex v0.1.80
[INFO] [stderr]    Compiling mio v0.6.23
[INFO] [stderr]    Compiling mio-extras v2.0.6
[INFO] [stderr]    Compiling env_logger v0.3.5
[INFO] [stderr]    Compiling ws v0.7.9
[INFO] [stderr]    Compiling pitot v0.0.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:113:13
[INFO] [stdout]     |
[INFO] [stdout] 113 |             try!(self.refill());
[INFO] [stdout]     |             ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:150:9
[INFO] [stdout]     |
[INFO] [stdout] 150 |         try!(self.serial
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:188:17
[INFO] [stdout]     |
[INFO] [stdout] 188 |                 try!(self.serial
[INFO] [stdout]     |                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:377:62
[INFO] [stdout]     |
[INFO] [stdout] 377 |                          Some((mag_dec as f32 * 1.0e-2, Some((mag_dec_accuracy as f32 * 1.0e-2))))
[INFO] [stdout]     |                                                              ^                                ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 377 -                          Some((mag_dec as f32 * 1.0e-2, Some((mag_dec_accuracy as f32 * 1.0e-2))))
[INFO] [stdout] 377 +                          Some((mag_dec as f32 * 1.0e-2, Some(mag_dec_accuracy as f32 * 1.0e-2)))
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:489:25
[INFO] [stdout]     |
[INFO] [stdout] 489 |                         try!(settings.set_baud_rate(BaudRate::Baud9600));
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:519:25
[INFO] [stdout]     |
[INFO] [stdout] 519 |                         try!(settings.set_baud_rate(BAUD_RATE));
[INFO] [stdout]     |                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/sensor/sdr/uat.rs:244:16
[INFO] [stdout]     |
[INFO] [stdout] 244 |         typ @ 0...1 => {
[INFO] [stdout]     |                ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(ellipsis_inclusive_range_patterns)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `...` range patterns are deprecated
[INFO] [stdout]    --> src/processor/traffic.rs:307:17
[INFO] [stdout]     |
[INFO] [stdout] 307 |         0xA00001...0xAFFFFF => {
[INFO] [stdout]     |                 ^^^ help: use `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/transport/udp.rs:162:9
[INFO] [stdout]     |
[INFO] [stdout] 162 |         try!(file.read_to_end(&mut buf));
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead
[INFO] [stdout]    --> src/transport/udp.rs:160:24
[INFO] [stdout]     |
[INFO] [stdout] 160 |         let mut file = try!(File::open(LEASE_FILE_PATH));
[INFO] [stdout]     |                        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/pitot/mod.rs:30:22
[INFO] [stdout]    |
[INFO] [stdout] 30 |     sensors: Vec<Box<Sensor>>,
[INFO] [stdout]    |                      ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 30 |     sensors: Vec<Box<dyn Sensor>>,
[INFO] [stdout]    |                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/pitot/mod.rs:31:25
[INFO] [stdout]    |
[INFO] [stdout] 31 |     processors: Vec<Box<Processor>>,
[INFO] [stdout]    |                         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 31 |     processors: Vec<Box<dyn Processor>>,
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/pitot/mod.rs:32:24
[INFO] [stdout]    |
[INFO] [stdout] 32 |     protocols: Vec<Box<Protocol>>,
[INFO] [stdout]    |                        ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 32 |     protocols: Vec<Box<dyn Protocol>>,
[INFO] [stdout]    |                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/pitot/mod.rs:33:25
[INFO] [stdout]    |
[INFO] [stdout] 33 |     transports: Vec<Box<Transport>>,
[INFO] [stdout]    |                         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 33 |     transports: Vec<Box<dyn Transport>>,
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/sensor/gnss/fake.rs:25:31
[INFO] [stdout]    |
[INFO] [stdout] 25 |     fn run(&mut self, h: &mut Pushable<SensorData>) {
[INFO] [stdout]    |                               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 25 |     fn run(&mut self, h: &mut dyn Pushable<SensorData>) {
[INFO] [stdout]    |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/sensor/mod.rs:37:31
[INFO] [stdout]    |
[INFO] [stdout] 37 |     fn run(&mut self, h: &mut Pushable<SensorData>);
[INFO] [stdout]    |                               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 37 |     fn run(&mut self, h: &mut dyn Pushable<SensorData>);
[INFO] [stdout]    |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/processor/mod.rs:40:36
[INFO] [stdout]    |
[INFO] [stdout] 40 |     fn run(&mut self, handle: &mut Pushable<Report>, i: ChainedIter);
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 40 |     fn run(&mut self, handle: &mut dyn Pushable<Report>, i: ChainedIter);
[INFO] [stdout]    |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/transport/mod.rs:28:36
[INFO] [stdout]    |
[INFO] [stdout] 28 |     fn run(&mut self, handle: &mut Handle, i: ChainedIter);
[INFO] [stdout]    |                                    ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 28 |     fn run(&mut self, handle: &mut dyn Handle, i: ChainedIter);
[INFO] [stdout]    |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/protocol/mod.rs:35:36
[INFO] [stdout]    |
[INFO] [stdout] 35 |     fn run(&mut self, handle: &mut Pushable<Payload>, i: ChainedIter);
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 35 |     fn run(&mut self, handle: &mut dyn Pushable<Payload>, i: ChainedIter);
[INFO] [stdout]    |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:440:31
[INFO] [stdout]     |
[INFO] [stdout] 440 |     fn run(&mut self, h: &mut Pushable<SensorData>) {
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 440 |     fn run(&mut self, h: &mut dyn Pushable<SensorData>) {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/sensor/sdr/uat.rs:317:31
[INFO] [stdout]     |
[INFO] [stdout] 317 |     fn run(&mut self, h: &mut Pushable<SensorData>) {
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 317 |     fn run(&mut self, h: &mut dyn Pushable<SensorData>) {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/sensor/sdr/es.rs:110:31
[INFO] [stdout]     |
[INFO] [stdout] 110 |     fn run(&mut self, h: &mut Pushable<SensorData>) {
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 110 |     fn run(&mut self, h: &mut dyn Pushable<SensorData>) {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/processor/ownship.rs:40:36
[INFO] [stdout]    |
[INFO] [stdout] 40 |     fn run(&mut self, handle: &mut Pushable<Report>, i: ChainedIter) {
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 40 |     fn run(&mut self, handle: &mut dyn Pushable<Report>, i: ChainedIter) {
[INFO] [stdout]    |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/processor/clock.rs:36:36
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn run(&mut self, handle: &mut Pushable<Report>, i: ChainedIter) {
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn run(&mut self, handle: &mut dyn Pushable<Report>, i: ChainedIter) {
[INFO] [stdout]    |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/processor/traffic.rs:169:36
[INFO] [stdout]     |
[INFO] [stdout] 169 |     fn run(&mut self, handle: &mut Pushable<Report>, i: ChainedIter) {
[INFO] [stdout]     |                                    ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 169 |     fn run(&mut self, handle: &mut dyn Pushable<Report>, i: ChainedIter) {
[INFO] [stdout]     |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/processor/fisb.rs:35:36
[INFO] [stdout]    |
[INFO] [stdout] 35 |     fn run(&mut self, handle: &mut Pushable<Report>, i: ChainedIter) {
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 35 |     fn run(&mut self, handle: &mut dyn Pushable<Report>, i: ChainedIter) {
[INFO] [stdout]    |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/transport/udp.rs:60:36
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn run(&mut self, handle: &mut Handle, i: ChainedIter) {
[INFO] [stdout]    |                                    ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn run(&mut self, handle: &mut dyn Handle, i: ChainedIter) {
[INFO] [stdout]    |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/protocol/gdl90.rs:64:36
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn run(&mut self, handle: &mut Pushable<Payload>, i: ChainedIter) {
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn run(&mut self, handle: &mut dyn Pushable<Payload>, i: ChainedIter) {
[INFO] [stdout]    |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/protocol/websocket.rs:51:37
[INFO] [stdout]    |
[INFO] [stdout] 51 |     fn run(&mut self, _handle: &mut Pushable<Payload>, i: ChainedIter) {
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 51 |     fn run(&mut self, _handle: &mut dyn Pushable<Payload>, i: ChainedIter) {
[INFO] [stdout]    |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:480:32
[INFO] [stdout]     |
[INFO] [stdout] 480 |     pub fn new() -> Option<Box<Sensor>> {
[INFO] [stdout]     |                                ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 480 |     pub fn new() -> Option<Box<dyn Sensor>> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/processor/ownship.rs:80:25
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub fn new() -> Box<Processor> {
[INFO] [stdout]    |                         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub fn new() -> Box<dyn Processor> {
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/transport/udp.rs:126:25
[INFO] [stdout]     |
[INFO] [stdout] 126 |     pub fn new() -> Box<Transport> {
[INFO] [stdout]     |                         ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 126 |     pub fn new() -> Box<dyn Transport> {
[INFO] [stdout]     |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/protocol/gdl90.rs:408:25
[INFO] [stdout]     |
[INFO] [stdout] 408 |     pub fn new() -> Box<Protocol> {
[INFO] [stdout]     |                         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 408 |     pub fn new() -> Box<dyn Protocol> {
[INFO] [stdout]     |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/pitot/mod.rs:58:42
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn link_sensor(&mut self, s: Box<Sensor>) {
[INFO] [stdout]    |                                          ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn link_sensor(&mut self, s: Box<dyn Sensor>) {
[INFO] [stdout]    |                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/pitot/mod.rs:62:45
[INFO] [stdout]    |
[INFO] [stdout] 62 |     pub fn link_processor(&mut self, p: Box<Processor>) {
[INFO] [stdout]    |                                             ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 62 |     pub fn link_processor(&mut self, p: Box<dyn Processor>) {
[INFO] [stdout]    |                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/pitot/mod.rs:66:44
[INFO] [stdout]    |
[INFO] [stdout] 66 |     pub fn link_protocol(&mut self, p: Box<Protocol>) {
[INFO] [stdout]    |                                            ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 66 |     pub fn link_protocol(&mut self, p: Box<dyn Protocol>) {
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/pitot/mod.rs:70:45
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub fn link_transport(&mut self, t: Box<Transport>) {
[INFO] [stdout]    |                                             ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub fn link_transport(&mut self, t: Box<dyn Transport>) {
[INFO] [stdout]    |                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/main.rs:54:83
[INFO] [stdout]    |
[INFO] [stdout] 54 | ...                   p.link_sensor(Box::new(e) as Box<Sensor>);
[INFO] [stdout]    |                                                        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 54 |                                                  p.link_sensor(Box::new(e) as Box<dyn Sensor>);
[INFO] [stdout]    |                                                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/main.rs:58:85
[INFO] [stdout]    |
[INFO] [stdout] 58 | ...                   p.link_sensor(Box::new(e) as Box<Sensor>);
[INFO] [stdout]    |                                                        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 58 |                                                    p.link_sensor(Box::new(e) as Box<dyn Sensor>);
[INFO] [stdout]    |                                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/main.rs:63:70
[INFO] [stdout]    |
[INFO] [stdout] 63 |     p.link_processor(Box::new(processor::clock::Clock::new()) as Box<Processor>);
[INFO] [stdout]    |                                                                      ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 63 |     p.link_processor(Box::new(processor::clock::Clock::new()) as Box<dyn Processor>);
[INFO] [stdout]    |                                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/main.rs:64:74
[INFO] [stdout]    |
[INFO] [stdout] 64 |     p.link_processor(Box::new(processor::traffic::Traffic::new()) as Box<Processor>);
[INFO] [stdout]    |                                                                          ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 64 |     p.link_processor(Box::new(processor::traffic::Traffic::new()) as Box<dyn Processor>);
[INFO] [stdout]    |                                                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/main.rs:65:68
[INFO] [stdout]    |
[INFO] [stdout] 65 |     p.link_processor(Box::new(processor::fisb::FISB::new()) as Box<Processor>);
[INFO] [stdout]    |                                                                    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 65 |     p.link_processor(Box::new(processor::fisb::FISB::new()) as Box<dyn Processor>);
[INFO] [stdout]    |                                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FakeGNSSProvider` is never constructed
[INFO] [stdout]   --> src/sensor/gnss/fake.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | struct FakeGNSSProvider {}
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/sensor/gnss/fake.rs:45:8
[INFO] [stdout]    |
[INFO] [stdout] 44 | impl FakeGNSSProvider {
[INFO] [stdout]    | --------------------- associated function in this implementation
[INFO] [stdout] 45 |     fn new() -> Option<Box<Self>> {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/sensor/gnss/ublox.rs:44:11
[INFO] [stdout]    |
[INFO] [stdout] 44 |     Parse(ErrorKind),
[INFO] [stdout]    |     ----- ^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProtocolError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 44 -     Parse(ErrorKind),
[INFO] [stdout] 44 +     Parse(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `rs_error` is never read
[INFO] [stdout]   --> src/sensor/sdr/bindings/libdump978.rs:49:9
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct Frame {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub rs_error: u32,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Frame` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:111:13
[INFO] [stdout]     |
[INFO] [stdout] 111 |     fn next(&mut self) -> Result<UBXPacket, Error> {
[INFO] [stdout]     |             ^^^^^^^^^            ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |             |
[INFO] [stdout]     |             the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 111 |     fn next(&mut self) -> Result<UBXPacket<'_>, Error> {
[INFO] [stdout]     |                                           ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:199:26
[INFO] [stdout]     |
[INFO] [stdout] 199 |   named!(parse_ubx_message<UBXPacket>,
[INFO] [stdout]     |   -                        ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |  _|
[INFO] [stdout]     | |
[INFO] [stdout] 200 | |        map_res!(do_parse!(
[INFO] [stdout] 201 | |             take_until_and_consume!(&[0xB5_u8, 0x62][..]) >>
[INFO] [stdout] 202 | |             class: le_u8 >>
[INFO] [stdout] ...   |
[INFO] [stdout] 208 | |             (class, id, payload, ck_a, ck_b)
[INFO] [stdout] 209 | |         ), UBXPacket::new_from_parser));
[INFO] [stdout]     | |                                       -
[INFO] [stdout]     | |                                       |
[INFO] [stdout]     | |_______________________________________the lifetime is named here
[INFO] [stdout]     |                                         the same lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 199 | named!(parse_ubx_message<UBXPacket<'a>>,
[INFO] [stdout]     |                                   ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:387:53
[INFO] [stdout]     |
[INFO] [stdout] 387 |     fn new(class: u8, id: u8, payload: &'a [u8]) -> UBXPacket {
[INFO] [stdout]     |                                         --          ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 387 |     fn new(class: u8, id: u8, payload: &'a [u8]) -> UBXPacket<'a> {
[INFO] [stdout]     |                                                              ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/sensor/gnss/ublox.rs:392:68
[INFO] [stdout]     |
[INFO] [stdout] 392 |     fn new_from_parser(data: (u8, u8, &'a [u8], u8, u8)) -> Result<UBXPacket, Error> {
[INFO] [stdout]     |                                        --                          ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                        |
[INFO] [stdout]     |                                        the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 392 |     fn new_from_parser(data: (u8, u8, &'a [u8], u8, u8)) -> Result<UBXPacket<'a>, Error> {
[INFO] [stdout]     |                                                                             ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused borrow that must be used
[INFO] [stdout]    --> src/protocol/gdl90.rs:135:9
[INFO] [stdout]     |
[INFO] [stdout] 135 |         &buf[4..436].clone_from_slice(&e.payload);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the borrow produces a value
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 135 |         let _ = &buf[4..436].clone_from_slice(&e.payload);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: linking with `cc` failed: exit status: 1
[INFO] [stdout]   |
[INFO] [stdout]   = note:  "cc" "-m64" "/tmp/rustccL04GN/symbols.o" "<17 object files omitted>" "-Wl,--as-needed" "-Wl,-Bdynamic" "-lrtlsdr" "-ldump978" "-ldump1090" "-Wl,-Bstatic" "/opt/rustwide/target/debug/deps/{libserde-c62bed17d7019041,libinotify-121274ae0be9f988,libinotify_sys-39e004d9fc94eaef,libbitflags-ae4318e8fded8832,libws-c5bedaf47e8cc6c2,liburl-a0674203487be579,libpercent_encoding-73a0215a80a159d3,libidna-28e7611e247d8b94,libunicode_normalization-ddc5e7c440a8c1fd,libtinyvec-8f77f64c852edda1,libtinyvec_macros-7b77ea21c73594ca,libunicode_bidi-a9d2c96e849c6f3c,libmatches-12896af12519b727,libsha1-f2d904a16cfde47c,libsha1_smol-a320b1639232fa11,librand-b8e9685e0d29f627,libmio_extras-3bb85f511de92c58,liblazycell-24027d197569389e,libmio-50b2310bd381880e,libslab-5629529544b2a983,libnet2-d33758fdc957f797,libcfg_if-5debf92116708c19,libhttparse-225777ae3f11a86e,libbytes-f1bcc500eb1b85b7,libiovec-c31e55153768baee,libbyteorder-8f59b6d1bfdaa844,libserde_json-ac88e2c590f14e66,libmemchr-60b408e76a46f254,libitoa-ef40fa516293a9d3,libryu-a7164637bc4900ee,libserde_core-b6917df4d3e6d1df,libnom-32916a3c7aabd1c3,libmemchr-d65f809aff816f6f,libserial-b9d9e0badb599ca2,libioctl_rs-62a0155f6e18b1fa,libtermios-29981ba876b5a78b,libchrono-d50de9bad93f15bf,libnum-caaadc89431b0eb4,libnum_iter-4feb00a5290ba293,libnum_integer-cb9b9956fc5cd6cb,libnum_traits-c445de6622136476,libtime-09ca80815d3fef84,libenv_logger-149c735b07616807,libregex-d6548cb831c2a2ca,libutf8_ranges-8667a1a5685acb34,libregex_syntax-b500501a19539956,libthread_local-7a468a3857789c21,libthread_id-60f6b45652fb353e,libaho_corasick-f9a5b9bf825da52d,libmemchr-ff44c363bf88fb27,liblibc-350c78c2386d199c,liblog-f7748546cf96ef65,liblog-28ade3d6717210f3}.rlib" "<sysroot>/lib/rustlib/x86_64-unknown-linux-gnu/lib/{libstd-*,libpanic_unwind-*,libobject-*,libmemchr-*,libaddr2line-*,libgimli-*,libcfg_if-*,librustc_demangle-*,libstd_detect-*,libhashbrown-*,librustc_std_workspace_alloc-*,libminiz_oxide-*,libadler2-*,libunwind-*,liblibc-*,librustc_std_workspace_core-*,liballoc-*,libcore-*,libcompiler_builtins-*}.rlib" "-Wl,-Bdynamic" "-lc" "-lgcc_s" "-lutil" "-lrt" "-lpthread" "-lm" "-ldl" "-lc" "-L" "/tmp/rustccL04GN/raw-dylibs" "-B<sysroot>/lib/rustlib/x86_64-unknown-linux-gnu/bin/gcc-ld" "-fuse-ld=lld" "-Wl,--eh-frame-hdr" "-Wl,-z,noexecstack" "-L" "<sysroot>/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-o" "/opt/rustwide/target/debug/deps/pitot-20f5cc59b8ede453" "-Wl,--gc-sections" "-pie" "-Wl,-z,relro,-z,now" "-nodefaultlibs"
[INFO] [stdout]   = note: some arguments are omitted. use `--verbose` to show all linker arguments
[INFO] [stdout]   = note: rust-lld: error: unable to find library -lrtlsdr
[INFO] [stdout]           rust-lld: error: unable to find library -ldump978
[INFO] [stdout]           rust-lld: error: unable to find library -ldump1090
[INFO] [stdout]           collect2: error: ld returned 1 exit status
[INFO] [stdout]           
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `pitot` (bin "pitot") due to 1 previous error; 51 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "bda99750d799eed5658c5fe69dfcc890c5a5bc41c464b3277fdb8d6110c4aa27", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "bda99750d799eed5658c5fe69dfcc890c5a5bc41c464b3277fdb8d6110c4aa27", kill_on_drop: false }`
[INFO] [stdout] bda99750d799eed5658c5fe69dfcc890c5a5bc41c464b3277fdb8d6110c4aa27
