[INFO] fetching crate gt7_server 1.1.1...
[INFO] checking gt7_server-1.1.1 against master#779e19d8baa3e3625bd4fc5c85cbb2ad47b43155 for pr-147589-1
[INFO] extracting crate gt7_server 1.1.1 into /workspace/builds/worker-2-tc1/source
[INFO] started tweaking crates.io crate gt7_server 1.1.1
[INFO] finished tweaking crates.io crate gt7_server 1.1.1
[INFO] tweaked toml for crates.io crate gt7_server 1.1.1 written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate gt7_server 1.1.1 on toolchain 779e19d8baa3e3625bd4fc5c85cbb2ad47b43155
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate gt7_server 1.1.1 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded thiserror v1.0.65
[INFO] [stderr]   Downloaded thiserror-impl v1.0.65
[INFO] [stderr]   Downloaded serde_derive v1.0.213
[INFO] [stderr]   Downloaded bytes v1.8.0
[INFO] [stderr]   Downloaded tokio-stream v0.1.16
[INFO] [stderr]   Downloaded pin-project v1.1.6
[INFO] [stderr]   Downloaded serde v1.0.213
[INFO] [stderr]   Downloaded warp v0.3.7
[INFO] [stderr]   Downloaded pin-project-internal v1.1.6
[INFO] [stderr]   Downloaded tokio v1.41.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 656e85ab8a9191853f3671f0bba46dfe3a9bc32cf7e39c98a8929689cdf59f7a
[INFO] running `Command { std: "docker" "start" "-a" "656e85ab8a9191853f3671f0bba46dfe3a9bc32cf7e39c98a8929689cdf59f7a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "656e85ab8a9191853f3671f0bba46dfe3a9bc32cf7e39c98a8929689cdf59f7a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "656e85ab8a9191853f3671f0bba46dfe3a9bc32cf7e39c98a8929689cdf59f7a", kill_on_drop: false }`
[INFO] [stdout] 656e85ab8a9191853f3671f0bba46dfe3a9bc32cf7e39c98a8929689cdf59f7a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a8f84acd80eddc9fe7f7661a565fdeca798139b00dac09ab633f1e388f4d58ba
[INFO] running `Command { std: "docker" "start" "-a" "a8f84acd80eddc9fe7f7661a565fdeca798139b00dac09ab633f1e388f4d58ba", kill_on_drop: false }`
[INFO] [stderr]     Checking bytes v1.8.0
[INFO] [stderr]    Compiling libc v0.2.161
[INFO] [stderr]    Compiling httparse v1.9.5
[INFO] [stderr]    Compiling serde v1.0.213
[INFO] [stderr]     Checking unicode-bidi v0.3.17
[INFO] [stderr]    Compiling thiserror v1.0.65
[INFO] [stderr]     Checking tinyvec v1.8.0
[INFO] [stderr]     Checking cpufeatures v0.2.14
[INFO] [stderr]    Compiling unicase v2.8.0
[INFO] [stderr]    Compiling syn v2.0.82
[INFO] [stderr]     Checking tracing-core v0.1.32
[INFO] [stderr]     Checking hashbrown v0.15.0
[INFO] [stderr]    Compiling multer v2.1.0
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]    Compiling serde_json v1.0.132
[INFO] [stderr]     Checking inout v0.1.3
[INFO] [stderr]     Checking cipher v0.4.4
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking salsa20 v0.10.2
[INFO] [stderr]     Checking http v0.2.12
[INFO] [stderr]     Checking http v1.1.0
[INFO] [stderr]     Checking indexmap v2.6.0
[INFO] [stderr]     Checking unicode-normalization v0.1.24
[INFO] [stderr]     Checking mio v1.0.2
[INFO] [stderr]     Checking socket2 v0.5.7
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking idna v0.5.0
[INFO] [stderr]     Checking http-body v0.4.6
[INFO] [stderr]     Checking headers-core v0.2.0
[INFO] [stderr]     Checking headers v0.3.9
[INFO] [stderr]     Checking url v2.5.2
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling tokio-macros v2.4.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.65
[INFO] [stderr]    Compiling serde_derive v1.0.213
[INFO] [stderr]    Compiling pin-project-internal v1.1.6
[INFO] [stderr]     Checking tokio v1.41.0
[INFO] [stderr]     Checking zerocopy v0.7.35
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking ppv-lite86 v0.2.20
[INFO] [stderr]     Checking pin-project v1.1.6
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking tungstenite v0.21.0
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking tokio-util v0.7.12
[INFO] [stderr]     Checking tokio-tungstenite v0.21.0
[INFO] [stderr]     Checking h2 v0.3.26
[INFO] [stderr]     Checking tokio-stream v0.1.16
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking hyper v0.14.31
[INFO] [stderr]     Checking warp v0.3.7
[INFO] [stderr]     Checking gt7_server v1.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/gt_data/gt_data.rs:87:29
[INFO] [stdout]    |
[INFO] [stdout] 87 |         data.current_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111);
[INFO] [stdout]    |                             ^                                                       ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 87 -         data.current_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111);
[INFO] [stdout] 87 +         data.current_gear = LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/gt_data/gt_data.rs:88:31
[INFO] [stdout]    |
[INFO] [stdout] 88 |         data.suggested_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4);
[INFO] [stdout]    |                               ^                                               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 88 -         data.suggested_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4);
[INFO] [stdout] 88 +         data.suggested_gear = LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `StreamCipherSeek`
[INFO] [stdout]  --> src/socket_server/helper.rs:1:48
[INFO] [stdout]   |
[INFO] [stdout] 1 | use salsa20::cipher::{KeyIvInit, StreamCipher, StreamCipherSeek};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TryStreamExt`
[INFO] [stdout]  --> src/server/ws.rs:3:37
[INFO] [stdout]   |
[INFO] [stdout] 3 | use futures::{StreamExt, FutureExt, TryStreamExt};
[INFO] [stdout]   |                                     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `reply::json` and `ws::Message`
[INFO] [stdout]  --> src/server/handler.rs:4:30
[INFO] [stdout]   |
[INFO] [stdout] 4 | use warp::{http::StatusCode, reply::json, ws::Message, Reply, Rejection};
[INFO] [stdout]   |                              ^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::convert::Infallible`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::convert::Infallible;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/gt_data/gt_data.rs:87:29
[INFO] [stdout]    |
[INFO] [stdout] 87 |         data.current_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111);
[INFO] [stdout]    |                             ^                                                       ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 87 -         data.current_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111);
[INFO] [stdout] 87 +         data.current_gear = LittleEndian::read_u16(&ddata[0x90..0x92]) & 0b00001111 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/gt_data/gt_data.rs:88:31
[INFO] [stdout]    |
[INFO] [stdout] 88 |         data.suggested_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4);
[INFO] [stdout]    |                               ^                                               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 88 -         data.suggested_gear = (LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4);
[INFO] [stdout] 88 +         data.suggested_gear = LittleEndian::read_u16(&ddata[0x90..0x92]) >> 4 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `StreamCipherSeek`
[INFO] [stdout]  --> src/socket_server/helper.rs:1:48
[INFO] [stdout]   |
[INFO] [stdout] 1 | use salsa20::cipher::{KeyIvInit, StreamCipher, StreamCipherSeek};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TryStreamExt`
[INFO] [stdout]  --> src/server/ws.rs:3:37
[INFO] [stdout]   |
[INFO] [stdout] 3 | use futures::{StreamExt, FutureExt, TryStreamExt};
[INFO] [stdout]   |                                     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `reply::json` and `ws::Message`
[INFO] [stdout]  --> src/server/handler.rs:4:30
[INFO] [stdout]   |
[INFO] [stdout] 4 | use warp::{http::StatusCode, reply::json, ws::Message, Reply, Rejection};
[INFO] [stdout]   |                              ^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::convert::Infallible`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::convert::Infallible;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `FutureExt`
[INFO] [stdout]  --> src/server/ws.rs:3:26
[INFO] [stdout]   |
[INFO] [stdout] 3 | use futures::{StreamExt, FutureExt, TryStreamExt};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `FutureExt`
[INFO] [stdout]  --> src/server/ws.rs:3:26
[INFO] [stdout]   |
[INFO] [stdout] 3 | use futures::{StreamExt, FutureExt, TryStreamExt};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `r_size`
[INFO] [stdout]    --> src/socket_server/socket_server.rs:118:16
[INFO] [stdout]     |
[INFO] [stdout] 118 |             Ok(r_size) => {
[INFO] [stdout]     |                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_r_size`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `client_ws_rcv`
[INFO] [stdout]   --> src/server/ws.rs:10:28
[INFO] [stdout]    |
[INFO] [stdout] 10 |     let (client_ws_sender, client_ws_rcv) = ws.split();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_client_ws_rcv`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `r_size`
[INFO] [stdout]    --> src/socket_server/socket_server.rs:118:16
[INFO] [stdout]     |
[INFO] [stdout] 118 |             Ok(r_size) => {
[INFO] [stdout]     |                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_r_size`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `client_ws_rcv`
[INFO] [stdout]   --> src/server/ws.rs:10:28
[INFO] [stdout]    |
[INFO] [stdout] 10 |     let (client_ws_sender, client_ws_rcv) = ws.split();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_client_ws_rcv`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 |     let mut playstation_ip: String;
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let mut ws_port: u16;
[INFO] [stdout]    |         ----^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:36:14
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let (tx, mut rx) = broadcast::channel::<GTData>(100);
[INFO] [stdout]    |              ----^^
[INFO] [stdout]    |              |
[INFO] [stdout]    |              help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rx`
[INFO] [stdout]   --> src/main.rs:36:14
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let (tx, mut rx) = broadcast::channel::<GTData>(100);
[INFO] [stdout]    |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_rx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     tyre_diameter_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_fl`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     tyre_diameter_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     tyre_diameter_RL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     tyre_diameter_RR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     type_speed_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     type_speed_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     type_speed_RL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_speed_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     tyre_speed_RR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_speed_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     tyre_slip_ratio_FL: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     tyre_slip_ratio_FR: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     tyre_slip_ratio_RL: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     tyre_slip_ratio_RR: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_temp_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     tyre_temp_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_temp_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_temp_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     tyre_temp_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_temp_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 |     let mut playstation_ip: String;
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let mut ws_port: u16;
[INFO] [stdout]    |         ----^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:36:14
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let (tx, mut rx) = broadcast::channel::<GTData>(100);
[INFO] [stdout]    |              ----^^
[INFO] [stdout]    |              |
[INFO] [stdout]    |              help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rx`
[INFO] [stdout]   --> src/main.rs:36:14
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let (tx, mut rx) = broadcast::channel::<GTData>(100);
[INFO] [stdout]    |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_rx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/server/ws.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | /     bs.map(|data| {
[INFO] [stdout] 14 | |         Ok(Message::text(serde_json::to_string(&data.unwrap()).unwrap()))
[INFO] [stdout] 15 | |     }).forward(client_ws_sender).await;
[INFO] [stdout]    | |______________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 13 |     let _ = bs.map(|data| {
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     tyre_diameter_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_fl`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     tyre_diameter_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     tyre_diameter_RL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_diameter_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     tyre_diameter_RR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_diameter_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     type_speed_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     type_speed_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `type_speed_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     type_speed_RL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `type_speed_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_speed_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     tyre_speed_RR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_speed_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     tyre_slip_ratio_FL: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     tyre_slip_ratio_FR: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_RL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     tyre_slip_ratio_RL: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_slip_ratio_RR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     tyre_slip_ratio_RR: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_slip_ratio_rr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_temp_FL` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     tyre_temp_FL: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_temp_fl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tyre_temp_FR` should have a snake case name
[INFO] [stdout]   --> src/gt_data/gt_data.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     tyre_temp_FR: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to snake case: `tyre_temp_fr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/server/ws.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | /     bs.map(|data| {
[INFO] [stdout] 14 | |         Ok(Message::text(serde_json::to_string(&data.unwrap()).unwrap()))
[INFO] [stdout] 15 | |     }).forward(client_ws_sender).await;
[INFO] [stdout]    | |______________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 13 |     let _ = bs.map(|data| {
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 29.75s
[INFO] running `Command { std: "docker" "inspect" "a8f84acd80eddc9fe7f7661a565fdeca798139b00dac09ab633f1e388f4d58ba", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a8f84acd80eddc9fe7f7661a565fdeca798139b00dac09ab633f1e388f4d58ba", kill_on_drop: false }`
[INFO] [stdout] a8f84acd80eddc9fe7f7661a565fdeca798139b00dac09ab633f1e388f4d58ba
