[INFO] fetching crate pitot 0.0.1...
[INFO] testing pitot-0.0.1 against beta-2026-04-21 for beta-1.96-2
[INFO] extracting crate pitot 0.0.1 into /workspace/builds/worker-2-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-2-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate pitot 0.0.1 on toolchain beta-2026-04-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "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-2026-04-21" "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.44)
[INFO] [stderr]       Adding env_logger v0.3.5 (available: v0.11.10)
[INFO] [stderr]       Adding inotify v0.4.2 (available: v0.11.1)
[INFO] [stderr]       Adding log v0.3.9 (available: v0.4.29)
[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.47)
[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-2026-04-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: `package.edition` is unspecified, defaulting to `2015` while the latest is `2024`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 5896e40b05a4ad144f8572c8b2ac23983456f62d2464edc37ce012c3ccffe572
[INFO] running `Command { std: "docker" "start" "-a" "5896e40b05a4ad144f8572c8b2ac23983456f62d2464edc37ce012c3ccffe572", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "5896e40b05a4ad144f8572c8b2ac23983456f62d2464edc37ce012c3ccffe572", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5896e40b05a4ad144f8572c8b2ac23983456f62d2464edc37ce012c3ccffe572", kill_on_drop: false }`
[INFO] [stdout] 5896e40b05a4ad144f8572c8b2ac23983456f62d2464edc37ce012c3ccffe572
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1e551eded444127193ece8bdbeda34bc4aec477f80b2c7ac3e78592ec4c51117
[INFO] running `Command { std: "docker" "start" "-a" "1e551eded444127193ece8bdbeda34bc4aec477f80b2c7ac3e78592ec4c51117", kill_on_drop: false }`
[INFO] [stderr] warning: `package.edition` is unspecified, defaulting to `2015` while the latest is `2024`
[INFO] [stderr]    Compiling libc v0.2.186
[INFO] [stderr]    Compiling winapi-build v0.1.1
[INFO] [stderr]    Compiling winapi v0.2.8
[INFO] [stderr]    Compiling proc-macro2 v1.0.106
[INFO] [stderr]    Compiling quote v1.0.45
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling utf8-ranges v0.1.3
[INFO] [stderr]    Compiling regex-syntax v0.3.9
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling lazycell v1.3.0
[INFO] [stderr]    Compiling kernel32-sys v0.2.2
[INFO] [stderr]    Compiling sha1 v0.6.1
[INFO] [stderr]    Compiling log v0.3.9
[INFO] [stderr]    Compiling memchr v2.8.0
[INFO] [stderr]    Compiling bitflags v0.9.1
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling num-iter v0.1.45
[INFO] [stderr]    Compiling num v0.1.43
[INFO] [stderr]    Compiling iovec v0.1.4
[INFO] [stderr]    Compiling net2 v0.2.39
[INFO] [stderr]    Compiling thread-id v2.0.0
[INFO] [stderr]    Compiling memchr v0.1.11
[INFO] [stderr]    Compiling termios v0.2.2
[INFO] [stderr]    Compiling ioctl-rs v0.1.6
[INFO] [stderr]    Compiling thread_local v0.2.7
[INFO] [stderr]    Compiling aho-corasick v0.5.3
[INFO] [stderr]    Compiling bytes v0.4.12
[INFO] [stderr]    Compiling time v0.1.45
[INFO] [stderr]    Compiling rand v0.4.6
[INFO] [stderr]    Compiling mio v0.6.23
[INFO] [stderr]    Compiling regex v0.1.80
[INFO] [stderr]    Compiling memchr v1.0.2
[INFO] [stderr]    Compiling inotify-sys v0.1.5
[INFO] [stderr]    Compiling inotify v0.4.2
[INFO] [stderr]    Compiling chrono v0.3.0
[INFO] [stderr]    Compiling nom v3.2.1
[INFO] [stderr]    Compiling serial v0.3.4
[INFO] [stderr]    Compiling mio-extras v2.0.6
[INFO] [stderr]    Compiling ws v0.7.9
[INFO] [stderr]    Compiling env_logger v0.3.5
[INFO] [stderr]    Compiling serde_derive v1.0.228
[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" "/opt/rustwide/target/debug/deps/rustcCWsUY2/symbols.o" "<17 object files omitted>" "-Wl,--as-needed" "-Wl,-Bdynamic" "-lrtlsdr" "-ldump978" "-ldump1090" "-Wl,-Bstatic" "/opt/rustwide/target/debug/deps/{libserde-3d8c067e343d479d,libinotify-df2fdf8c0c2c48a6,libinotify_sys-7f6321e7af22737b,libbitflags-82d1a37773c96fd1,libws-2ab2c1cd127e3db0,liburl-4c6c30110faea529,libpercent_encoding-4ba2794398efc7a6,libidna-99f2d1a3d584b184,libunicode_normalization-9307a2c655b3a3a8,libtinyvec-27f7baa2b5a4eb6c,libtinyvec_macros-9b9b0c30a7e420c3,libunicode_bidi-46fddec1b3c8369c,libmatches-199ca9faf44a74ba,libsha1-87e1f43db32d934c,libsha1_smol-c84f3fb8930b46aa,librand-6048028f5936834f,libmio_extras-2537e02ee6dd6471,liblazycell-5eed5efdf11de5d1,libmio-a3c5a93d1fd4b669,libslab-229cf4143d039c7e,libnet2-83504d3e1094d2c9,libcfg_if-4c48786b821c6a94,libhttparse-9c8043f0d8f65c21,libbytes-f27b4122b003d2ef,libiovec-02acb06030d5958a,libbyteorder-0d5229b4099d70a3,libserde_json-b0c4678edd0e6349,libmemchr-9c99a16d1eb4a64c,libitoa-c3f3678fd0b86a79,libzmij-32087f229b5896fd,libserde_core-6504fde8f3d6c9d3,libnom-1fce818236820b04,libmemchr-59eff8eec04c9c53,libserial-c63fedd8ced17f40,libioctl_rs-aee0d41ad986f982,libtermios-d4ddab04fd0b91ca,libchrono-929b2f325c9f87d7,libnum-594e17d8e074ccb9,libnum_iter-72943b17f8645355,libnum_integer-3831462b4a2efa6d,libnum_traits-13e0c6dd117d8ba0,libtime-a1f03a1b4b58df6a,libenv_logger-d40cdd1116918f35,libregex-eb28b0341e60cce8,libutf8_ranges-132d5cd13178f0de,libregex_syntax-b498ff21fd00441f,libthread_local-545f28406f0b1b1a,libthread_id-2f88ef0e0d5bf5e5,libaho_corasick-8bd071a6ce2641ff,libmemchr-306c67e4dfbe3d63,liblibc-bc3e3e692ddd7ff7,liblog-0cf16875f1b0d734,liblog-5081bf809293ba62}.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" "/opt/rustwide/target/debug/deps/rustcCWsUY2/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-873915e0aba8e894" "-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" "1e551eded444127193ece8bdbeda34bc4aec477f80b2c7ac3e78592ec4c51117", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1e551eded444127193ece8bdbeda34bc4aec477f80b2c7ac3e78592ec4c51117", kill_on_drop: false }`
[INFO] [stdout] 1e551eded444127193ece8bdbeda34bc4aec477f80b2c7ac3e78592ec4c51117
