[INFO] cloning repository https://github.com/samuelbytema/SolanaArbitrageBot
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/samuelbytema/SolanaArbitrageBot" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsamuelbytema%2FSolanaArbitrageBot", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsamuelbytema%2FSolanaArbitrageBot'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 5154881caeb1f3d0e7a8396a9e5aecb9c50bc487
[INFO] checking samuelbytema/SolanaArbitrageBot against try#0bdee9e879c87b7211d316e9152109cfd46c576b for pr-150097
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsamuelbytema%2FSolanaArbitrageBot" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/samuelbytema/SolanaArbitrageBot
[INFO] finished tweaking git repo https://github.com/samuelbytema/SolanaArbitrageBot
[INFO] tweaked toml for git repo https://github.com/samuelbytema/SolanaArbitrageBot written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/samuelbytema/SolanaArbitrageBot on toolchain 0bdee9e879c87b7211d316e9152109cfd46c576b
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0bdee9e879c87b7211d316e9152109cfd46c576b" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/samuelbytema/SolanaArbitrageBot 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" "+0bdee9e879c87b7211d316e9152109cfd46c576b" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0bdee9e879c87b7211d316e9152109cfd46c576b" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 5220cca70a44c5b9ef58e3d12e7c9faf8e82709c42b199bd93655803d387d866
[INFO] running `Command { std: "docker" "start" "-a" "5220cca70a44c5b9ef58e3d12e7c9faf8e82709c42b199bd93655803d387d866", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "5220cca70a44c5b9ef58e3d12e7c9faf8e82709c42b199bd93655803d387d866", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5220cca70a44c5b9ef58e3d12e7c9faf8e82709c42b199bd93655803d387d866", kill_on_drop: false }`
[INFO] [stdout] 5220cca70a44c5b9ef58e3d12e7c9faf8e82709c42b199bd93655803d387d866
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0bdee9e879c87b7211d316e9152109cfd46c576b" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0035e74ba818cf6a91896e8d3bcdb045d1d53a5fc83b04cf28f8fca2570dcf5b
[INFO] running `Command { std: "docker" "start" "-a" "0035e74ba818cf6a91896e8d3bcdb045d1d53a5fc83b04cf28f8fca2570dcf5b", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.103
[INFO] [stderr]    Compiling unicode-ident v1.0.22
[INFO] [stderr]    Compiling quote v1.0.42
[INFO] [stderr]    Compiling libc v0.2.178
[INFO] [stderr]     Checking cfg-if v1.0.4
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]     Checking const-oid v0.9.6
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling toml_datetime v0.7.3
[INFO] [stderr]    Compiling zerocopy v0.8.31
[INFO] [stderr]    Compiling borsh v1.6.0
[INFO] [stderr]     Checking solana-sanitize v3.0.1
[INFO] [stderr]    Compiling semver v1.0.27
[INFO] [stderr]     Checking five8 v1.0.0
[INFO] [stderr]     Checking solana-atomic-u64 v3.0.0
[INFO] [stderr]     Checking five8_const v1.0.0
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]     Checking memchr v2.7.6
[INFO] [stderr]    Compiling find-msvc-tools v0.1.5
[INFO] [stderr]     Checking itoa v1.0.15
[INFO] [stderr]     Checking log v0.4.29
[INFO] [stderr]    Compiling bs58 v0.5.1
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]     Checking pin-project-lite v0.2.16
[INFO] [stderr]     Checking percent-encoding v2.3.2
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]    Compiling pkg-config v0.3.32
[INFO] [stderr]     Checking futures-core v0.3.31
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking solana-program-memory v3.1.0
[INFO] [stderr]     Checking bytes v1.11.0
[INFO] [stderr]     Checking ryu v1.0.20
[INFO] [stderr]    Compiling curve25519-dalek v4.1.3
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]     Checking lock_api v0.4.14
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking keccak v0.1.5
[INFO] [stderr]     Checking futures-sink v0.3.31
[INFO] [stderr]     Checking stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]     Checking derivation-path v0.2.0
[INFO] [stderr]     Checking qstring v0.7.2
[INFO] [stderr]    Compiling indexmap v2.12.1
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]     Checking slab v0.4.11
[INFO] [stderr]     Checking solana-msg v3.0.0
[INFO] [stderr]     Checking opaque-debug v0.3.1
[INFO] [stderr]     Checking solana-define-syscall v4.0.1
[INFO] [stderr]     Checking solana-derivation-path v3.0.0
[INFO] [stderr]    Compiling syn v2.0.111
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]     Checking solana-seed-derivable v3.0.0
[INFO] [stderr]     Checking futures-io v0.3.31
[INFO] [stderr]     Checking futures-task v0.3.31
[INFO] [stderr]     Checking arrayvec v0.7.6
[INFO] [stderr]     Checking equivalent v1.0.2
[INFO] [stderr]     Checking tracing-core v0.1.35
[INFO] [stderr]     Checking solana-program-option v3.0.0
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking mio v1.1.0
[INFO] [stderr]     Checking socket2 v0.6.1
[INFO] [stderr]     Checking signal-hook-registry v1.4.7
[INFO] [stderr]    Compiling toml_parser v1.0.4
[INFO] [stderr]     Checking http v1.4.0
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking itertools v0.12.1
[INFO] [stderr]     Checking writeable v0.6.2
[INFO] [stderr]     Checking litemap v0.8.1
[INFO] [stderr]     Checking aho-corasick v1.1.4
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]     Checking regex-syntax v0.8.8
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]    Compiling icu_normalizer_data v2.1.1
[INFO] [stderr]    Compiling zstd-safe v7.2.4
[INFO] [stderr]    Compiling icu_properties_data v2.1.1
[INFO] [stderr]    Compiling cc v1.2.48
[INFO] [stderr]    Compiling toml_edit v0.23.7
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling crunchy v0.2.4
[INFO] [stderr]     Checking try-lock v0.2.5
[INFO] [stderr]     Checking atomic-waker v1.1.2
[INFO] [stderr]     Checking alloc-no-stdlib v2.0.4
[INFO] [stderr]     Checking tower-service v0.3.3
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]     Checking alloc-stdlib v0.2.2
[INFO] [stderr]     Checking want v0.3.1
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking adler2 v2.0.1
[INFO] [stderr]    Compiling rustls v0.23.35
[INFO] [stderr]     Checking ascii v0.9.3
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]    Compiling crypto-common v0.1.7
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]     Checking simd-adler32 v0.3.7
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]     Checking combine v3.8.1
[INFO] [stderr]     Checking brotli-decompressor v5.0.0
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking ff v0.13.1
[INFO] [stderr]     Checking hash32 v0.3.1
[INFO] [stderr]     Checking base16ct v0.2.0
[INFO] [stderr]     Checking ipnet v2.11.0
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]     Checking openssl-probe v0.1.6
[INFO] [stderr]     Checking rustc-demangle v0.1.26
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking solana-svm-feature-set v3.1.4
[INFO] [stderr]     Checking group v0.13.0
[INFO] [stderr]     Checking sync_wrapper v1.0.2
[INFO] [stderr]     Checking bitflags v2.10.0
[INFO] [stderr]     Checking serde_json v1.0.145
[INFO] [stderr]     Checking serde_bytes v0.11.19
[INFO] [stderr]     Checking solana-short-vec v3.1.0
[INFO] [stderr]     Checking form_urlencoded v1.2.2
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]     Checking encoding_rs v0.8.35
[INFO] [stderr]     Checking tower-layer v0.3.3
[INFO] [stderr]    Compiling ucd-trie v0.1.7
[INFO] [stderr]     Checking compression-core v0.4.31
[INFO] [stderr]     Checking allocator-api2 v0.2.21
[INFO] [stderr]    Compiling const-random-macro v0.1.16
[INFO] [stderr]     Checking getrandom v0.1.16
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]     Checking utf8parse v0.2.2
[INFO] [stderr]     Checking brotli v8.0.2
[INFO] [stderr]    Compiling solana-version v3.1.4
[INFO] [stderr]     Checking flate2 v1.1.5
[INFO] [stderr]     Checking iri-string v0.7.9
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]    Compiling proc-macro-crate v3.4.0
[INFO] [stderr]    Compiling anyhow v1.0.100
[INFO] [stderr]     Checking const-random v0.1.18
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]     Checking anstyle-parse v0.2.7
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]    Compiling pest v2.8.4
[INFO] [stderr]    Compiling blake3 v1.8.2
[INFO] [stderr]    Compiling zstd-sys v2.0.16+zstd.1.5.7
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling memoffset v0.9.1
[INFO] [stderr]     Checking colorchoice v1.0.4
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]     Checking anstyle v1.0.13
[INFO] [stderr]     Checking is_terminal_polyfill v1.70.2
[INFO] [stderr]     Checking anstyle-query v1.1.5
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking anstream v0.6.21
[INFO] [stderr]     Checking dlv-list v0.5.2
[INFO] [stderr]     Checking toml_write v0.1.2
[INFO] [stderr]     Checking unicode-width v0.2.2
[INFO] [stderr]     Checking ordered-multimap v0.7.3
[INFO] [stderr]     Checking hashlink v0.8.4
[INFO] [stderr]     Checking console v0.16.1
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking solana-packet v3.0.0
[INFO] [stderr]     Checking solana-native-token v3.0.0
[INFO] [stderr]    Compiling rust_decimal v1.39.0
[INFO] [stderr]     Checking base64ct v1.8.0
[INFO] [stderr]     Checking base64 v0.21.7
[INFO] [stderr]     Checking arraydeque v0.5.1
[INFO] [stderr]     Checking minimal-lexical v0.2.1
[INFO] [stderr]     Checking unicode-segmentation v1.12.0
[INFO] [stderr]     Checking unit-prefix v0.5.2
[INFO] [stderr]     Checking signature v1.6.4
[INFO] [stderr]     Checking siphasher v0.3.11
[INFO] [stderr]     Checking solana-hard-forks v3.0.0
[INFO] [stderr]     Checking clap_lex v0.7.6
[INFO] [stderr]     Checking ed25519 v1.5.3
[INFO] [stderr]     Checking clap_builder v4.5.53
[INFO] [stderr]     Checking indicatif v0.18.3
[INFO] [stderr]    Compiling pest_meta v2.8.4
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking password-hash v0.5.0
[INFO] [stderr]     Checking yaml-rust2 v0.8.1
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking convert_case v0.6.0
[INFO] [stderr]     Checking rust-ini v0.20.0
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking solana-big-mod-exp v3.0.0
[INFO] [stderr]     Checking sharded-slab v0.1.7
[INFO] [stderr]     Checking thread_local v1.1.9
[INFO] [stderr]     Checking pathdiff v0.2.3
[INFO] [stderr]     Checking nu-ansi-term v0.50.3
[INFO] [stderr]     Checking solana-time-utils v3.0.0
[INFO] [stderr]     Checking jiff v0.2.16
[INFO] [stderr]     Checking iana-time-zone v0.1.64
[INFO] [stderr]     Checking regex v1.12.2
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking uuid v1.19.0
[INFO] [stderr]     Checking hex v0.4.3
[INFO] [stderr]     Checking Inflector v0.11.4
[INFO] [stderr]     Checking env_filter v0.1.4
[INFO] [stderr]     Checking compression-codecs v0.4.33
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]    Compiling pest_generator v2.8.4
[INFO] [stderr]    Compiling zeroize_derive v1.4.2
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling borsh-derive v1.6.0
[INFO] [stderr]    Compiling bytemuck_derive v1.10.2
[INFO] [stderr]    Compiling curve25519-dalek-derive v0.1.1
[INFO] [stderr]    Compiling solana-sdk-macro v3.0.0
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]     Checking zeroize v1.8.2
[INFO] [stderr]     Checking tokio v1.48.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling num_enum_derive v0.7.5
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]     Checking merlin v3.0.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]     Checking bytemuck v1.24.0
[INFO] [stderr]     Checking thiserror v2.0.17
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking inout v0.1.4
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]     Checking universal-hash v0.5.1
[INFO] [stderr]     Checking yoke v0.8.1
[INFO] [stderr]     Checking aead v0.5.2
[INFO] [stderr]     Checking cipher v0.4.4
[INFO] [stderr]     Checking polyval v0.6.2
[INFO] [stderr]     Checking aes v0.8.4
[INFO] [stderr]     Checking ctr v0.9.2
[INFO] [stderr]     Checking signature v2.2.0
[INFO] [stderr]     Checking hmac v0.12.1
[INFO] [stderr]     Checking sha3 v0.10.8
[INFO] [stderr]     Checking pbkdf2 v0.11.0
[INFO] [stderr]     Checking zerovec v0.11.5
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking zerotrie v0.2.3
[INFO] [stderr]    Compiling spl-discriminator-syn v0.2.1
[INFO] [stderr]     Checking rustls-pki-types v1.13.1
[INFO] [stderr]     Checking der v0.7.10
[INFO] [stderr]     Checking ed25519 v2.2.3
[INFO] [stderr]     Checking aes-gcm-siv v0.11.1
[INFO] [stderr]     Checking solana-seed-phrase v3.0.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]     Checking tinystr v0.8.2
[INFO] [stderr]     Checking potential_utf v0.1.4
[INFO] [stderr]     Checking solana-sbpf v0.13.1
[INFO] [stderr]     Checking zstd v0.13.3
[INFO] [stderr]    Compiling spl-discriminator-derive v0.2.0
[INFO] [stderr]     Checking num_enum v0.7.5
[INFO] [stderr]     Checking crypto-bigint v0.5.5
[INFO] [stderr]     Checking icu_collections v2.1.1
[INFO] [stderr]     Checking rfc6979 v0.4.0
[INFO] [stderr]     Checking rustls-webpki v0.103.8
[INFO] [stderr]     Checking icu_locale_core v2.1.1
[INFO] [stderr]     Checking webpki-roots v1.0.4
[INFO] [stderr]    Compiling cfg_eval v0.1.2
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]     Checking digest v0.9.0
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]     Checking block-buffer v0.9.0
[INFO] [stderr]    Compiling pest_derive v2.8.4
[INFO] [stderr]     Checking spki v0.7.3
[INFO] [stderr]     Checking sec1 v0.7.3
[INFO] [stderr]     Checking sha2 v0.9.9
[INFO] [stderr]     Checking curve25519-dalek v3.2.0
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]     Checking tracing v0.1.43
[INFO] [stderr]    Compiling serde_with_macros v3.16.1
[INFO] [stderr]     Checking solana-borsh v3.0.0
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]     Checking tracing-subscriber v0.3.22
[INFO] [stderr]     Checking pkcs8 v0.10.2
[INFO] [stderr]     Checking pbkdf2 v0.12.2
[INFO] [stderr]     Checking env_logger v0.11.8
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking icu_properties v2.1.1
[INFO] [stderr]     Checking elliptic-curve v0.13.8
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking ecdsa v0.16.9
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking k256 v0.13.4
[INFO] [stderr]     Checking serde_with v3.16.1
[INFO] [stderr]     Checking solana-hash v4.0.1
[INFO] [stderr]     Checking solana-program-error v3.0.0
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking serde-big-array v0.5.1
[INFO] [stderr]     Checking solana-fee-calculator v3.0.0
[INFO] [stderr]     Checking bv v0.11.1
[INFO] [stderr]     Checking solana-serde-varint v3.0.0
[INFO] [stderr]     Checking solana-commitment-config v3.1.0
[INFO] [stderr]     Checking solana-reward-info v3.0.0
[INFO] [stderr]     Checking solana-inflation v3.0.0
[INFO] [stderr]     Checking solana-sha256-hasher v3.1.0
[INFO] [stderr]     Checking solana-hash v3.1.0
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking solana-keccak-hasher v3.1.0
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]     Checking solana-blake3-hasher v3.1.0
[INFO] [stderr]     Checking solana-instruction-error v2.1.0
[INFO] [stderr]     Checking solana-program-pack v3.0.0
[INFO] [stderr]     Checking spl-discriminator v0.5.1
[INFO] [stderr]     Checking jsonrpc-core v18.0.0
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]     Checking solana-epoch-info v3.1.0
[INFO] [stderr]     Checking solana-transaction-error v3.0.0
[INFO] [stderr]     Checking solana-shred-version v3.0.0
[INFO] [stderr]     Checking json5 v0.4.1
[INFO] [stderr]     Checking solana-secp256k1-recover v3.1.0
[INFO] [stderr]     Checking solana-fee-structure v3.0.0
[INFO] [stderr]     Checking ron v0.8.1
[INFO] [stderr]     Checking solana-serde v3.0.0
[INFO] [stderr]     Checking chrono v0.4.42
[INFO] [stderr]     Checking ed25519-dalek v1.0.1
[INFO] [stderr]     Checking async-stream v0.3.6
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking clap v4.5.53
[INFO] [stderr]     Checking url v2.5.7
[INFO] [stderr]     Checking solana-address v2.0.0
[INFO] [stderr]     Checking ed25519-dalek v2.2.0
[INFO] [stderr]     Checking solana-curve25519 v3.1.4
[INFO] [stderr]     Checking solana-address v1.1.0
[INFO] [stderr]     Checking solana-sdk-ids v3.1.0
[INFO] [stderr]     Checking solana-pubkey v4.0.0
[INFO] [stderr]     Checking solana-account-info v3.1.0
[INFO] [stderr]     Checking solana-epoch-rewards-hasher v3.1.0
[INFO] [stderr]     Checking solana-signature v3.1.0
[INFO] [stderr]     Checking ed25519-dalek-bip32 v0.3.0
[INFO] [stderr]     Checking solana-pubkey v3.0.0
[INFO] [stderr]     Checking solana-sysvar-id v3.1.0
[INFO] [stderr]     Checking solana-instruction v3.1.0
[INFO] [stderr]     Checking tokio-util v0.7.17
[INFO] [stderr]     Checking tokio-rustls v0.26.4
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking async-compression v0.4.34
[INFO] [stderr]     Checking tokio-stream v0.1.17
[INFO] [stderr]     Checking solana-program-entrypoint v3.1.1
[INFO] [stderr]     Checking solana-serialize-utils v3.1.0
[INFO] [stderr]     Checking solana-signer v3.0.0
[INFO] [stderr]     Checking solana-nonce v3.0.0
[INFO] [stderr]     Checking spl-generic-token v2.0.1
[INFO] [stderr]     Checking solana-epoch-schedule v3.0.0
[INFO] [stderr]     Checking solana-clock v3.0.0
[INFO] [stderr]     Checking solana-slot-hashes v3.0.0
[INFO] [stderr]     Checking solana-rent v3.0.0
[INFO] [stderr]     Checking solana-slot-history v3.0.0
[INFO] [stderr]     Checking solana-last-restart-slot v3.0.0
[INFO] [stderr]     Checking solana-epoch-rewards v3.0.0
[INFO] [stderr]     Checking solana-instructions-sysvar v3.0.0
[INFO] [stderr]     Checking solana-system-interface v2.0.0
[INFO] [stderr]     Checking solana-zk-sdk v4.0.0
[INFO] [stderr]     Checking solana-message v3.0.1
[INFO] [stderr]     Checking solana-cpi v3.1.0
[INFO] [stderr]     Checking agave-feature-set v3.1.4
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking spl-token-interface v2.0.0
[INFO] [stderr]     Checking solana-stable-layout v3.0.0
[INFO] [stderr]     Checking solana-address-lookup-table-interface v3.0.0
[INFO] [stderr]     Checking solana-sysvar v3.1.1
[INFO] [stderr]     Checking solana-epoch-stake v3.0.0
[INFO] [stderr]     Checking h2 v0.4.12
[INFO] [stderr]     Checking spl-associated-token-account-interface v2.0.0
[INFO] [stderr]     Checking spl-memo-interface v2.0.0
[INFO] [stderr]     Checking solana-loader-v2-interface v3.0.0
[INFO] [stderr]     Checking solana-keypair v3.1.0
[INFO] [stderr]     Checking solana-presigner v3.0.0
[INFO] [stderr]     Checking solana-offchain-message v3.0.0
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking solana-feature-gate-interface v3.0.0
[INFO] [stderr]     Checking solana-account v3.2.0
[INFO] [stderr]     Checking tokio-test v0.4.4
[INFO] [stderr]     Checking tower-http v0.6.7
[INFO] [stderr]     Checking solana-loader-v3-interface v6.1.0
[INFO] [stderr]     Checking solana-stake-interface v2.0.2
[INFO] [stderr]     Checking solana-vote-interface v4.0.4
[INFO] [stderr]     Checking config v0.14.1
[INFO] [stderr]     Checking solana-account-decoder-client-types v3.1.4
[INFO] [stderr]     Checking solana-transaction-context v3.1.4
[INFO] [stderr]     Checking solana-config-interface v2.0.0
[INFO] [stderr]     Checking agave-reserved-account-keys v3.1.4
[INFO] [stderr]     Checking solana-transaction v3.0.2
[INFO] [stderr]     Checking solana-example-mocks v3.0.0
[INFO] [stderr]     Checking solana-program v3.0.0
[INFO] [stderr]     Checking solana-sdk v3.0.0
[INFO] [stderr]     Checking spl-pod v0.7.1
[INFO] [stderr]     Checking spl-token-confidential-transfer-proof-generation v0.5.1
[INFO] [stderr]     Checking solana-transaction-status-client-types v3.1.4
[INFO] [stderr]     Checking spl-type-length-value v0.9.0
[INFO] [stderr]     Checking spl-token-confidential-transfer-proof-extraction v0.5.1
[INFO] [stderr]     Checking spl-token-group-interface v0.7.1
[INFO] [stderr]     Checking spl-token-metadata-interface v0.8.0
[INFO] [stderr]     Checking spl-token-2022-interface v2.1.0
[INFO] [stderr]     Checking hyper v1.8.1
[INFO] [stderr]     Checking solana-rpc-client-types v3.1.4
[INFO] [stderr]     Checking hyper-util v0.1.19
[INFO] [stderr]     Checking solana-account-decoder v3.1.4
[INFO] [stderr]     Checking hyper-rustls v0.27.7
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking solana-transaction-status v3.1.4
[INFO] [stderr]     Checking reqwest v0.12.24
[INFO] [stderr]     Checking reqwest-middleware v0.4.2
[INFO] [stderr]     Checking solana-rpc-client-api v3.1.4
[INFO] [stderr]     Checking solana-rpc-client v3.1.4
[INFO] [stderr]     Checking offchain-bot v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/config/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::time::Duration;
[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 imports: `Config`, `Environment`, and `File`
[INFO] [stdout]  --> src/config/mod.rs:4:14
[INFO] [stdout]   |
[INFO] [stdout] 4 | use config::{Config, Environment, File};
[INFO] [stdout]   |              ^^^^^^  ^^^^^^^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/models/pool.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `solana_program::pubkey::Pubkey`
[INFO] [stdout]  --> src/models/arbitrage.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use solana_program::pubkey::Pubkey;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `transaction::Transaction`
[INFO] [stdout]  --> src/models/transaction.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 |     transaction::Transaction,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: ambiguous glob re-exports
[INFO] [stdout]  --> src/models/mod.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub use token::*;
[INFO] [stdout]   |         ^^^^^^^^ the name `TokenBalance` in the type namespace is first re-exported here
[INFO] [stdout] ...
[INFO] [stdout] 9 | pub use transaction::*;
[INFO] [stdout]   |         -------------- but the name `TokenBalance` in the type namespace is also re-exported here
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(ambiguous_glob_reexports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/raydium.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/dex/raydium.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/raydium.rs:11:86
[INFO] [stdout]    |
[INFO] [stdout] 11 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/meteora.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/meteora.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/whirlpool.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/whirlpool.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/pump.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/pump.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Pool`, `StorageUsage`, and `Token`
[INFO] [stdout]   --> src/arbitrage/engine.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 |         ArbitrageMetrics, Token, Pool, RiskScore, ExecutionStatus
[INFO] [stdout]    |                           ^^^^^  ^^^^
[INFO] [stdout] 15 |     },
[INFO] [stdout] 16 |     services::{database::DatabaseService, memory_store::{MemoryStore, StorageUsage}},
[INFO] [stdout]    |                                                                       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/services/database.rs:4:14
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `pubkey::Pubkey`
[INFO] [stdout]  --> src/services/jito.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     pubkey::Pubkey,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `uuid::Uuid`
[INFO] [stdout]  --> src/services/memory_store.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use uuid::Uuid;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::Ordering`
[INFO] [stdout]  --> src/utils/math.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::cmp::Ordering;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Block`
[INFO] [stdout]  --> src/utils/crypto.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 | use aes::{Aes256, Block};
[INFO] [stdout]   |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Pbkdf2`
[INFO] [stdout]    --> src/utils/crypto.rs:106:30
[INFO] [stdout]     |
[INFO] [stdout] 106 |         use pbkdf2::{pbkdf2, Pbkdf2};
[INFO] [stdout]     |                              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Pbkdf2`
[INFO] [stdout]    --> src/utils/crypto.rs:242:30
[INFO] [stdout]     |
[INFO] [stdout] 242 |         use pbkdf2::{pbkdf2, Pbkdf2};
[INFO] [stdout]     |                              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Ipv6Addr`
[INFO] [stdout]  --> src/utils/network.rs:1:34
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::{IpAddr, Ipv4Addr, Ipv6Addr, SocketAddr};
[INFO] [stdout]   |                                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/config/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::time::Duration;
[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 imports: `Config`, `Environment`, and `File`
[INFO] [stdout]  --> src/config/mod.rs:4:14
[INFO] [stdout]   |
[INFO] [stdout] 4 | use config::{Config, Environment, File};
[INFO] [stdout]   |              ^^^^^^  ^^^^^^^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/models/pool.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `solana_program::pubkey::Pubkey`
[INFO] [stdout]  --> src/models/arbitrage.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use solana_program::pubkey::Pubkey;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `transaction::Transaction`
[INFO] [stdout]  --> src/models/transaction.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 |     transaction::Transaction,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: ambiguous glob re-exports
[INFO] [stdout]  --> src/models/mod.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub use token::*;
[INFO] [stdout]   |         ^^^^^^^^ the name `TokenBalance` in the type namespace is first re-exported here
[INFO] [stdout] ...
[INFO] [stdout] 9 | pub use transaction::*;
[INFO] [stdout]   |         -------------- but the name `TokenBalance` in the type namespace is also re-exported here
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(ambiguous_glob_reexports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/raydium.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/dex/raydium.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/raydium.rs:11:86
[INFO] [stdout]    |
[INFO] [stdout] 11 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/meteora.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/meteora.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/whirlpool.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/whirlpool.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/dex/pump.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PoolUpdate`
[INFO] [stdout]   --> src/dex/pump.rs:10:86
[INFO] [stdout]    |
[INFO] [stdout] 10 |     dex::{DexInterface, DexError, DexMetrics, DexConnectionConfig, PoolUpdateStream, PoolUpdate, DexType},
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Pool`, `StorageUsage`, and `Token`
[INFO] [stdout]   --> src/arbitrage/engine.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 |         ArbitrageMetrics, Token, Pool, RiskScore, ExecutionStatus
[INFO] [stdout]    |                           ^^^^^  ^^^^
[INFO] [stdout] 15 |     },
[INFO] [stdout] 16 |     services::{database::DatabaseService, memory_store::{MemoryStore, StorageUsage}},
[INFO] [stdout]    |                                                                       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/services/database.rs:4:14
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `pubkey::Pubkey`
[INFO] [stdout]  --> src/services/jito.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 |     pubkey::Pubkey,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `uuid::Uuid`
[INFO] [stdout]  --> src/services/memory_store.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use uuid::Uuid;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::Ordering`
[INFO] [stdout]  --> src/utils/math.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::cmp::Ordering;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Block`
[INFO] [stdout]  --> src/utils/crypto.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 | use aes::{Aes256, Block};
[INFO] [stdout]   |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Pbkdf2`
[INFO] [stdout]    --> src/utils/crypto.rs:106:30
[INFO] [stdout]     |
[INFO] [stdout] 106 |         use pbkdf2::{pbkdf2, Pbkdf2};
[INFO] [stdout]     |                              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Pbkdf2`
[INFO] [stdout]    --> src/utils/crypto.rs:242:30
[INFO] [stdout]     |
[INFO] [stdout] 242 |         use pbkdf2::{pbkdf2, Pbkdf2};
[INFO] [stdout]     |                              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Ipv6Addr`
[INFO] [stdout]  --> src/utils/network.rs:1:34
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::{IpAddr, Ipv4Addr, Ipv6Addr, SocketAddr};
[INFO] [stdout]   |                                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]   --> src/services/jito.rs:92:40
[INFO] [stdout]    |
[INFO] [stdout] 92 |         let transaction_data = base64::encode(&bincode::serialize(transaction)?);
[INFO] [stdout]    |                                        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]   --> src/services/jito.rs:92:40
[INFO] [stdout]    |
[INFO] [stdout] 92 |         let transaction_data = base64::encode(&bincode::serialize(transaction)?);
[INFO] [stdout]    |                                        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:225:38
[INFO] [stdout]     |
[INFO] [stdout] 225 |         let mut current = start_time.date();
[INFO] [stdout]     |                                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:226:28
[INFO] [stdout]     |
[INFO] [stdout] 226 |         let end = end_time.date();
[INFO] [stdout]     |                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:229:46
[INFO] [stdout]     |
[INFO] [stdout] 229 |             if Self::is_business_day(current.and_hms(0, 0, 0)) {
[INFO] [stdout]     |                                              ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::succ`: Use succ_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:232:31
[INFO] [stdout]     |
[INFO] [stdout] 232 |             current = current.succ();
[INFO] [stdout]     |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:244:38
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut current = start_time.date();
[INFO] [stdout]     |                                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:245:28
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let end = end_time.date();
[INFO] [stdout]     |                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:248:46
[INFO] [stdout]     |
[INFO] [stdout] 248 |             if Self::is_business_day(current.and_hms(0, 0, 0)) {
[INFO] [stdout]     |                                              ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:249:44
[INFO] [stdout]     |
[INFO] [stdout] 249 |                 business_days.push(current.and_hms(9, 0, 0)); // 9:00 AM
[INFO] [stdout]     |                                            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::succ`: Use succ_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:251:31
[INFO] [stdout]     |
[INFO] [stdout] 251 |             current = current.succ();
[INFO] [stdout]     |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:314:18
[INFO] [stdout]     |
[INFO] [stdout] 314 |         if start.date() == end.date() {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:314:32
[INFO] [stdout]     |
[INFO] [stdout] 314 |         if start.date() == end.date() {
[INFO] [stdout]     |                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output_amount`
[INFO] [stdout]    --> src/dex/interface.rs:192:13
[INFO] [stdout]     |
[INFO] [stdout] 192 |         let output_amount = numerator / denominator;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_output_amount`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `input_amount`
[INFO] [stdout]    --> src/dex/interface.rs:217:9
[INFO] [stdout]     |
[INFO] [stdout] 217 |         input_amount: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_input_amount`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:225:38
[INFO] [stdout]     |
[INFO] [stdout] 225 |         let mut current = start_time.date();
[INFO] [stdout]     |                                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:226:28
[INFO] [stdout]     |
[INFO] [stdout] 226 |         let end = end_time.date();
[INFO] [stdout]     |                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:229:46
[INFO] [stdout]     |
[INFO] [stdout] 229 |             if Self::is_business_day(current.and_hms(0, 0, 0)) {
[INFO] [stdout]     |                                              ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::succ`: Use succ_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:232:31
[INFO] [stdout]     |
[INFO] [stdout] 232 |             current = current.succ();
[INFO] [stdout]     |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:244:38
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut current = start_time.date();
[INFO] [stdout]     |                                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:245:28
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let end = end_time.date();
[INFO] [stdout]     |                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:248:46
[INFO] [stdout]     |
[INFO] [stdout] 248 |             if Self::is_business_day(current.and_hms(0, 0, 0)) {
[INFO] [stdout]     |                                              ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:249:44
[INFO] [stdout]     |
[INFO] [stdout] 249 |                 business_days.push(current.and_hms(9, 0, 0)); // 9:00 AM
[INFO] [stdout]     |                                            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::succ`: Use succ_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:251:31
[INFO] [stdout]     |
[INFO] [stdout] 251 |             current = current.succ();
[INFO] [stdout]     |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:314:18
[INFO] [stdout]     |
[INFO] [stdout] 314 |         if start.date() == end.date() {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/utils/time.rs:314:32
[INFO] [stdout]     |
[INFO] [stdout] 314 |         if start.date() == end.date() {
[INFO] [stdout]     |                                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]    --> src/utils/time.rs:364:26
[INFO] [stdout]     |
[INFO] [stdout] 364 |         let monday = Utc.ymd(2024, 1, 1).and_hms(10, 0, 0); // Monday
[INFO] [stdout]     |                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:364:42
[INFO] [stdout]     |
[INFO] [stdout] 364 |         let monday = Utc.ymd(2024, 1, 1).and_hms(10, 0, 0); // Monday
[INFO] [stdout]     |                                          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]    --> src/utils/time.rs:365:28
[INFO] [stdout]     |
[INFO] [stdout] 365 |         let saturday = Utc.ymd(2024, 1, 6).and_hms(10, 0, 0); // Saturday
[INFO] [stdout]     |                            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/utils/time.rs:365:44
[INFO] [stdout]     |
[INFO] [stdout] 365 |         let saturday = Utc.ymd(2024, 1, 6).and_hms(10, 0, 0); // Saturday
[INFO] [stdout]     |                                            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/raydium.rs:245:9
[INFO] [stdout]     |
[INFO] [stdout] 245 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/raydium.rs:243:9
[INFO] [stdout]     |
[INFO] [stdout] 243 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/raydium.rs:299:42
[INFO] [stdout]     |
[INFO] [stdout] 299 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output_amount`
[INFO] [stdout]    --> src/dex/interface.rs:192:13
[INFO] [stdout]     |
[INFO] [stdout] 192 |         let output_amount = numerator / denominator;
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_output_amount`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `input_amount`
[INFO] [stdout]    --> src/dex/interface.rs:217:9
[INFO] [stdout]     |
[INFO] [stdout] 217 |         input_amount: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_input_amount`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/meteora.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/meteora.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/meteora.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/raydium.rs:245:9
[INFO] [stdout]     |
[INFO] [stdout] 245 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/raydium.rs:243:9
[INFO] [stdout]     |
[INFO] [stdout] 243 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/raydium.rs:299:42
[INFO] [stdout]     |
[INFO] [stdout] 299 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/whirlpool.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/whirlpool.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/whirlpool.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/meteora.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/meteora.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/meteora.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/pump.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/pump.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/pump.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token_b`
[INFO] [stdout]    --> src/arbitrage/scanner.rs:163:9
[INFO] [stdout]     |
[INFO] [stdout] 163 |         token_b: &Token,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `opportunity`
[INFO] [stdout]    --> src/arbitrage/executor.rs:247:34
[INFO] [stdout]     |
[INFO] [stdout] 247 |     pub fn should_execute(&self, opportunity: &ArbitrageOpportunity) -> bool {
[INFO] [stdout]     |                                  ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_opportunity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_profit`
[INFO] [stdout]    --> src/arbitrage/executor.rs:251:43
[INFO] [stdout]     |
[INFO] [stdout] 251 |             ExecutionCondition::MinProfit(min_profit) => {
[INFO] [stdout]     |                                           ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_min_profit`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `risk_score`
[INFO] [stdout]    --> src/arbitrage/executor.rs:257:41
[INFO] [stdout]     |
[INFO] [stdout] 257 |             ExecutionCondition::MaxRisk(risk_score) => {
[INFO] [stdout]     |                                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_risk_score`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `status`
[INFO] [stdout]   --> src/services/solana.rs:57:13
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let status = self.rpc_client.get_transaction(signature, UiTransactionEncoding::Json)?;
[INFO] [stdout]    |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_status`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction`
[INFO] [stdout]    --> src/services/solana.rs:304:44
[INFO] [stdout]     |
[INFO] [stdout] 304 |     pub async fn verify_transaction(&self, transaction: &Transaction) -> Result<bool> {
[INFO] [stdout]     |                                            ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/whirlpool.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/whirlpool.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `host`
[INFO] [stdout]    --> src/utils/network.rs:377:9
[INFO] [stdout]     |
[INFO] [stdout] 377 |         host: &str,
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_host`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `StoreMetrics` is more private than the item `MemoryStore::get_metrics`
[INFO] [stdout]    --> src/services/memory_store.rs:228:5
[INFO] [stdout]     |
[INFO] [stdout] 228 |     pub async fn get_metrics(&self) -> StoreMetrics {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `MemoryStore::get_metrics` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `StoreMetrics` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/services/memory_store.rs:33:1
[INFO] [stdout]     |
[INFO] [stdout]  33 | struct StoreMetrics {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `base_price`, `quote_price`, and `volume_7d` are never read
[INFO] [stdout]   --> src/dex/raydium.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | struct RaydiumPool {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 30 |     base_price: String,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 31 |     quote_price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 32 |     volume_24h: String,
[INFO] [stdout] 33 |     volume_7d: String,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RaydiumPool` has a derived impl for the trait `Debug`, but this is 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: struct `RaydiumQuote` is never constructed
[INFO] [stdout]   --> src/dex/raydium.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | struct RaydiumQuote {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `validate_opportunity` and `calculate_optimal_amount` are never used
[INFO] [stdout]    --> src/arbitrage/scanner.rs:206:8
[INFO] [stdout]     |
[INFO] [stdout]  22 | impl OpportunityScanner {
[INFO] [stdout]     | ----------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 206 |     fn validate_opportunity(&self, opportunity: &ArbitrageOpportunity) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 231 |     fn calculate_optimal_amount(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `dex_instances` and `config` are never read
[INFO] [stdout]   --> src/arbitrage/executor.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct ArbitrageExecutor {
[INFO] [stdout]    |            ----------------- fields in this struct
[INFO] [stdout] 23 |     dex_instances: Arc<HashMap<DexType, Box<dyn DexInterface>>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 24 |     execution_sender: mpsc::Sender<ArbitrageExecution>,
[INFO] [stdout] 25 |     config: AppConfig,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `check_execution_status` is never used
[INFO] [stdout]    --> src/arbitrage/executor.rs:137:14
[INFO] [stdout]     |
[INFO] [stdout]  30 | impl ArbitrageExecutor {
[INFO] [stdout]     | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 137 |     async fn check_execution_status(&self, execution: &mut ArbitrageExecution) -> Result<()> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/whirlpool.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/utils/crypto.rs:110:9
[INFO] [stdout]     |
[INFO] [stdout] 110 |         pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, 10000, &mut hash);
[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] 110 |         let _ = pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, 10000, &mut hash);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/utils/crypto.rs:246:9
[INFO] [stdout]     |
[INFO] [stdout] 246 |         pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, iterations, &mut key);
[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] 246 |         let _ = pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, iterations, &mut key);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]    --> src/utils/network.rs:107:21
[INFO] [stdout]     |
[INFO] [stdout] 107 |         port > 0 && port <= 65535
[INFO] [stdout]     |                     ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slippage_tolerance`
[INFO] [stdout]    --> src/dex/pump.rs:230:9
[INFO] [stdout]     |
[INFO] [stdout] 230 |         slippage_tolerance: Decimal,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_slippage_tolerance`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `quote`
[INFO] [stdout]    --> src/dex/pump.rs:228:9
[INFO] [stdout]     |
[INFO] [stdout] 228 |         quote: &PoolQuote,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_quote`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction_data`
[INFO] [stdout]    --> src/dex/pump.rs:278:42
[INFO] [stdout]     |
[INFO] [stdout] 278 |     async fn validate_transaction(&self, transaction_data: &[u8]) -> Result<bool> {
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `token_b`
[INFO] [stdout]    --> src/arbitrage/scanner.rs:163:9
[INFO] [stdout]     |
[INFO] [stdout] 163 |         token_b: &Token,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `opportunity`
[INFO] [stdout]    --> src/arbitrage/executor.rs:247:34
[INFO] [stdout]     |
[INFO] [stdout] 247 |     pub fn should_execute(&self, opportunity: &ArbitrageOpportunity) -> bool {
[INFO] [stdout]     |                                  ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_opportunity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_profit`
[INFO] [stdout]    --> src/arbitrage/executor.rs:251:43
[INFO] [stdout]     |
[INFO] [stdout] 251 |             ExecutionCondition::MinProfit(min_profit) => {
[INFO] [stdout]     |                                           ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_min_profit`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `risk_score`
[INFO] [stdout]    --> src/arbitrage/executor.rs:257:41
[INFO] [stdout]     |
[INFO] [stdout] 257 |             ExecutionCondition::MaxRisk(risk_score) => {
[INFO] [stdout]     |                                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_risk_score`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `status`
[INFO] [stdout]   --> src/services/solana.rs:57:13
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let status = self.rpc_client.get_transaction(signature, UiTransactionEncoding::Json)?;
[INFO] [stdout]    |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_status`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transaction`
[INFO] [stdout]    --> src/services/solana.rs:304:44
[INFO] [stdout]     |
[INFO] [stdout] 304 |     pub async fn verify_transaction(&self, transaction: &Transaction) -> Result<bool> {
[INFO] [stdout]     |                                            ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transaction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `host`
[INFO] [stdout]    --> src/utils/network.rs:377:9
[INFO] [stdout]     |
[INFO] [stdout] 377 |         host: &str,
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_host`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `StoreMetrics` is more private than the item `memory_store::MemoryStore::get_metrics`
[INFO] [stdout]    --> src/services/memory_store.rs:228:5
[INFO] [stdout]     |
[INFO] [stdout] 228 |     pub async fn get_metrics(&self) -> StoreMetrics {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `memory_store::MemoryStore::get_metrics` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `StoreMetrics` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/services/memory_store.rs:33:1
[INFO] [stdout]     |
[INFO] [stdout]  33 | struct StoreMetrics {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `base_price`, `quote_price`, and `volume_7d` are never read
[INFO] [stdout]   --> src/dex/raydium.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | struct RaydiumPool {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 30 |     base_price: String,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 31 |     quote_price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 32 |     volume_24h: String,
[INFO] [stdout] 33 |     volume_7d: String,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RaydiumPool` has a derived impl for the trait `Debug`, but this is 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: struct `RaydiumQuote` is never constructed
[INFO] [stdout]   --> src/dex/raydium.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | struct RaydiumQuote {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `validate_opportunity` and `calculate_optimal_amount` are never used
[INFO] [stdout]    --> src/arbitrage/scanner.rs:206:8
[INFO] [stdout]     |
[INFO] [stdout]  22 | impl OpportunityScanner {
[INFO] [stdout]     | ----------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 206 |     fn validate_opportunity(&self, opportunity: &ArbitrageOpportunity) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 231 |     fn calculate_optimal_amount(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `dex_instances` and `config` are never read
[INFO] [stdout]   --> src/arbitrage/executor.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct ArbitrageExecutor {
[INFO] [stdout]    |            ----------------- fields in this struct
[INFO] [stdout] 23 |     dex_instances: Arc<HashMap<DexType, Box<dyn DexInterface>>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 24 |     execution_sender: mpsc::Sender<ArbitrageExecution>,
[INFO] [stdout] 25 |     config: AppConfig,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `check_execution_status` is never used
[INFO] [stdout]    --> src/arbitrage/executor.rs:137:14
[INFO] [stdout]     |
[INFO] [stdout]  30 | impl ArbitrageExecutor {
[INFO] [stdout]     | ---------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 137 |     async fn check_execution_status(&self, execution: &mut ArbitrageExecution) -> Result<()> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/utils/crypto.rs:110:9
[INFO] [stdout]     |
[INFO] [stdout] 110 |         pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, 10000, &mut hash);
[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] 110 |         let _ = pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, 10000, &mut hash);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/utils/crypto.rs:246:9
[INFO] [stdout]     |
[INFO] [stdout] 246 |         pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, iterations, &mut key);
[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] 246 |         let _ = pbkdf2::<Hmac<Sha256>>(password.as_bytes(), salt, iterations, &mut key);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]    --> src/utils/network.rs:107:21
[INFO] [stdout]     |
[INFO] [stdout] 107 |         port > 0 && port <= 65535
[INFO] [stdout]     |                     ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 19s
[INFO] running `Command { std: "docker" "inspect" "0035e74ba818cf6a91896e8d3bcdb045d1d53a5fc83b04cf28f8fca2570dcf5b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0035e74ba818cf6a91896e8d3bcdb045d1d53a5fc83b04cf28f8fca2570dcf5b", kill_on_drop: false }`
[INFO] [stdout] 0035e74ba818cf6a91896e8d3bcdb045d1d53a5fc83b04cf28f8fca2570dcf5b
