[INFO] cloning repository https://github.com/HaroldRobson/MEV_JUNE [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/HaroldRobson/MEV_JUNE" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FHaroldRobson%2FMEV_JUNE", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FHaroldRobson%2FMEV_JUNE'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] fdd539c4462ce7b08ee5ea1fb863be517826a628 [INFO] checking HaroldRobson/MEV_JUNE against master#42f4793e5a514858221b07ac379029d90353913e for pr-148952 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FHaroldRobson%2FMEV_JUNE" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'... [INFO] [stderr] done. [INFO] [stderr] Updating files: 60% (1526/2502) Updating files: 61% (1527/2502) Updating files: 62% (1552/2502) Updating files: 63% (1577/2502) Updating files: 64% (1602/2502) Updating files: 65% (1627/2502) Updating files: 66% (1652/2502) Updating files: 67% (1677/2502) Updating files: 68% (1702/2502) Updating files: 69% (1727/2502) Updating files: 70% (1752/2502) Updating files: 71% (1777/2502) Updating files: 72% (1802/2502) Updating files: 73% (1827/2502) Updating files: 74% (1852/2502) Updating files: 75% (1877/2502) Updating files: 76% (1902/2502) Updating files: 77% (1927/2502) Updating files: 78% (1952/2502) Updating files: 79% (1977/2502) Updating files: 80% (2002/2502) Updating files: 81% (2027/2502) Updating files: 82% (2052/2502) Updating files: 83% (2077/2502) Updating files: 84% (2102/2502) Updating files: 85% (2127/2502) Updating files: 86% (2152/2502) Updating files: 87% (2177/2502) Updating files: 88% (2202/2502) Updating files: 89% (2227/2502) Updating files: 90% (2252/2502) Updating files: 91% (2277/2502) Updating files: 92% (2302/2502) Updating files: 93% (2327/2502) Updating files: 94% (2352/2502) Updating files: 95% (2377/2502) Updating files: 96% (2402/2502) Updating files: 97% (2427/2502) Updating files: 98% (2452/2502) Updating files: 99% (2477/2502) Updating files: 100% (2502/2502) Updating files: 100% (2502/2502), done. [INFO] started tweaking git repo https://github.com/HaroldRobson/MEV_JUNE [INFO] finished tweaking git repo https://github.com/HaroldRobson/MEV_JUNE [INFO] tweaked toml for git repo https://github.com/HaroldRobson/MEV_JUNE written to /workspace/builds/worker-6-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/HaroldRobson/MEV_JUNE on toolchain 42f4793e5a514858221b07ac379029d90353913e [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+42f4793e5a514858221b07ac379029d90353913e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/HaroldRobson/MEV_JUNE 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" "+42f4793e5a514858221b07ac379029d90353913e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded message v0.1.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+42f4793e5a514858221b07ac379029d90353913e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 140fb82c4a999c6c0454b038d67750c651faf6a7c03b1dad390a8664b23e1c56 [INFO] running `Command { std: "docker" "start" "-a" "140fb82c4a999c6c0454b038d67750c651faf6a7c03b1dad390a8664b23e1c56", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "140fb82c4a999c6c0454b038d67750c651faf6a7c03b1dad390a8664b23e1c56", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "140fb82c4a999c6c0454b038d67750c651faf6a7c03b1dad390a8664b23e1c56", kill_on_drop: false }` [INFO] [stdout] 140fb82c4a999c6c0454b038d67750c651faf6a7c03b1dad390a8664b23e1c56 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+42f4793e5a514858221b07ac379029d90353913e" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 03d47dde593eff13934bfddec0224776cec96834a4aaa8ce1211bfa9481b9772 [INFO] running `Command { std: "docker" "start" "-a" "03d47dde593eff13934bfddec0224776cec96834a4aaa8ce1211bfa9481b9772", kill_on_drop: false }` [INFO] [stderr] Compiling cc v1.2.25 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Checking smallvec v1.15.0 [INFO] [stderr] Compiling syn v2.0.101 [INFO] [stderr] Checking mio v1.0.4 [INFO] [stderr] Checking socket2 v0.5.10 [INFO] [stderr] Checking simdutf8 v0.1.5 [INFO] [stderr] Checking fastrand v2.3.0 [INFO] [stderr] Checking message v0.1.0 [INFO] [stderr] Checking json v0.12.4 [INFO] [stderr] Checking parking_lot_core v0.9.11 [INFO] [stderr] Checking parking_lot v0.12.4 [INFO] [stderr] Checking ordered-float v2.10.1 [INFO] [stderr] Checking chrono v0.4.41 [INFO] [stderr] Compiling openssl-sys v0.9.109 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling openssl v0.10.73 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling tokio-macros v2.5.0 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Checking tokio v1.45.1 [INFO] [stderr] Checking futures-util v0.3.31 [INFO] [stderr] Checking serde v1.0.219 [INFO] [stderr] Checking futures-executor v0.3.31 [INFO] [stderr] Checking futures v0.3.31 [INFO] [stderr] Checking tokio-util v0.7.15 [INFO] [stderr] Checking tokio-native-tls v0.3.1 [INFO] [stderr] Checking tokio-websockets v0.11.4 [INFO] [stderr] Checking serde_json v1.0.140 [INFO] [stderr] Checking serde-value v0.7.0 [INFO] [stderr] Checking serde-aux v4.7.0 [INFO] [stderr] Checking lesson5 v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `tokio::*` [INFO] [stdout] --> src/main.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use tokio::*; [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: `Error` [INFO] [stdout] --> src/main.rs:7:39 [INFO] [stdout] | [INFO] [stdout] 7 | use tokio_websockets::{ClientBuilder, Error, Message}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_aux::prelude::*` [INFO] [stdout] --> src/market_data.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_aux::prelude::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::string` [INFO] [stdout] --> src/market_data.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::string; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `AskMarketQuote`, `BidMarketQuote`, `CoinBaseBookTicker`, and `ExchangeName` [INFO] [stdout] --> src/main.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | AskMarketQuote, BidMarketQuote, CoinBaseBookTicker, CoinBaseMessage, ExchangeName, [INFO] [stdout] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::Utc` [INFO] [stdout] --> src/ATOMIC_SP_MATRIX.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use chrono::Utc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Deserialize`, `Deserializer`, and `Serialize` [INFO] [stdout] --> src/ATOMIC_SP_MATRIX.rs:3:13 [INFO] [stdout] | [INFO] [stdout] 3 | use serde::{Deserialize, Deserializer, Serialize}; [INFO] [stdout] | ^^^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_aux::prelude::*` [INFO] [stdout] --> src/ATOMIC_SP_MATRIX.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_aux::prelude::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/ATOMIC_SP_MATRIX.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::mpsc` [INFO] [stdout] --> src/main.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use tokio::sync::mpsc; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::*` [INFO] [stdout] --> src/main.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use tokio::*; [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: `Error` [INFO] [stdout] --> src/main.rs:7:39 [INFO] [stdout] | [INFO] [stdout] 7 | use tokio_websockets::{ClientBuilder, Error, Message}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_aux::prelude::*` [INFO] [stdout] --> src/market_data.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_aux::prelude::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::string` [INFO] [stdout] --> src/market_data.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::string; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `AskMarketQuote`, `BidMarketQuote`, `CoinBaseBookTicker`, and `ExchangeName` [INFO] [stdout] --> src/main.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | AskMarketQuote, BidMarketQuote, CoinBaseBookTicker, CoinBaseMessage, ExchangeName, [INFO] [stdout] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::Utc` [INFO] [stdout] --> src/ATOMIC_SP_MATRIX.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use chrono::Utc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Deserialize`, `Deserializer`, and `Serialize` [INFO] [stdout] --> src/ATOMIC_SP_MATRIX.rs:3:13 [INFO] [stdout] | [INFO] [stdout] 3 | use serde::{Deserialize, Deserializer, Serialize}; [INFO] [stdout] | ^^^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_aux::prelude::*` [INFO] [stdout] --> src/ATOMIC_SP_MATRIX.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_aux::prelude::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/ATOMIC_SP_MATRIX.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::mpsc` [INFO] [stdout] --> src/main.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use tokio::sync::mpsc; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:116:13 [INFO] [stdout] | [INFO] [stdout] 116 | let mut handle = tokio::spawn(async move { [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: unused variable: `response` [INFO] [stdout] --> src/main.rs:38:33 [INFO] [stdout] | [INFO] [stdout] 38 | let (mut ws_stream, response) = match ClientBuilder::from_uri(uri).connect().await { [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_response` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `response` [INFO] [stdout] --> src/main.rs:118:33 [INFO] [stdout] | [INFO] [stdout] 118 | let (mut ws_stream, response) = match ClientBuilder::from_uri(uri).connect().await { [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_response` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `arb_opp_finder` [INFO] [stdout] --> src/main.rs:195:9 [INFO] [stdout] | [INFO] [stdout] 195 | let arb_opp_finder = tokio::spawn(async move { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arb_opp_finder` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `quantity` and `timestamp_ms` are never read [INFO] [stdout] --> src/market_data.rs:72:9 [INFO] [stdout] | [INFO] [stdout] 68 | pub struct AskMarketQuote { [INFO] [stdout] | -------------- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 72 | pub quantity: f64, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 73 | pub timestamp_ms: u64, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AskMarketQuote` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `quantity` and `timestamp_ms` are never read [INFO] [stdout] --> src/market_data.rs:81:9 [INFO] [stdout] | [INFO] [stdout] 77 | pub struct BidMarketQuote { [INFO] [stdout] | -------------- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 81 | pub quantity: f64, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 82 | pub timestamp_ms: u64, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `BidMarketQuote` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: module `ATOMIC_SP_MATRIX` should have a snake case name [INFO] [stdout] --> src/main.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | mod ATOMIC_SP_MATRIX; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `atomic_sp_matrix` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/main.rs:56:13 [INFO] [stdout] | [INFO] [stdout] 56 | / ws_stream [INFO] [stdout] 57 | | .send(Message::text(subscribe_msg.to_string())) [INFO] [stdout] 58 | | .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] 56 | let _ = ws_stream [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `CBstreams` should have a snake case name [INFO] [stdout] --> src/main.rs:110:9 [INFO] [stdout] | [INFO] [stdout] 110 | let CBstreams = vec![("", "wss://advanced-trade-ws.coinbase.com")]; [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `cbstreams` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/main.rs:131:13 [INFO] [stdout] | [INFO] [stdout] 131 | / ws_stream [INFO] [stdout] 132 | | .send(Message::text(subscribe_msg.to_string())) [INFO] [stdout] 133 | | .await; [INFO] [stdout] | |______________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 131 | let _ = ws_stream [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `asToken` should have a snake case name [INFO] [stdout] --> src/market_data.rs:48:8 [INFO] [stdout] | [INFO] [stdout] 48 | fn asToken(symbol: String) -> Token { [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `as_token` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `getAskMarketQuotes` should have a snake case name [INFO] [stdout] --> src/market_data.rs:111:12 [INFO] [stdout] | [INFO] [stdout] 111 | pub fn getAskMarketQuotes(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_ask_market_quotes` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `AskMarketQuoteVec` should have a snake case name [INFO] [stdout] --> src/market_data.rs:112:17 [INFO] [stdout] | [INFO] [stdout] 112 | let mut AskMarketQuoteVec: Vec = Vec::new(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote_vec` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `askMarketQuote` should have a snake case name [INFO] [stdout] --> src/market_data.rs:116:13 [INFO] [stdout] | [INFO] [stdout] 116 | let askMarketQuote = AskMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `getBidMarketQuotes` should have a snake case name [INFO] [stdout] --> src/market_data.rs:129:12 [INFO] [stdout] | [INFO] [stdout] 129 | pub fn getBidMarketQuotes(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_bid_market_quotes` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `bidMarketQuoteVec` should have a snake case name [INFO] [stdout] --> src/market_data.rs:130:17 [INFO] [stdout] | [INFO] [stdout] 130 | let mut bidMarketQuoteVec: Vec = Vec::new(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote_vec` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `bidMarketQuote` should have a snake case name [INFO] [stdout] --> src/market_data.rs:134:13 [INFO] [stdout] | [INFO] [stdout] 134 | let bidMarketQuote = BidMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `getBidMarketQuotes` should have a snake case name [INFO] [stdout] --> src/market_data.rs:181:12 [INFO] [stdout] | [INFO] [stdout] 181 | pub fn getBidMarketQuotes(&self) -> BidMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_bid_market_quotes` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `bidMarketQuote` should have a snake case name [INFO] [stdout] --> src/market_data.rs:184:13 [INFO] [stdout] | [INFO] [stdout] 184 | let bidMarketQuote = BidMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `getAskMarketQuotes` should have a snake case name [INFO] [stdout] --> src/market_data.rs:195:12 [INFO] [stdout] | [INFO] [stdout] 195 | pub fn getAskMarketQuotes(&self) -> AskMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_ask_market_quotes` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `askMarketQuote` should have a snake case name [INFO] [stdout] --> src/market_data.rs:198:13 [INFO] [stdout] | [INFO] [stdout] 198 | let askMarketQuote = AskMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:116:13 [INFO] [stdout] | [INFO] [stdout] 116 | let mut handle = tokio::spawn(async move { [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: unused variable: `response` [INFO] [stdout] --> src/main.rs:38:33 [INFO] [stdout] | [INFO] [stdout] 38 | let (mut ws_stream, response) = match ClientBuilder::from_uri(uri).connect().await { [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_response` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `response` [INFO] [stdout] --> src/main.rs:118:33 [INFO] [stdout] | [INFO] [stdout] 118 | let (mut ws_stream, response) = match ClientBuilder::from_uri(uri).connect().await { [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_response` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `arb_opp_finder` [INFO] [stdout] --> src/main.rs:195:9 [INFO] [stdout] | [INFO] [stdout] 195 | let arb_opp_finder = tokio::spawn(async move { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arb_opp_finder` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `quantity` and `timestamp_ms` are never read [INFO] [stdout] --> src/market_data.rs:72:9 [INFO] [stdout] | [INFO] [stdout] 68 | pub struct AskMarketQuote { [INFO] [stdout] | -------------- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 72 | pub quantity: f64, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 73 | pub timestamp_ms: u64, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AskMarketQuote` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `quantity` and `timestamp_ms` are never read [INFO] [stdout] --> src/market_data.rs:81:9 [INFO] [stdout] | [INFO] [stdout] 77 | pub struct BidMarketQuote { [INFO] [stdout] | -------------- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 81 | pub quantity: f64, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 82 | pub timestamp_ms: u64, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `BidMarketQuote` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: module `ATOMIC_SP_MATRIX` should have a snake case name [INFO] [stdout] --> src/main.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | mod ATOMIC_SP_MATRIX; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `atomic_sp_matrix` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/main.rs:56:13 [INFO] [stdout] | [INFO] [stdout] 56 | / ws_stream [INFO] [stdout] 57 | | .send(Message::text(subscribe_msg.to_string())) [INFO] [stdout] 58 | | .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] 56 | let _ = ws_stream [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `CBstreams` should have a snake case name [INFO] [stdout] --> src/main.rs:110:9 [INFO] [stdout] | [INFO] [stdout] 110 | let CBstreams = vec![("", "wss://advanced-trade-ws.coinbase.com")]; [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `cbstreams` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/main.rs:131:13 [INFO] [stdout] | [INFO] [stdout] 131 | / ws_stream [INFO] [stdout] 132 | | .send(Message::text(subscribe_msg.to_string())) [INFO] [stdout] 133 | | .await; [INFO] [stdout] | |______________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 131 | let _ = ws_stream [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `asToken` should have a snake case name [INFO] [stdout] --> src/market_data.rs:48:8 [INFO] [stdout] | [INFO] [stdout] 48 | fn asToken(symbol: String) -> Token { [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `as_token` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `getAskMarketQuotes` should have a snake case name [INFO] [stdout] --> src/market_data.rs:111:12 [INFO] [stdout] | [INFO] [stdout] 111 | pub fn getAskMarketQuotes(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_ask_market_quotes` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `AskMarketQuoteVec` should have a snake case name [INFO] [stdout] --> src/market_data.rs:112:17 [INFO] [stdout] | [INFO] [stdout] 112 | let mut AskMarketQuoteVec: Vec = Vec::new(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote_vec` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `askMarketQuote` should have a snake case name [INFO] [stdout] --> src/market_data.rs:116:13 [INFO] [stdout] | [INFO] [stdout] 116 | let askMarketQuote = AskMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `getBidMarketQuotes` should have a snake case name [INFO] [stdout] --> src/market_data.rs:129:12 [INFO] [stdout] | [INFO] [stdout] 129 | pub fn getBidMarketQuotes(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_bid_market_quotes` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `bidMarketQuoteVec` should have a snake case name [INFO] [stdout] --> src/market_data.rs:130:17 [INFO] [stdout] | [INFO] [stdout] 130 | let mut bidMarketQuoteVec: Vec = Vec::new(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote_vec` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `bidMarketQuote` should have a snake case name [INFO] [stdout] --> src/market_data.rs:134:13 [INFO] [stdout] | [INFO] [stdout] 134 | let bidMarketQuote = BidMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `getBidMarketQuotes` should have a snake case name [INFO] [stdout] --> src/market_data.rs:181:12 [INFO] [stdout] | [INFO] [stdout] 181 | pub fn getBidMarketQuotes(&self) -> BidMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_bid_market_quotes` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `bidMarketQuote` should have a snake case name [INFO] [stdout] --> src/market_data.rs:184:13 [INFO] [stdout] | [INFO] [stdout] 184 | let bidMarketQuote = BidMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `bid_market_quote` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `getAskMarketQuotes` should have a snake case name [INFO] [stdout] --> src/market_data.rs:195:12 [INFO] [stdout] | [INFO] [stdout] 195 | pub fn getAskMarketQuotes(&self) -> AskMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_ask_market_quotes` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `askMarketQuote` should have a snake case name [INFO] [stdout] --> src/market_data.rs:198:13 [INFO] [stdout] | [INFO] [stdout] 198 | let askMarketQuote = AskMarketQuote { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ask_market_quote` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 35.55s [INFO] running `Command { std: "docker" "inspect" "03d47dde593eff13934bfddec0224776cec96834a4aaa8ce1211bfa9481b9772", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "03d47dde593eff13934bfddec0224776cec96834a4aaa8ce1211bfa9481b9772", kill_on_drop: false }` [INFO] [stdout] 03d47dde593eff13934bfddec0224776cec96834a4aaa8ce1211bfa9481b9772