[INFO] cloning repository https://github.com/theoOdendaal/binny
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/theoOdendaal/binny" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FtheoOdendaal%2Fbinny", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FtheoOdendaal%2Fbinny'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] ea274f1304af965d8e13b853f78f43cab07be8a4
[INFO] checking theoOdendaal/binny against master#779e19d8baa3e3625bd4fc5c85cbb2ad47b43155 for pr-147589-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FtheoOdendaal%2Fbinny" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/theoOdendaal/binny
[INFO] finished tweaking git repo https://github.com/theoOdendaal/binny
[INFO] tweaked toml for git repo https://github.com/theoOdendaal/binny written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/theoOdendaal/binny 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 git repo https://github.com/theoOdendaal/binny 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]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded liblzma v0.4.2
[INFO] [stderr]   Downloaded rustls-native-certs v0.5.0
[INFO] [stderr]   Downloaded ppmd-rust v1.2.1
[INFO] [stderr]   Downloaded libbz2-rs-sys v0.2.1
[INFO] [stderr]   Downloaded bzip2 v0.6.0
[INFO] [stderr]   Downloaded zip v4.3.0
[INFO] [stderr]   Downloaded liblzma-sys v0.4.4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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] 908eaead8ed6984bd82b90ad7031b01022e9763358008c7f769bbfa4a9c4ad1d
[INFO] running `Command { std: "docker" "start" "-a" "908eaead8ed6984bd82b90ad7031b01022e9763358008c7f769bbfa4a9c4ad1d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "908eaead8ed6984bd82b90ad7031b01022e9763358008c7f769bbfa4a9c4ad1d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "908eaead8ed6984bd82b90ad7031b01022e9763358008c7f769bbfa4a9c4ad1d", kill_on_drop: false }`
[INFO] [stdout] 908eaead8ed6984bd82b90ad7031b01022e9763358008c7f769bbfa4a9c4ad1d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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] 7f6f7147ce48d5cd5816869450fe2233a78c45dd8a6e329590814798799dc562
[INFO] running `Command { std: "docker" "start" "-a" "7f6f7147ce48d5cd5816869450fe2233a78c45dd8a6e329590814798799dc562", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.174
[INFO] [stderr]     Checking cfg-if v1.0.1
[INFO] [stderr]    Compiling syn v2.0.104
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking slab v0.4.10
[INFO] [stderr]     Checking indexmap v2.10.0
[INFO] [stderr]     Checking bitflags v2.9.1
[INFO] [stderr]     Checking bytemuck v1.23.1
[INFO] [stderr]     Checking crc32fast v1.4.2
[INFO] [stderr]    Compiling matrixmultiply v0.3.10
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking zlib-rs v0.5.1
[INFO] [stderr]     Checking safe_arch v0.7.4
[INFO] [stderr]     Checking digest v0.9.0
[INFO] [stderr]     Checking wide v0.7.33
[INFO] [stderr]     Checking block-buffer v0.9.0
[INFO] [stderr]     Checking libbz2-rs-sys v0.2.1
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking parking_lot_core v0.9.11
[INFO] [stderr]     Checking mio v1.0.4
[INFO] [stderr]    Compiling jobserver v0.1.33
[INFO] [stderr]     Checking parking_lot v0.12.4
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]     Checking signal-hook-registry v1.4.5
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking libz-rs-sys v0.5.1
[INFO] [stderr]     Checking num-complex v0.4.6
[INFO] [stderr]     Checking bumpalo v3.19.0
[INFO] [stderr]    Compiling cc v1.2.29
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking opaque-debug v0.3.1
[INFO] [stderr]     Checking zopfli v0.8.2
[INFO] [stderr]     Checking sha-1 v0.9.8
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking flate2 v1.1.2
[INFO] [stderr]     Checking num-rational v0.4.2
[INFO] [stderr]     Checking bzip2 v0.6.0
[INFO] [stderr]     Checking getrandom v0.3.3
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking aes v0.8.4
[INFO] [stderr]     Checking simba v0.9.0
[INFO] [stderr]     Checking encoding_rs v0.8.35
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking constant_time_eq v0.3.1
[INFO] [stderr]     Checking ppmd-rust v1.2.1
[INFO] [stderr]     Checking deflate64 v0.1.9
[INFO] [stderr]     Checking chrono v0.4.41
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]    Compiling ring v0.16.20
[INFO] [stderr]    Compiling zstd-sys v2.0.15+zstd.1.5.7
[INFO] [stderr]    Compiling liblzma-sys v0.4.4
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking yoke v0.8.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]     Checking zerovec v0.11.2
[INFO] [stderr]    Compiling zeroize_derive v1.4.2
[INFO] [stderr]     Checking zerotrie v0.2.2
[INFO] [stderr]     Checking tokio v1.46.1
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]     Checking webpki v0.21.4
[INFO] [stderr]    Compiling zstd-safe v7.2.4
[INFO] [stderr]     Checking zeroize v1.8.1
[INFO] [stderr]     Checking sct v0.6.1
[INFO] [stderr]     Checking tinystr v0.8.1
[INFO] [stderr]     Checking potential_utf v0.1.2
[INFO] [stderr]     Checking rustls v0.19.1
[INFO] [stderr]     Checking icu_collections v2.0.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]     Checking icu_locale_core v2.0.0
[INFO] [stderr]     Checking zstd v0.13.3
[INFO] [stderr]     Checking rustls-pki-types v1.12.0
[INFO] [stderr]     Checking liblzma v0.4.2
[INFO] [stderr]    Compiling nalgebra-macros v0.2.2
[INFO] [stderr]     Checking zip v4.3.0
[INFO] [stderr]     Checking icu_provider v2.0.0
[INFO] [stderr]     Checking icu_properties v2.0.1
[INFO] [stderr]     Checking icu_normalizer v2.0.0
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking nalgebra v0.33.2
[INFO] [stderr]     Checking rustls-native-certs v0.5.0
[INFO] [stderr]     Checking serde v1.0.219
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.0.3
[INFO] [stderr]     Checking url v2.5.4
[INFO] [stderr]     Checking tungstenite v0.14.0
[INFO] [stderr]     Checking tokio-util v0.7.15
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking tower-http v0.6.6
[INFO] [stderr]     Checking h2 v0.4.11
[INFO] [stderr]     Checking serde_json v1.0.140
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking hyper v1.6.0
[INFO] [stderr]     Checking hyper-util v0.1.15
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking reqwest v0.12.22
[INFO] [stderr]     Checking binny v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `SimpleStrategy`
[INFO] [stdout]   --> src/main.rs:12:46
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::strategy::simple::{SimpleAverage, SimpleStrategy};
[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: `SimpleStrategy`
[INFO] [stdout]   --> src/main.rs:12:46
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::strategy::simple::{SimpleAverage, SimpleStrategy};
[INFO] [stdout]    |                                              ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `temp_stream` is never used
[INFO] [stdout]   --> src/main.rs:45:4
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn temp_stream() -> Result<(), Error> {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `BASE_END_POINT` is never used
[INFO] [stdout]   --> src/binance/stream.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | static BASE_END_POINT: &str = "wss://stream.binance.com:9443";
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `KlineInterval` is never used
[INFO] [stdout]   --> src/binance/stream.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum KlineInterval {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `stream_to_channel` is never used
[INFO] [stdout]   --> src/binance/stream.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 81 | pub fn stream_to_channel(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `BASE_END_POINT` is never used
[INFO] [stdout]  --> src/binance/trade_book.rs:3:8
[INFO] [stdout]   |
[INFO] [stdout] 3 | static BASE_END_POINT: &str = "wss://stream.binance.com:9443/ws";
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DiffDepthStream` is never constructed
[INFO] [stdout]  --> src/binance/trade_book.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct DiffDepthStream {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TIMESTAMP_CHANGE_2025_MS` is never used
[INFO] [stdout]  --> src/fs/parse.rs:8:7
[INFO] [stdout]   |
[INFO] [stdout] 8 | const TIMESTAMP_CHANGE_2025_MS: i64 = 1735689600000;
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `micro_seconds_to_datetime` is never used
[INFO] [stdout]   --> src/fs/parse.rs:10:4
[INFO] [stdout]    |
[INFO] [stdout] 10 | fn micro_seconds_to_datetime(t: &i64) -> LocalResult<DateTime<Utc>> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `milli_seconds_to_datetime` is never used
[INFO] [stdout]   --> src/fs/parse.rs:14:4
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn milli_seconds_to_datetime(t: &i64) -> LocalResult<DateTime<Utc>> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `binance_timestamp_to_datetime` is never used
[INFO] [stdout]   --> src/fs/parse.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub fn binance_timestamp_to_datetime(t: &i64) -> Option<DateTime<Utc>> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `to_log_returns` is never used
[INFO] [stdout]   --> src/math.rs:18:8
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub fn to_log_returns(observations: &[f64]) -> Vec<f64> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compute_residuals` is never used
[INFO] [stdout]   --> src/math.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn compute_residuals(y: &[f64], x: &[f64]) -> Option<Vec<f64>> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AugmentedDicketFuller` is never constructed
[INFO] [stdout]   --> src/math.rs:57:12
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub struct AugmentedDicketFuller {}
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `generate_variables`, `ols_beta`, and `statistic` are never used
[INFO] [stdout]    --> src/math.rs:62:8
[INFO] [stdout]     |
[INFO] [stdout]  59 | impl AugmentedDicketFuller {
[INFO] [stdout]     | -------------------------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  62 |     fn generate_variables(y: &[f64], max_lags: usize) -> (Vec<Vec<f64>>, Vec<f64>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     fn ols_beta(x: &DMatrix<f64>, y: &DVector<f64>) -> Option<(DVector<f64>, f64)> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn statistic(y: &[f64], max_lags: usize) -> Option<f64> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `e`, `E`, and `s` are never read
[INFO] [stdout]   --> src/models.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 92 | pub struct KlineEvent {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 93 |     e: String, //Event type
[INFO] [stdout]    |     ^
[INFO] [stdout] 94 |     E: u64,    //Event time
[INFO] [stdout]    |     ^
[INFO] [stdout] 95 |     s: String, //Symbol
[INFO] [stdout]    |     ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `KlineEvent` 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: multiple fields are never read
[INFO] [stdout]    --> src/models.rs:102:5
[INFO] [stdout]     |
[INFO] [stdout] 101 | pub struct Kline {
[INFO] [stdout]     |            ----- fields in this struct
[INFO] [stdout] 102 |     t: i64,    // Kline start time
[INFO] [stdout]     |     ^
[INFO] [stdout] 103 |     T: i64,    // Kline close time
[INFO] [stdout]     |     ^
[INFO] [stdout] 104 |     s: String, // Symbol
[INFO] [stdout]     |     ^
[INFO] [stdout] 105 |     i: String, // Interval (e.g. "1m")
[INFO] [stdout]     |     ^
[INFO] [stdout] 106 |     f: i64,    // First trade ID
[INFO] [stdout]     |     ^
[INFO] [stdout] 107 |     L: i64,    // Last trade ID
[INFO] [stdout]     |     ^
[INFO] [stdout] 108 |     o: String, // Open price
[INFO] [stdout]     |     ^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     h: String, // High price
[INFO] [stdout]     |     ^
[INFO] [stdout] 112 |     l: String, // Low price
[INFO] [stdout]     |     ^
[INFO] [stdout] 113 |     v: String, // Volume (base asset)
[INFO] [stdout]     |     ^
[INFO] [stdout] 114 |     n: u64,    // Number of trades
[INFO] [stdout]     |     ^
[INFO] [stdout] 115 |     x: bool,   // Is this kline closed?
[INFO] [stdout]     |     ^
[INFO] [stdout] 116 |     q: String, // Quote asset volume
[INFO] [stdout]     |     ^
[INFO] [stdout] 117 |     V: String, // Taker buy base asset volume
[INFO] [stdout]     |     ^
[INFO] [stdout] 118 |     Q: String, // Taker buy quote asset volume
[INFO] [stdout]     |     ^
[INFO] [stdout] 119 |     B: String, // Unused, can be ignored
[INFO] [stdout]     |     ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Kline` 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: variant `Short` is never constructed
[INFO] [stdout]   --> src/strategy/decision.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub enum PositionDirection {
[INFO] [stdout]    |          ----------------- variant in this enum
[INFO] [stdout] 30 |     Long,
[INFO] [stdout] 31 |     Short,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PositionDirection` 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: struct `SimpleStrategy` is never constructed
[INFO] [stdout]  --> src/strategy/simple.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct SimpleStrategy {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `temp_stream` is never used
[INFO] [stdout]   --> src/main.rs:45:4
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn temp_stream() -> Result<(), Error> {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `BASE_END_POINT` is never used
[INFO] [stdout]   --> src/binance/stream.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | static BASE_END_POINT: &str = "wss://stream.binance.com:9443";
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `KlineInterval` is never used
[INFO] [stdout]   --> src/binance/stream.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum KlineInterval {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `stream_to_channel` is never used
[INFO] [stdout]   --> src/binance/stream.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 81 | pub fn stream_to_channel(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `BASE_END_POINT` is never used
[INFO] [stdout]  --> src/binance/trade_book.rs:3:8
[INFO] [stdout]   |
[INFO] [stdout] 3 | static BASE_END_POINT: &str = "wss://stream.binance.com:9443/ws";
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DiffDepthStream` is never constructed
[INFO] [stdout]  --> src/binance/trade_book.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct DiffDepthStream {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TIMESTAMP_CHANGE_2025_MS` is never used
[INFO] [stdout]  --> src/fs/parse.rs:8:7
[INFO] [stdout]   |
[INFO] [stdout] 8 | const TIMESTAMP_CHANGE_2025_MS: i64 = 1735689600000;
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `micro_seconds_to_datetime` is never used
[INFO] [stdout]   --> src/fs/parse.rs:10:4
[INFO] [stdout]    |
[INFO] [stdout] 10 | fn micro_seconds_to_datetime(t: &i64) -> LocalResult<DateTime<Utc>> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `milli_seconds_to_datetime` is never used
[INFO] [stdout]   --> src/fs/parse.rs:14:4
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn milli_seconds_to_datetime(t: &i64) -> LocalResult<DateTime<Utc>> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `binance_timestamp_to_datetime` is never used
[INFO] [stdout]   --> src/fs/parse.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub fn binance_timestamp_to_datetime(t: &i64) -> Option<DateTime<Utc>> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `to_log_returns` is never used
[INFO] [stdout]   --> src/math.rs:18:8
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub fn to_log_returns(observations: &[f64]) -> Vec<f64> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compute_residuals` is never used
[INFO] [stdout]   --> src/math.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn compute_residuals(y: &[f64], x: &[f64]) -> Option<Vec<f64>> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AugmentedDicketFuller` is never constructed
[INFO] [stdout]   --> src/math.rs:57:12
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub struct AugmentedDicketFuller {}
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `generate_variables`, `ols_beta`, and `statistic` are never used
[INFO] [stdout]    --> src/math.rs:62:8
[INFO] [stdout]     |
[INFO] [stdout]  59 | impl AugmentedDicketFuller {
[INFO] [stdout]     | -------------------------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  62 |     fn generate_variables(y: &[f64], max_lags: usize) -> (Vec<Vec<f64>>, Vec<f64>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     fn ols_beta(x: &DMatrix<f64>, y: &DVector<f64>) -> Option<(DVector<f64>, f64)> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn statistic(y: &[f64], max_lags: usize) -> Option<f64> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `e`, `E`, and `s` are never read
[INFO] [stdout]   --> src/models.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 92 | pub struct KlineEvent {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 93 |     e: String, //Event type
[INFO] [stdout]    |     ^
[INFO] [stdout] 94 |     E: u64,    //Event time
[INFO] [stdout]    |     ^
[INFO] [stdout] 95 |     s: String, //Symbol
[INFO] [stdout]    |     ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `KlineEvent` 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: multiple fields are never read
[INFO] [stdout]    --> src/models.rs:102:5
[INFO] [stdout]     |
[INFO] [stdout] 101 | pub struct Kline {
[INFO] [stdout]     |            ----- fields in this struct
[INFO] [stdout] 102 |     t: i64,    // Kline start time
[INFO] [stdout]     |     ^
[INFO] [stdout] 103 |     T: i64,    // Kline close time
[INFO] [stdout]     |     ^
[INFO] [stdout] 104 |     s: String, // Symbol
[INFO] [stdout]     |     ^
[INFO] [stdout] 105 |     i: String, // Interval (e.g. "1m")
[INFO] [stdout]     |     ^
[INFO] [stdout] 106 |     f: i64,    // First trade ID
[INFO] [stdout]     |     ^
[INFO] [stdout] 107 |     L: i64,    // Last trade ID
[INFO] [stdout]     |     ^
[INFO] [stdout] 108 |     o: String, // Open price
[INFO] [stdout]     |     ^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     h: String, // High price
[INFO] [stdout]     |     ^
[INFO] [stdout] 112 |     l: String, // Low price
[INFO] [stdout]     |     ^
[INFO] [stdout] 113 |     v: String, // Volume (base asset)
[INFO] [stdout]     |     ^
[INFO] [stdout] 114 |     n: u64,    // Number of trades
[INFO] [stdout]     |     ^
[INFO] [stdout] 115 |     x: bool,   // Is this kline closed?
[INFO] [stdout]     |     ^
[INFO] [stdout] 116 |     q: String, // Quote asset volume
[INFO] [stdout]     |     ^
[INFO] [stdout] 117 |     V: String, // Taker buy base asset volume
[INFO] [stdout]     |     ^
[INFO] [stdout] 118 |     Q: String, // Taker buy quote asset volume
[INFO] [stdout]     |     ^
[INFO] [stdout] 119 |     B: String, // Unused, can be ignored
[INFO] [stdout]     |     ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Kline` 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: variant `Short` is never constructed
[INFO] [stdout]   --> src/strategy/decision.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub enum PositionDirection {
[INFO] [stdout]    |          ----------------- variant in this enum
[INFO] [stdout] 30 |     Long,
[INFO] [stdout] 31 |     Short,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PositionDirection` 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: struct `SimpleStrategy` is never constructed
[INFO] [stdout]  --> src/strategy/simple.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct SimpleStrategy {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 33s
[INFO] running `Command { std: "docker" "inspect" "7f6f7147ce48d5cd5816869450fe2233a78c45dd8a6e329590814798799dc562", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7f6f7147ce48d5cd5816869450fe2233a78c45dd8a6e329590814798799dc562", kill_on_drop: false }`
[INFO] [stdout] 7f6f7147ce48d5cd5816869450fe2233a78c45dd8a6e329590814798799dc562
