[INFO] fetching crate pitot 0.0.1...
[INFO] testing pitot-0.0.1 against try#c2e32f1c9652b13ed99608599c1e855462f421f3 for pr-146098-8
[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 c2e32f1c9652b13ed99608599c1e855462f421f3
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "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-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 8e3fdd50dec6e6e96f3fbad72269688e2982ad3e59ecff5f0f053fa395187ab1
[INFO] running `Command { std: "docker" "start" "-a" "8e3fdd50dec6e6e96f3fbad72269688e2982ad3e59ecff5f0f053fa395187ab1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "8e3fdd50dec6e6e96f3fbad72269688e2982ad3e59ecff5f0f053fa395187ab1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8e3fdd50dec6e6e96f3fbad72269688e2982ad3e59ecff5f0f053fa395187ab1", kill_on_drop: false }`
[INFO] [stdout] 8e3fdd50dec6e6e96f3fbad72269688e2982ad3e59ecff5f0f053fa395187ab1
[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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 07c6c24d8e853bd5f1a56ac8ebcd3f0c6bc3a26b26e81c9e66ff9eb1417b9cab
[INFO] running `Command { std: "docker" "start" "-a" "07c6c24d8e853bd5f1a56ac8ebcd3f0c6bc3a26b26e81c9e66ff9eb1417b9cab", 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 num-traits v0.2.19
[INFO] [stderr]    Compiling tinyvec v1.10.0
[INFO] [stderr]    Compiling quote v1.0.42
[INFO] [stderr]    Compiling unicode-bidi v0.3.18
[INFO] [stderr]    Compiling matches v0.1.10
[INFO] [stderr]    Compiling sha1_smol v1.0.1
[INFO] [stderr]    Compiling lazycell v1.3.0
[INFO] [stderr]    Compiling percent-encoding v1.0.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling sha1 v0.6.1
[INFO] [stderr]    Compiling log v0.3.9
[INFO] [stderr]    Compiling bitflags v0.9.1
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]    Compiling syn v2.0.110
[INFO] [stderr]    Compiling unicode-normalization v0.1.25
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling idna v0.1.5
[INFO] [stderr]    Compiling num-iter v0.1.45
[INFO] [stderr]    Compiling num v0.1.43
[INFO] [stderr]    Compiling url v1.7.2
[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 thread_local v0.2.7
[INFO] [stderr]    Compiling bytes v0.4.12
[INFO] [stderr]    Compiling aho-corasick v0.5.3
[INFO] [stderr]    Compiling time v0.1.45
[INFO] [stderr]    Compiling termios v0.2.2
[INFO] [stderr]    Compiling memchr v1.0.2
[INFO] [stderr]    Compiling inotify-sys v0.1.5
[INFO] [stderr]    Compiling ioctl-rs v0.1.6
[INFO] [stderr]    Compiling rand v0.4.6
[INFO] [stderr]    Compiling mio v0.6.23
[INFO] [stderr]    Compiling regex v0.1.80
[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 inotify v0.4.2
[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" "/tmp/rustcJ4zepg/symbols.o" "<17 object files omitted>" "-Wl,--as-needed" "-Wl,-Bdynamic" "-lrtlsdr" "-ldump978" "-ldump1090" "-Wl,-Bstatic" "/opt/rustwide/target/debug/deps/{libserde-37646bd4e49bfacd,libinotify-ba04b2929a71ff7c,libinotify_sys-a0a688dca27436a0,libbitflags-2381fd4b7839de46,libws-6cb92f842b5f8fd0,liburl-4d05370d96d649d6,libpercent_encoding-2853bb6f5ea162ad,libidna-5adc193d2fea4f66,libunicode_normalization-c8d5538d3790e8fb,libtinyvec-2583def413d04980,libtinyvec_macros-1c14e8980bff1229,libunicode_bidi-e61eae15e30d3a28,libmatches-78daa3f1b5ec35b5,libsha1-e444a5a6da6e8df8,libsha1_smol-4fed1055ba2d5f30,librand-9955f7f67f713936,libmio_extras-5f537a8df8f61e3b,liblazycell-0fc01752428421b1,libmio-34e7d6842c159492,libslab-8c0cbfb396425d81,libnet2-35a4555e293afcfc,libcfg_if-7e9efee4241be1ca,libhttparse-47a3d40564b60e09,libbytes-c1708db26e4053bc,libiovec-dd9ab6ab8250736d,libbyteorder-1efcbe4f07366651,libserde_json-f8dd111aa1eebc08,libmemchr-f04d4ed0ff57c3c8,libitoa-6b76ec393d6a2c41,libryu-0ea4bafc9bef6d8b,libserde_core-89637146ece38bd9,libnom-5383aeaa730bb55f,libmemchr-1aaab1f865a8ea8f,libserial-8a712407679dac28,libioctl_rs-287dda3d25f79352,libtermios-74cecba42fdcd4b4,libchrono-4fd84a9ca571b35e,libnum-5798cb7eef2de513,libnum_iter-739ff038a55c8c6a,libnum_integer-495a495718461c33,libnum_traits-e05972f153d0dad0,libtime-0f4969ccead839db,libenv_logger-d1b11340ef971a3f,libregex-716c140309665a9d,libutf8_ranges-95950487d995d2f0,libregex_syntax-0d2685fac6efdcc7,libthread_local-3aa984859c3d923d,libthread_id-f418f20015ba827c,libaho_corasick-7540d4f149740422,libmemchr-a61452274bdfbae9,liblibc-c690b88316dd3626,liblog-2e0e7e83e98a675c,liblog-28f8cc0684f4f944}.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/rustcJ4zepg/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-a8ed12a907078657" "-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" "07c6c24d8e853bd5f1a56ac8ebcd3f0c6bc3a26b26e81c9e66ff9eb1417b9cab", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "07c6c24d8e853bd5f1a56ac8ebcd3f0c6bc3a26b26e81c9e66ff9eb1417b9cab", kill_on_drop: false }`
[INFO] [stdout] 07c6c24d8e853bd5f1a56ac8ebcd3f0c6bc3a26b26e81c9e66ff9eb1417b9cab
