[INFO] fetching crate irox-sirf 0.3.1...
[INFO] checking irox-sirf-0.3.1 against master#30f74ff0dc4d66debc8b50724c446f817e5f75f4 for pr-121848-1
[INFO] extracting crate irox-sirf 0.3.1 into /workspace/builds/worker-3-tc1/source
[INFO] validating manifest of crates.io crate irox-sirf 0.3.1 on toolchain 30f74ff0dc4d66debc8b50724c446f817e5f75f4
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate irox-sirf 0.3.1
[INFO] finished tweaking crates.io crate irox-sirf 0.3.1
[INFO] tweaked toml for crates.io crate irox-sirf 0.3.1 written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded irox-tools v0.6.0
[INFO] [stderr]   Downloaded irox-enums v0.2.2
[INFO] [stderr]   Downloaded irox-enums_derive v0.2.2
[INFO] [stderr]   Downloaded irox-types v0.3.0
[INFO] [stderr]   Downloaded irox-structs_derive v0.2.3
[INFO] [stderr]   Downloaded irox-structs v0.4.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 9273e254f7efbc2d0375190c2d1de9826bc4adbbddd6e86c9bb13b346c5df66c
[INFO] running `Command { std: "docker" "start" "-a" "9273e254f7efbc2d0375190c2d1de9826bc4adbbddd6e86c9bb13b346c5df66c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "9273e254f7efbc2d0375190c2d1de9826bc4adbbddd6e86c9bb13b346c5df66c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9273e254f7efbc2d0375190c2d1de9826bc4adbbddd6e86c9bb13b346c5df66c", kill_on_drop: false }`
[INFO] [stdout] 9273e254f7efbc2d0375190c2d1de9826bc4adbbddd6e86c9bb13b346c5df66c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6f1b45549a6985209bd62d593c1d76bb36de9517df7e9c88e7145519842e2368
[INFO] running `Command { std: "docker" "start" "-a" "6f1b45549a6985209bd62d593c1d76bb36de9517df7e9c88e7145519842e2368", kill_on_drop: false }`
[INFO] [stderr]     Checking irox-tools v0.6.0
[INFO] [stderr]    Compiling syn v2.0.57
[INFO] [stderr]    Compiling irox-enums_derive v0.2.2
[INFO] [stderr]    Compiling irox-enums v0.2.2
[INFO] [stderr]    Compiling irox-types v0.3.0
[INFO] [stderr]    Compiling irox-structs_derive v0.2.3
[INFO] [stderr]     Checking irox-structs v0.4.0
[INFO] [stderr]     Checking irox-sirf v0.3.1 (/opt/rustwide/workdir)
[INFO] [stdout] error[E0432]: unresolved import `irox_tools::read::consume_until`
[INFO] [stdout]  --> src/packet.rs:8:24
[INFO] [stdout]   |
[INFO] [stdout] 8 | use irox_tools::read::{consume_until, read_exact, read_exact_vec};
[INFO] [stdout]   |                        ^^^^^^^^^^^^^ no `consume_until` in `read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `irox_tools::read::consume_until`
[INFO] [stdout]  --> src/packet.rs:8:24
[INFO] [stdout]   |
[INFO] [stdout] 8 | use irox_tools::read::{consume_until, read_exact, read_exact_vec};
[INFO] [stdout]   |                        ^^^^^^^^^^^^^ no `consume_until` in `read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/x02_mesnavdata.rs:99:22
[INFO] [stdout]    |
[INFO] [stdout] 99 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/x02_mesnavdata.rs:99:22
[INFO] [stdout]    |
[INFO] [stdout] 99 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/x1e_navsvstate.rs:44:22
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<NavLibSVState, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/x1e_navsvstate.rs:44:22
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<NavLibSVState, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/xff_asciidata.rs:30:22
[INFO] [stdout]    |
[INFO] [stdout] 30 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<AsciiData, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/xff_asciidata.rs:30:22
[INFO] [stdout]    |
[INFO] [stdout] 30 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<AsciiData, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]    --> src/packet.rs:155:22
[INFO] [stdout]     |
[INFO] [stdout] 155 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<PacketType, Self::Error> {
[INFO] [stdout]     |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]    --> src/packet.rs:155:22
[INFO] [stdout]     |
[INFO] [stdout] 155 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<PacketType, Self::Error> {
[INFO] [stdout]     |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:100:32
[INFO] [stdout]     |
[INFO] [stdout] 100 |         let x_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:100:32
[INFO] [stdout]     |
[INFO] [stdout] 100 |         let x_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:101:32
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let y_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:101:32
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let y_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:102:32
[INFO] [stdout]     |
[INFO] [stdout] 102 |         let z_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:103:40
[INFO] [stdout]     |
[INFO] [stdout] 103 |         let x_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:104:40
[INFO] [stdout]     |
[INFO] [stdout] 104 |         let y_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:102:32
[INFO] [stdout]     |
[INFO] [stdout] 102 |         let z_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:105:40
[INFO] [stdout]     |
[INFO] [stdout] 105 |         let z_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:103:40
[INFO] [stdout]     |
[INFO] [stdout] 103 |         let x_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:104:40
[INFO] [stdout]     |
[INFO] [stdout] 104 |         let y_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:105:40
[INFO] [stdout]     |
[INFO] [stdout] 105 |         let z_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:106:26
[INFO] [stdout]     |
[INFO] [stdout] 106 |         let mode = input.read_u8()?;
[INFO] [stdout]     |                          ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:107:30
[INFO] [stdout]     |
[INFO] [stdout] 107 |         let hdop = read_hdop(input)?;
[INFO] [stdout]     |                    --------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_hdop`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:169:17
[INFO] [stdout]     |
[INFO] [stdout] 169 | fn read_hdop<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                 ^^^^ required by this bound in `read_hdop`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:106:26
[INFO] [stdout]     |
[INFO] [stdout] 106 |         let mode = input.read_u8()?;
[INFO] [stdout]     |                          ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:107:30
[INFO] [stdout]     |
[INFO] [stdout] 107 |         let hdop = read_hdop(input)?;
[INFO] [stdout]     |                    --------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_hdop`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:169:17
[INFO] [stdout]     |
[INFO] [stdout] 169 | fn read_hdop<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                 ^^^^ required by this bound in `read_hdop`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:108:27
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mode2 = input.read_u8()?;
[INFO] [stdout]     |                           ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:108:27
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mode2 = input.read_u8()?;
[INFO] [stdout]     |                           ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_u16` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:109:30
[INFO] [stdout]     |
[INFO] [stdout] 109 |         let gps_week = input.read_be_u16()?;
[INFO] [stdout]     |                              ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_u16`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:110:41
[INFO] [stdout]     |
[INFO] [stdout] 110 |         let gps_tow = util::read_gpstow(input)?;
[INFO] [stdout]     |                       ----------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_gpstow`
[INFO] [stdout]    --> src/input/util.rs:11:23
[INFO] [stdout]     |
[INFO] [stdout] 11  | pub fn read_gpstow<T: Bits>(out: &mut T) -> Result<f64, std::io::Error> {
[INFO] [stdout]     |                       ^^^^ required by this bound in `read_gpstow`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_u16` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:109:30
[INFO] [stdout]     |
[INFO] [stdout] 109 |         let gps_week = input.read_be_u16()?;
[INFO] [stdout]     |                              ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_u16`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:110:41
[INFO] [stdout]     |
[INFO] [stdout] 110 |         let gps_tow = util::read_gpstow(input)?;
[INFO] [stdout]     |                       ----------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_gpstow`
[INFO] [stdout]    --> src/input/util.rs:11:23
[INFO] [stdout]     |
[INFO] [stdout] 11  | pub fn read_gpstow<T: Bits>(out: &mut T) -> Result<f64, std::io::Error> {
[INFO] [stdout]     |                       ^^^^ required by this bound in `read_gpstow`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:111:32
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let svs_in_fix = input.read_u8()?;
[INFO] [stdout]     |                                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:111:32
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let svs_in_fix = input.read_u8()?;
[INFO] [stdout]     |                                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:112:29
[INFO] [stdout]     |
[INFO] [stdout] 112 |         let ch1_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:112:29
[INFO] [stdout]     |
[INFO] [stdout] 112 |         let ch1_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:113:29
[INFO] [stdout]     |
[INFO] [stdout] 113 |         let ch2_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:113:29
[INFO] [stdout]     |
[INFO] [stdout] 113 |         let ch2_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:114:29
[INFO] [stdout]     |
[INFO] [stdout] 114 |         let ch3_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:114:29
[INFO] [stdout]     |
[INFO] [stdout] 114 |         let ch3_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |         let ch4_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |         let ch4_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:116:29
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let ch5_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:116:29
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let ch5_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:117:29
[INFO] [stdout]     |
[INFO] [stdout] 117 |         let ch6_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:117:29
[INFO] [stdout]     |
[INFO] [stdout] 117 |         let ch6_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:118:29
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let ch7_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:118:29
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let ch7_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:119:29
[INFO] [stdout]     |
[INFO] [stdout] 119 |         let ch8_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:119:29
[INFO] [stdout]     |
[INFO] [stdout] 119 |         let ch8_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:120:29
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let ch9_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:120:29
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let ch9_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:121:30
[INFO] [stdout]     |
[INFO] [stdout] 121 |         let ch10_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:121:30
[INFO] [stdout]     |
[INFO] [stdout] 121 |         let ch10_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:122:30
[INFO] [stdout]     |
[INFO] [stdout] 122 |         let ch11_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:122:30
[INFO] [stdout]     |
[INFO] [stdout] 122 |         let ch11_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:123:30
[INFO] [stdout]     |
[INFO] [stdout] 123 |         let ch12_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:123:30
[INFO] [stdout]     |
[INFO] [stdout] 123 |         let ch12_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]   --> src/input/x1e_navsvstate.rs:45:35
[INFO] [stdout]    |
[INFO] [stdout] 45 |         NavLibSVState::parse_from(input)
[INFO] [stdout]    |         ------------------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]    |         |
[INFO] [stdout]    |         required by a bound introduced by this call
[INFO] [stdout]    |
[INFO] [stdout] note: required by a bound in `parse_from`
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/irox-structs-0.4.0/src/lib.rs:18:22
[INFO] [stdout]    |
[INFO] [stdout] 18 |     fn parse_from<T: Bits>(input: &mut T) -> Result<Self::ImplType, std::io::Error>;
[INFO] [stdout]    |                      ^^^^ required by this bound in `Struct::parse_from`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<NavLibSVState, Self::Error> {
[INFO] [stdout]    |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]   --> src/input/x1e_navsvstate.rs:45:35
[INFO] [stdout]    |
[INFO] [stdout] 45 |         NavLibSVState::parse_from(input)
[INFO] [stdout]    |         ------------------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]    |         |
[INFO] [stdout]    |         required by a bound introduced by this call
[INFO] [stdout]    |
[INFO] [stdout] note: required by a bound in `parse_from`
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/irox-structs-0.4.0/src/lib.rs:18:22
[INFO] [stdout]    |
[INFO] [stdout] 18 |     fn parse_from<T: Bits>(input: &mut T) -> Result<Self::ImplType, std::io::Error>;
[INFO] [stdout]    |                      ^^^^ required by this bound in `Struct::parse_from`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<NavLibSVState, Self::Error> {
[INFO] [stdout]    |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/packet.rs:156:58
[INFO] [stdout]     |
[INFO] [stdout] 156 |         let payload = Packetizer::new().read_next_packet(input)?;
[INFO] [stdout]     |                                         ---------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_next_packet`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/irox-tools-0.6.0/src/packetio.rs:34:28
[INFO] [stdout]     |
[INFO] [stdout] 34  | pub trait Packetization<T: Bits> {
[INFO] [stdout]     |                            ^^^^ required by this bound in `Packetization::read_next_packet`
[INFO] [stdout] 35  |     /// Reads the next packet from the source reader
[INFO] [stdout] 36  |     fn read_next_packet(&mut self, source: &mut T) -> Result<PacketData, Error>;
[INFO] [stdout]     |        ---------------- required by a bound in this associated function
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 155 |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<PacketType, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/packet.rs:156:58
[INFO] [stdout]     |
[INFO] [stdout] 156 |         let payload = Packetizer::new().read_next_packet(input)?;
[INFO] [stdout]     |                                         ---------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_next_packet`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/irox-tools-0.6.0/src/packetio.rs:34:28
[INFO] [stdout]     |
[INFO] [stdout] 34  | pub trait Packetization<T: Bits> {
[INFO] [stdout]     |                            ^^^^ required by this bound in `Packetization::read_next_packet`
[INFO] [stdout] 35  |     /// Reads the next packet from the source reader
[INFO] [stdout] 36  |     fn read_next_packet(&mut self, source: &mut T) -> Result<PacketData, Error>;
[INFO] [stdout]     |        ---------------- required by a bound in this associated function
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 155 |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<PacketType, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 31 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0276, E0277, E0432, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0276`.
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 31 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0276, E0277, E0432, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0276`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `irox-sirf` (lib) due to 32 previous errors
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error: could not compile `irox-sirf` (lib test) due to 32 previous errors
[INFO] running `Command { std: "docker" "inspect" "6f1b45549a6985209bd62d593c1d76bb36de9517df7e9c88e7145519842e2368", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6f1b45549a6985209bd62d593c1d76bb36de9517df7e9c88e7145519842e2368", kill_on_drop: false }`
[INFO] [stdout] 6f1b45549a6985209bd62d593c1d76bb36de9517df7e9c88e7145519842e2368
[INFO] checking irox-sirf-0.3.1 against try#72eda894eb3548c7ba774079ce0afab42958d4ee for pr-121848-1
[INFO] extracting crate irox-sirf 0.3.1 into /workspace/builds/worker-3-tc2/source
[INFO] validating manifest of crates.io crate irox-sirf 0.3.1 on toolchain 72eda894eb3548c7ba774079ce0afab42958d4ee
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate irox-sirf 0.3.1
[INFO] finished tweaking crates.io crate irox-sirf 0.3.1
[INFO] tweaked toml for crates.io crate irox-sirf 0.3.1 written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 90d9222a7ae78d566001c8e0c1dab4f24d41bb0ca71e8552ecaa718168cc0842
[INFO] running `Command { std: "docker" "start" "-a" "90d9222a7ae78d566001c8e0c1dab4f24d41bb0ca71e8552ecaa718168cc0842", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "90d9222a7ae78d566001c8e0c1dab4f24d41bb0ca71e8552ecaa718168cc0842", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "90d9222a7ae78d566001c8e0c1dab4f24d41bb0ca71e8552ecaa718168cc0842", kill_on_drop: false }`
[INFO] [stdout] 90d9222a7ae78d566001c8e0c1dab4f24d41bb0ca71e8552ecaa718168cc0842
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 4282bbe8fe621e91ec3e43307098be952f7d1b053eb6ba47c779649997f0f63b
[INFO] running `Command { std: "docker" "start" "-a" "4282bbe8fe621e91ec3e43307098be952f7d1b053eb6ba47c779649997f0f63b", kill_on_drop: false }`
[INFO] [stderr]     Checking irox-tools v0.6.0
[INFO] [stderr]    Compiling syn v2.0.57
[INFO] [stderr]    Compiling irox-enums_derive v0.2.2
[INFO] [stderr]    Compiling irox-enums v0.2.2
[INFO] [stderr]    Compiling irox-types v0.3.0
[INFO] [stderr]    Compiling irox-structs_derive v0.2.3
[INFO] [stderr]     Checking irox-structs v0.4.0
[INFO] [stderr]     Checking irox-sirf v0.3.1 (/opt/rustwide/workdir)
[INFO] [stdout] error[E0432]: unresolved import `irox_tools::read::consume_until`
[INFO] [stdout]  --> src/packet.rs:8:24
[INFO] [stdout]   |
[INFO] [stdout] 8 | use irox_tools::read::{consume_until, read_exact, read_exact_vec};
[INFO] [stdout]   |                        ^^^^^^^^^^^^^ no `consume_until` in `read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `irox_tools::read::consume_until`
[INFO] [stdout]  --> src/packet.rs:8:24
[INFO] [stdout]   |
[INFO] [stdout] 8 | use irox_tools::read::{consume_until, read_exact, read_exact_vec};
[INFO] [stdout]   |                        ^^^^^^^^^^^^^ no `consume_until` in `read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/x02_mesnavdata.rs:99:22
[INFO] [stdout]    |
[INFO] [stdout] 99 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/x02_mesnavdata.rs:99:22
[INFO] [stdout]    |
[INFO] [stdout] 99 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/x1e_navsvstate.rs:44:22
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<NavLibSVState, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/x1e_navsvstate.rs:44:22
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<NavLibSVState, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/xff_asciidata.rs:30:22
[INFO] [stdout]    |
[INFO] [stdout] 30 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<AsciiData, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]    --> src/packet.rs:155:22
[INFO] [stdout]     |
[INFO] [stdout] 155 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<PacketType, Self::Error> {
[INFO] [stdout]     |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]   --> src/input/xff_asciidata.rs:30:22
[INFO] [stdout]    |
[INFO] [stdout] 30 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<AsciiData, Self::Error> {
[INFO] [stdout]    |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0276]: impl has stricter requirements than trait
[INFO] [stdout]    --> src/packet.rs:155:22
[INFO] [stdout]     |
[INFO] [stdout] 155 |     fn build_from<T: Read>(&self, input: &mut T) -> Result<PacketType, Self::Error> {
[INFO] [stdout]     |                      ^^^^ impl has extra requirement `T: std::io::Read`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:100:32
[INFO] [stdout]     |
[INFO] [stdout] 100 |         let x_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:100:32
[INFO] [stdout]     |
[INFO] [stdout] 100 |         let x_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:101:32
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let y_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:101:32
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let y_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:102:32
[INFO] [stdout]     |
[INFO] [stdout] 102 |         let z_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:103:40
[INFO] [stdout]     |
[INFO] [stdout] 103 |         let x_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:104:40
[INFO] [stdout]     |
[INFO] [stdout] 104 |         let y_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:105:40
[INFO] [stdout]     |
[INFO] [stdout] 105 |         let z_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_i32` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:102:32
[INFO] [stdout]     |
[INFO] [stdout] 102 |         let z_position = input.read_be_i32()?;
[INFO] [stdout]     |                                ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_i32`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:103:40
[INFO] [stdout]     |
[INFO] [stdout] 103 |         let x_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:104:40
[INFO] [stdout]     |
[INFO] [stdout] 104 |         let y_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:105:40
[INFO] [stdout]     |
[INFO] [stdout] 105 |         let z_velocity = read_velocity(input)?;
[INFO] [stdout]     |                          ------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_velocity`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:159:21
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn read_velocity<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                     ^^^^ required by this bound in `read_velocity`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:106:26
[INFO] [stdout]     |
[INFO] [stdout] 106 |         let mode = input.read_u8()?;
[INFO] [stdout]     |                          ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:107:30
[INFO] [stdout]     |
[INFO] [stdout] 107 |         let hdop = read_hdop(input)?;
[INFO] [stdout]     |                    --------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_hdop`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:169:17
[INFO] [stdout]     |
[INFO] [stdout] 169 | fn read_hdop<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                 ^^^^ required by this bound in `read_hdop`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:106:26
[INFO] [stdout]     |
[INFO] [stdout] 106 |         let mode = input.read_u8()?;
[INFO] [stdout]     |                          ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:107:30
[INFO] [stdout]     |
[INFO] [stdout] 107 |         let hdop = read_hdop(input)?;
[INFO] [stdout]     |                    --------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_hdop`
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:169:17
[INFO] [stdout]     |
[INFO] [stdout] 169 | fn read_hdop<T: Bits>(out: &mut T) -> Result<f32, std::io::Error> {
[INFO] [stdout]     |                 ^^^^ required by this bound in `read_hdop`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:108:27
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mode2 = input.read_u8()?;
[INFO] [stdout]     |                           ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:108:27
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mode2 = input.read_u8()?;
[INFO] [stdout]     |                           ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_u16` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:109:30
[INFO] [stdout]     |
[INFO] [stdout] 109 |         let gps_week = input.read_be_u16()?;
[INFO] [stdout]     |                              ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_u16`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:110:41
[INFO] [stdout]     |
[INFO] [stdout] 110 |         let gps_tow = util::read_gpstow(input)?;
[INFO] [stdout]     |                       ----------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_gpstow`
[INFO] [stdout]    --> src/input/util.rs:11:23
[INFO] [stdout]     |
[INFO] [stdout] 11  | pub fn read_gpstow<T: Bits>(out: &mut T) -> Result<f64, std::io::Error> {
[INFO] [stdout]     |                       ^^^^ required by this bound in `read_gpstow`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_be_u16` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:109:30
[INFO] [stdout]     |
[INFO] [stdout] 109 |         let gps_week = input.read_be_u16()?;
[INFO] [stdout]     |                              ^^^^^^^^^^^ method not found in `&mut T`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: the following trait defines an item `read_be_u16`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:110:41
[INFO] [stdout]     |
[INFO] [stdout] 110 |         let gps_tow = util::read_gpstow(input)?;
[INFO] [stdout]     |                       ----------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_gpstow`
[INFO] [stdout]    --> src/input/util.rs:11:23
[INFO] [stdout]     |
[INFO] [stdout] 11  | pub fn read_gpstow<T: Bits>(out: &mut T) -> Result<f64, std::io::Error> {
[INFO] [stdout]     |                       ^^^^ required by this bound in `read_gpstow`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:111:32
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let svs_in_fix = input.read_u8()?;
[INFO] [stdout]     |                                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:111:32
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let svs_in_fix = input.read_u8()?;
[INFO] [stdout]     |                                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:112:29
[INFO] [stdout]     |
[INFO] [stdout] 112 |         let ch1_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:112:29
[INFO] [stdout]     |
[INFO] [stdout] 112 |         let ch1_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:113:29
[INFO] [stdout]     |
[INFO] [stdout] 113 |         let ch2_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:113:29
[INFO] [stdout]     |
[INFO] [stdout] 113 |         let ch2_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:114:29
[INFO] [stdout]     |
[INFO] [stdout] 114 |         let ch3_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:114:29
[INFO] [stdout]     |
[INFO] [stdout] 114 |         let ch3_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |         let ch4_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |         let ch4_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:116:29
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let ch5_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:116:29
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let ch5_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:117:29
[INFO] [stdout]     |
[INFO] [stdout] 117 |         let ch6_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:117:29
[INFO] [stdout]     |
[INFO] [stdout] 117 |         let ch6_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:118:29
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let ch7_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:119:29
[INFO] [stdout]     |
[INFO] [stdout] 119 |         let ch8_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:118:29
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let ch7_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:120:29
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let ch9_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:119:29
[INFO] [stdout]     |
[INFO] [stdout] 119 |         let ch8_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:121:30
[INFO] [stdout]     |
[INFO] [stdout] 121 |         let ch10_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:120:29
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let ch9_prn = input.read_u8()?;
[INFO] [stdout]     |                             ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:122:30
[INFO] [stdout]     |
[INFO] [stdout] 122 |         let ch11_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:121:30
[INFO] [stdout]     |
[INFO] [stdout] 121 |         let ch10_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:123:30
[INFO] [stdout]     |
[INFO] [stdout] 123 |         let ch12_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:122:30
[INFO] [stdout]     |
[INFO] [stdout] 122 |         let ch11_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]   --> src/input/x1e_navsvstate.rs:45:35
[INFO] [stdout]    |
[INFO] [stdout] 45 |         NavLibSVState::parse_from(input)
[INFO] [stdout]    |         ------------------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]    |         |
[INFO] [stdout]    |         required by a bound introduced by this call
[INFO] [stdout]    |
[INFO] [stdout] note: required by a bound in `parse_from`
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/irox-structs-0.4.0/src/lib.rs:18:22
[INFO] [stdout]    |
[INFO] [stdout] 18 |     fn parse_from<T: Bits>(input: &mut T) -> Result<Self::ImplType, std::io::Error>;
[INFO] [stdout]    |                      ^^^^ required by this bound in `Struct::parse_from`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<NavLibSVState, Self::Error> {
[INFO] [stdout]    |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/packet.rs:156:58
[INFO] [stdout]     |
[INFO] [stdout] 156 |         let payload = Packetizer::new().read_next_packet(input)?;
[INFO] [stdout]     |                                         ---------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_next_packet`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/irox-tools-0.6.0/src/packetio.rs:34:28
[INFO] [stdout]     |
[INFO] [stdout] 34  | pub trait Packetization<T: Bits> {
[INFO] [stdout]     |                            ^^^^ required by this bound in `Packetization::read_next_packet`
[INFO] [stdout] 35  |     /// Reads the next packet from the source reader
[INFO] [stdout] 36  |     fn read_next_packet(&mut self, source: &mut T) -> Result<PacketData, Error>;
[INFO] [stdout]     |        ---------------- required by a bound in this associated function
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 155 |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<PacketType, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `read_u8` found for mutable reference `&mut T` in the current scope
[INFO] [stdout]    --> src/input/x02_mesnavdata.rs:123:30
[INFO] [stdout]     |
[INFO] [stdout] 123 |         let ch12_prn = input.read_u8()?;
[INFO] [stdout]     |                              ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the type parameter is bounded by the trait
[INFO] [stdout] help: there is a method `read` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/std/src/io/mod.rs:742:5
[INFO] [stdout] help: the following trait defines an item `read_u8`, perhaps you need to restrict type parameter `T` with it:
[INFO] [stdout]     |
[INFO] [stdout] 99  |     fn build_from<T: Read + Bits>(&self, input: &mut T) -> Result<MeasuredNavigationData, Self::Error> {
[INFO] [stdout]     |                           ++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]   --> src/input/x1e_navsvstate.rs:45:35
[INFO] [stdout]    |
[INFO] [stdout] 45 |         NavLibSVState::parse_from(input)
[INFO] [stdout]    |         ------------------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]    |         |
[INFO] [stdout]    |         required by a bound introduced by this call
[INFO] [stdout]    |
[INFO] [stdout] note: required by a bound in `parse_from`
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/irox-structs-0.4.0/src/lib.rs:18:22
[INFO] [stdout]    |
[INFO] [stdout] 18 |     fn parse_from<T: Bits>(input: &mut T) -> Result<Self::ImplType, std::io::Error>;
[INFO] [stdout]    |                      ^^^^ required by this bound in `Struct::parse_from`
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<NavLibSVState, Self::Error> {
[INFO] [stdout]    |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 31 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0276, E0277, E0432, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0276`.
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `T: Bits` is not satisfied
[INFO] [stdout]    --> src/packet.rs:156:58
[INFO] [stdout]     |
[INFO] [stdout] 156 |         let payload = Packetizer::new().read_next_packet(input)?;
[INFO] [stdout]     |                                         ---------------- ^^^^^ the trait `Bits` is not implemented for `T`
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `read_next_packet`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/irox-tools-0.6.0/src/packetio.rs:34:28
[INFO] [stdout]     |
[INFO] [stdout] 34  | pub trait Packetization<T: Bits> {
[INFO] [stdout]     |                            ^^^^ required by this bound in `Packetization::read_next_packet`
[INFO] [stdout] 35  |     /// Reads the next packet from the source reader
[INFO] [stdout] 36  |     fn read_next_packet(&mut self, source: &mut T) -> Result<PacketData, Error>;
[INFO] [stdout]     |        ---------------- required by a bound in this associated function
[INFO] [stdout] help: consider further restricting this bound
[INFO] [stdout]     |
[INFO] [stdout] 155 |     fn build_from<T: Read + irox_structs::Bits>(&self, input: &mut T) -> Result<PacketType, Self::Error> {
[INFO] [stdout]     |                           ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `irox-sirf` (lib) due to 32 previous errors
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error: aborting due to 31 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0276, E0277, E0432, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0276`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `irox-sirf` (lib test) due to 32 previous errors
[INFO] running `Command { std: "docker" "inspect" "4282bbe8fe621e91ec3e43307098be952f7d1b053eb6ba47c779649997f0f63b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4282bbe8fe621e91ec3e43307098be952f7d1b053eb6ba47c779649997f0f63b", kill_on_drop: false }`
[INFO] [stdout] 4282bbe8fe621e91ec3e43307098be952f7d1b053eb6ba47c779649997f0f63b
