[INFO] cloning repository https://github.com/ButtStuf/zee
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/ButtStuf/zee" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FButtStuf%2Fzee", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FButtStuf%2Fzee'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 226b63b3ade94ed74795350e512e6baab7ffd629
[INFO] checking ButtStuf/zee against master#46424fb5054f211ec836c5c03159f92e46bb35ac for pr-139042
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FButtStuf%2Fzee" "/workspace/builds/worker-5-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc1/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/ButtStuf/zee on toolchain 46424fb5054f211ec836c5c03159f92e46bb35ac
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+46424fb5054f211ec836c5c03159f92e46bb35ac" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/ButtStuf/zee
[INFO] finished tweaking git repo https://github.com/ButtStuf/zee
[INFO] tweaked toml for git repo https://github.com/ButtStuf/zee written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] crate git repo https://github.com/ButtStuf/zee 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" "+46424fb5054f211ec836c5c03159f92e46bb35ac" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded thiserror-impl v1.0.65
[INFO] [stderr]   Downloaded bytecheck_derive v0.6.12
[INFO] [stderr]   Downloaded rust_decimal_macros v1.36.0
[INFO] [stderr]   Downloaded anyhow v1.0.91
[INFO] [stderr]   Downloaded simdutf8 v0.1.5
[INFO] [stderr]   Downloaded schannel v0.1.26
[INFO] [stderr]   Downloaded serde_derive v1.0.213
[INFO] [stderr]   Downloaded serde v1.0.213
[INFO] [stderr]   Downloaded indicatif v0.17.8
[INFO] [stderr]   Downloaded rkyv v0.7.45
[INFO] [stderr]   Downloaded async-compression v0.4.17
[INFO] [stderr]   Downloaded regex v1.11.0
[INFO] [stderr]   Downloaded syn v2.0.83
[INFO] [stderr]   Downloaded bytecheck v0.6.12
[INFO] [stderr]   Downloaded rust_decimal v1.36.0
[INFO] [stderr]   Downloaded cc v1.1.31
[INFO] [stderr]   Downloaded thiserror v1.0.65
[INFO] [stderr]   Downloaded rend v0.4.2
[INFO] [stderr]   Downloaded rkyv_derive v0.7.45
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:4b26683ee3c49f365255c425c23003cbf4366de097804722c29c5bbbee3624d2" "/opt/rustwide/cargo-home/bin/cargo" "+46424fb5054f211ec836c5c03159f92e46bb35ac" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 4d493d41c974526409ec114edfb2b1f718e5f866edefce67e65e2cf77a5b509b
[INFO] running `Command { std: "docker" "start" "-a" "4d493d41c974526409ec114edfb2b1f718e5f866edefce67e65e2cf77a5b509b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4d493d41c974526409ec114edfb2b1f718e5f866edefce67e65e2cf77a5b509b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4d493d41c974526409ec114edfb2b1f718e5f866edefce67e65e2cf77a5b509b", kill_on_drop: false }`
[INFO] [stdout] 4d493d41c974526409ec114edfb2b1f718e5f866edefce67e65e2cf77a5b509b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:4b26683ee3c49f365255c425c23003cbf4366de097804722c29c5bbbee3624d2" "/opt/rustwide/cargo-home/bin/cargo" "+46424fb5054f211ec836c5c03159f92e46bb35ac" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2622c31394bbfea58efb5898c7dbc7b2dfab8dcdb2cb7b16bd00e04af2efc9aa
[INFO] running `Command { std: "docker" "start" "-a" "2622c31394bbfea58efb5898c7dbc7b2dfab8dcdb2cb7b16bd00e04af2efc9aa", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.89
[INFO] [stderr]    Compiling libc v0.2.161
[INFO] [stderr]    Compiling serde v1.0.213
[INFO] [stderr]     Checking memchr v2.7.4
[INFO] [stderr]    Compiling semver v1.0.23
[INFO] [stderr]    Compiling thiserror v1.0.65
[INFO] [stderr]     Checking cpufeatures v0.2.14
[INFO] [stderr]    Compiling hashbrown v0.15.0
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling serde_json v1.0.132
[INFO] [stderr]    Compiling anyhow v1.0.91
[INFO] [stderr]    Compiling borsh v1.5.1
[INFO] [stderr]     Checking arrayvec v0.7.6
[INFO] [stderr]     Checking pin-project-lite v0.2.14
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]     Checking regex-syntax v0.8.5
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]     Checking scopeguard v1.2.0
[INFO] [stderr]     Checking bytes v1.8.0
[INFO] [stderr]     Checking smallvec v1.13.2
[INFO] [stderr]    Compiling pkg-config v0.3.31
[INFO] [stderr]     Checking iana-time-zone v0.1.61
[INFO] [stderr]     Checking futures-core v0.3.31
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]     Checking futures-sink v0.3.31
[INFO] [stderr]     Checking futures-io v0.3.31
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]     Checking futures-task v0.3.31
[INFO] [stderr]    Compiling vcpkg v0.2.15
[INFO] [stderr]     Checking tracing-core v0.1.32
[INFO] [stderr]    Compiling rustls v0.21.12
[INFO] [stderr]    Compiling httparse v1.9.5
[INFO] [stderr]     Checking unicode-bidi v0.3.17
[INFO] [stderr]    Compiling solana-frozen-abi-macro v1.18.26
[INFO] [stderr]    Compiling solana-frozen-abi v1.18.26
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]    Compiling solana-sdk v1.18.26
[INFO] [stderr]     Checking foreign-types-shared v0.1.1
[INFO] [stderr]     Checking http v0.2.12
[INFO] [stderr]    Compiling openssl v0.10.68
[INFO] [stderr]     Checking foreign-types v0.3.2
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling native-tls v0.2.12
[INFO] [stderr]     Checking alloc-no-stdlib v2.0.4
[INFO] [stderr]    Compiling quote v1.0.37
[INFO] [stderr]    Compiling indexmap v2.6.0
[INFO] [stderr]     Checking tower-service v0.3.3
[INFO] [stderr]     Checking alloc-stdlib v0.2.2
[INFO] [stderr]     Checking adler2 v2.0.0
[INFO] [stderr]     Checking miniz_oxide v0.8.0
[INFO] [stderr]     Checking brotli-decompressor v4.0.1
[INFO] [stderr]     Checking idna v0.5.0
[INFO] [stderr]    Compiling num-bigint v0.2.6
[INFO] [stderr]    Compiling syn v2.0.83
[INFO] [stderr]    Compiling jobserver v0.1.32
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking crc32fast v1.4.2
[INFO] [stderr]    Compiling num-rational v0.2.4
[INFO] [stderr]    Compiling num-complex v0.2.4
[INFO] [stderr]     Checking webpki-roots v0.25.4
[INFO] [stderr]    Compiling cc v1.1.31
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]     Checking getrandom v0.1.16
[INFO] [stderr]     Checking memmap2 v0.5.10
[INFO] [stderr]     Checking atty v0.2.14
[INFO] [stderr]     Checking socket2 v0.5.7
[INFO] [stderr]     Checking signal-hook-registry v1.4.2
[INFO] [stderr]    Compiling toml_edit v0.22.22
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]     Checking mio v1.0.2
[INFO] [stderr]     Checking url v2.5.2
[INFO] [stderr]     Checking http-body v0.4.6
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking ahash v0.7.8
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking flate2 v1.0.34
[INFO] [stderr]     Checking hashbrown v0.11.2
[INFO] [stderr]     Checking rand_xoshiro v0.6.0
[INFO] [stderr]     Checking crossbeam-channel v0.5.13
[INFO] [stderr]     Checking encoding_rs v0.8.34
[INFO] [stderr]     Checking ipnet v2.10.1
[INFO] [stderr]     Checking brotli v7.0.0
[INFO] [stderr]     Checking unreachable v1.0.0
[INFO] [stderr]     Checking gethostname v0.2.3
[INFO] [stderr]     Checking regex-automata v0.4.8
[INFO] [stderr]     Checking num-iter v0.1.45
[INFO] [stderr]     Checking plain v0.2.3
[INFO] [stderr]     Checking ascii v0.9.3
[INFO] [stderr]    Compiling solana-program-runtime v1.18.26
[INFO] [stderr]     Checking hash32 v0.2.1
[INFO] [stderr]    Compiling winnow v0.5.40
[INFO] [stderr]     Checking rustc-demangle v0.1.24
[INFO] [stderr]     Checking eager v0.1.0
[INFO] [stderr]    Compiling time-core v0.1.2
[INFO] [stderr]    Compiling num-conv v0.1.0
[INFO] [stderr]    Compiling zstd-safe v5.0.2+zstd.1.5.2
[INFO] [stderr]    Compiling solana-version v1.18.26
[INFO] [stderr]    Compiling time-macros v0.2.18
[INFO] [stderr]     Checking unicode-width v0.1.14
[INFO] [stderr]     Checking combine v3.8.1
[INFO] [stderr]    Compiling solana-vote-program v1.18.26
[INFO] [stderr]     Checking spin v0.5.2
[INFO] [stderr]     Checking untrusted v0.7.1
[INFO] [stderr]     Checking base64 v0.13.1
[INFO] [stderr]    Compiling unicode-xid v0.2.6
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking console v0.15.8
[INFO] [stderr]    Compiling memoffset v0.7.1
[INFO] [stderr]     Checking data-encoding v2.6.0
[INFO] [stderr]     Checking pem v1.1.1
[INFO] [stderr]    Compiling rustix v0.38.37
[INFO] [stderr]     Checking num v0.2.1
[INFO] [stderr]    Compiling portable-atomic v1.9.0
[INFO] [stderr]     Checking percentage v0.1.0
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling oid-registry v0.6.1
[INFO] [stderr]     Checking const-oid v0.7.1
[INFO] [stderr]     Checking nix v0.26.4
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking der v0.5.1
[INFO] [stderr]    Compiling solana-perf v1.18.26
[INFO] [stderr]     Checking number_prefix v0.4.0
[INFO] [stderr]     Checking event-listener v2.5.3
[INFO] [stderr]    Compiling blake3 v1.5.1
[INFO] [stderr]    Compiling toml v0.5.11
[INFO] [stderr]    Compiling solana-program v1.18.26
[INFO] [stderr]    Compiling ring v0.17.8
[INFO] [stderr]    Compiling openssl-sys v0.9.104
[INFO] [stderr]    Compiling proc-macro-crate v3.2.0
[INFO] [stderr]    Compiling zstd-sys v2.0.13+zstd.1.5.6
[INFO] [stderr]     Checking time v0.3.36
[INFO] [stderr]    Compiling ring v0.16.20
[INFO] [stderr]     Checking rusticata-macros v4.1.0
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]     Checking base64ct v1.6.0
[INFO] [stderr]    Compiling proc-macro-crate v0.1.5
[INFO] [stderr]     Checking regex v1.11.0
[INFO] [stderr]     Checking os_str_bytes v6.6.1
[INFO] [stderr]     Checking fastrand v2.1.1
[INFO] [stderr]    Compiling toml_edit v0.19.15
[INFO] [stderr]     Checking clap_lex v0.2.4
[INFO] [stderr]     Checking spki v0.5.4
[INFO] [stderr]     Checking env_logger v0.9.3
[INFO] [stderr]     Checking Inflector v0.11.4
[INFO] [stderr]     Checking indicatif v0.17.8
[INFO] [stderr]     Checking solana-rayon-threadlimit v1.18.26
[INFO] [stderr]     Checking concurrent-queue v2.5.0
[INFO] [stderr]     Checking textwrap v0.16.1
[INFO] [stderr]     Checking solana-logger v1.18.26
[INFO] [stderr]     Checking shell-words v1.1.0
[INFO] [stderr]     Checking yasna v0.5.2
[INFO] [stderr]     Checking utf-8 v0.7.6
[INFO] [stderr]     Checking async-channel v1.9.0
[INFO] [stderr]     Checking clap v3.2.25
[INFO] [stderr]     Checking textwrap v0.11.0
[INFO] [stderr]     Checking rtoolbox v0.0.2
[INFO] [stderr]     Checking strsim v0.8.0
[INFO] [stderr]     Checking ansi_term v0.12.1
[INFO] [stderr]     Checking histogram v0.6.9
[INFO] [stderr]    Compiling rust_decimal v1.36.0
[INFO] [stderr]     Checking rpassword v7.3.1
[INFO] [stderr]     Checking async-mutex v1.4.0
[INFO] [stderr]     Checking clap v2.34.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]    Compiling borsh-derive-internal v0.10.4
[INFO] [stderr]    Compiling borsh-derive-internal v0.9.3
[INFO] [stderr]    Compiling wasm-bindgen-backend v0.2.95
[INFO] [stderr]    Compiling borsh-schema-derive-internal v0.10.4
[INFO] [stderr]    Compiling borsh-schema-derive-internal v0.9.3
[INFO] [stderr]    Compiling darling_core v0.20.10
[INFO] [stderr]    Compiling proc-macro-crate v1.3.1
[INFO] [stderr]    Compiling synstructure v0.12.6
[INFO] [stderr]     Checking dashmap v5.5.3
[INFO] [stderr]    Compiling rust_decimal_macros v1.36.0
[INFO] [stderr]    Compiling serde_derive v1.0.213
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling thiserror-impl v1.0.65
[INFO] [stderr]    Compiling zeroize_derive v1.4.2
[INFO] [stderr]    Compiling ark-serialize-derive v0.4.2
[INFO] [stderr]    Compiling ark-ff-macros v0.4.2
[INFO] [stderr]    Compiling ark-ff-asm v0.4.2
[INFO] [stderr]    Compiling derivative v2.2.0
[INFO] [stderr]    Compiling syn_derive v0.1.8
[INFO] [stderr]     Checking zeroize v1.3.0
[INFO] [stderr]    Compiling wasm-bindgen-macro-support v0.2.95
[INFO] [stderr]    Compiling borsh-derive v0.9.3
[INFO] [stderr]    Compiling borsh-derive v0.10.4
[INFO] [stderr]    Compiling bytemuck_derive v1.8.0
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]     Checking zerocopy v0.7.35
[INFO] [stderr]    Compiling solana-sdk-macro v1.18.26
[INFO] [stderr]    Compiling num_enum_derive v0.7.3
[INFO] [stderr]     Checking ppv-lite86 v0.2.20
[INFO] [stderr]    Compiling borsh-derive v1.5.1
[INFO] [stderr]     Checking borsh v0.9.3
[INFO] [stderr]     Checking hashbrown v0.13.2
[INFO] [stderr]    Compiling qualifier_attr v0.2.2
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling tokio-macros v2.4.0
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking borsh v0.10.4
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]     Checking rustls-webpki v0.101.7
[INFO] [stderr]     Checking bytemuck v1.19.0
[INFO] [stderr]    Compiling wasm-bindgen-macro v0.2.95
[INFO] [stderr]     Checking num_enum v0.7.3
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]     Checking sct v0.7.1
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]     Checking merlin v3.0.0
[INFO] [stderr]     Checking tokio v1.41.0
[INFO] [stderr]    Compiling spl-discriminator-syn v0.1.2
[INFO] [stderr]     Checking wasm-bindgen v0.2.95
[INFO] [stderr]     Checking ark-std v0.4.0
[INFO] [stderr]    Compiling scroll_derive v0.11.1
[INFO] [stderr]    Compiling spl-program-error-derive v0.3.2
[INFO] [stderr]    Compiling enum-iterator-derive v1.4.0
[INFO] [stderr]    Compiling num_enum_derive v0.6.1
[INFO] [stderr]    Compiling num-derive v0.3.3
[INFO] [stderr]    Compiling spl-discriminator-derive v0.1.2
[INFO] [stderr]    Compiling darling_macro v0.20.10
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking scroll v0.11.0
[INFO] [stderr]    Compiling asn1-rs-derive v0.4.0
[INFO] [stderr]    Compiling asn1-rs-impl v0.1.0
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling darling v0.20.10
[INFO] [stderr]    Compiling serde_with_macros v2.3.3
[INFO] [stderr]     Checking goblin v0.5.4
[INFO] [stderr]    Compiling async-trait v0.1.83
[INFO] [stderr]     Checking enum-iterator v1.5.0
[INFO] [stderr]     Checking rcgen v0.10.0
[INFO] [stderr]     Checking num_enum v0.6.1
[INFO] [stderr]     Checking zstd v0.11.2+zstd.1.5.2
[INFO] [stderr]    Compiling dlopen2_derive v0.3.0
[INFO] [stderr]     Checking webpki-roots v0.24.0
[INFO] [stderr]     Checking caps v0.5.5
[INFO] [stderr]     Checking pkcs8 v0.8.0
[INFO] [stderr]     Checking asn1-rs v0.5.2
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking quinn-udp v0.4.1
[INFO] [stderr]     Checking dlopen2 v0.5.0
[INFO] [stderr]     Checking der-parser v8.2.0
[INFO] [stderr]     Checking quinn-proto v0.10.6
[INFO] [stderr]     Checking solana_rbpf v0.8.3
[INFO] [stderr]     Checking x509-parser v0.14.0
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking tokio-util v0.7.12
[INFO] [stderr]     Checking generic-array v0.14.7
[INFO] [stderr]     Checking bitflags v2.6.0
[INFO] [stderr]     Checking bv v0.11.1
[INFO] [stderr]     Checking serde_bytes v0.11.15
[INFO] [stderr]     Checking im v15.1.0
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking serde_with v2.3.3
[INFO] [stderr]     Checking chrono v0.4.38
[INFO] [stderr]     Checking tokio-rustls v0.24.1
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking async-compression v0.4.17
[INFO] [stderr]     Checking tokio-stream v0.1.16
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]     Checking crypto-common v0.1.6
[INFO] [stderr]     Checking digest v0.9.0
[INFO] [stderr]     Checking block-buffer v0.9.0
[INFO] [stderr]     Checking crypto-mac v0.8.0
[INFO] [stderr]     Checking cipher v0.3.0
[INFO] [stderr]     Checking h2 v0.3.26
[INFO] [stderr]     Checking pbkdf2 v0.4.0
[INFO] [stderr]     Checking hmac v0.8.1
[INFO] [stderr]     Checking curve25519-dalek v3.2.1
[INFO] [stderr]     Checking libsecp256k1-core v0.2.2
[INFO] [stderr]     Checking sha2 v0.9.9
[INFO] [stderr]     Checking universal-hash v0.4.1
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking hmac-drbg v0.3.0
[INFO] [stderr]     Checking aes v0.7.5
[INFO] [stderr]     Checking polyval v0.5.3
[INFO] [stderr]     Checking ctr v0.8.0
[INFO] [stderr]     Checking ark-serialize v0.4.2
[INFO] [stderr]     Checking tiny-bip39 v0.8.2
[INFO] [stderr]     Checking sha3 v0.10.8
[INFO] [stderr]     Checking hmac v0.12.1
[INFO] [stderr]     Checking pbkdf2 v0.11.0
[INFO] [stderr]     Checking aead v0.4.3
[INFO] [stderr]     Checking sha3 v0.9.1
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking ark-ff v0.4.2
[INFO] [stderr]     Checking aes-gcm-siv v0.10.3
[INFO] [stderr]     Checking tungstenite v0.20.1
[INFO] [stderr]     Checking ed25519-dalek v1.0.1
[INFO] [stderr]     Checking jsonrpc-core v18.0.0
[INFO] [stderr]     Checking quinn v0.10.2
[INFO] [stderr]     Checking libsecp256k1 v0.6.0
[INFO] [stderr]     Checking ed25519-dalek-bip32 v0.2.0
[INFO] [stderr]     Checking tempfile v3.13.0
[INFO] [stderr]     Checking tokio-tungstenite v0.20.1
[INFO] [stderr]     Checking dialoguer v0.10.4
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking hyper v0.14.31
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]     Checking hyper-rustls v0.24.2
[INFO] [stderr]     Checking ark-poly v0.4.2
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking ark-ec v0.4.2
[INFO] [stderr]     Checking ark-bn254 v0.4.0
[INFO] [stderr]     Checking light-poseidon v0.2.0
[INFO] [stderr]     Checking spl-program-error v0.3.0
[INFO] [stderr]     Checking spl-discriminator v0.1.0
[INFO] [stderr]     Checking spl-memo v4.0.0
[INFO] [stderr]     Checking spl-token v4.0.0
[INFO] [stderr]     Checking solana-zk-token-sdk v1.18.26
[INFO] [stderr]     Checking solana-measure v1.18.26
[INFO] [stderr]     Checking solana-metrics v1.18.26
[INFO] [stderr]     Checking solana-remote-wallet v1.18.26
[INFO] [stderr]     Checking solana-clap-utils v1.18.26
[INFO] [stderr]     Checking solana-net-utils v1.18.26
[INFO] [stderr]     Checking solana-connection-cache v1.18.26
[INFO] [stderr]     Checking solana-config-program v1.18.26
[INFO] [stderr]     Checking spl-pod v0.1.0
[INFO] [stderr]     Checking spl-type-length-value v0.3.0
[INFO] [stderr]     Checking spl-token-group-interface v0.1.0
[INFO] [stderr]     Checking solana-streamer v1.18.26
[INFO] [stderr]     Checking spl-tlv-account-resolution v0.5.1
[INFO] [stderr]     Checking spl-token-metadata-interface v0.2.0
[INFO] [stderr]     Checking spl-transfer-hook-interface v0.4.1
[INFO] [stderr]     Checking spl-token-2022 v1.0.0
[INFO] [stderr]     Checking solana-udp-client v1.18.26
[INFO] [stderr]     Checking solana-account-decoder v1.18.26
[INFO] [stderr]     Checking spl-associated-token-account v2.3.0
[INFO] [stderr]     Checking solana-transaction-status v1.18.26
[INFO] [stderr]     Checking solana-rpc-client-api v1.18.26
[INFO] [stderr]     Checking solana-rpc-client v1.18.26
[INFO] [stderr]     Checking solana-pubsub-client v1.18.26
[INFO] [stderr]     Checking solana-quic-client v1.18.26
[INFO] [stderr]     Checking solana-rpc-client-nonce-utils v1.18.26
[INFO] [stderr]     Checking solana-tpu-client v1.18.26
[INFO] [stderr]     Checking solana-thin-client v1.18.26
[INFO] [stderr]     Checking solana-client v1.18.26
[INFO] [stderr]     Checking mev-bot-solana v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] error[E0432]: unresolved import `crate::utils::solana::send_transaction`
[INFO] [stdout]  --> bot/flashbots_client.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::utils::solana::send_transaction;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ no `send_transaction` in `utils::solana`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::dex::dex_trait`
[INFO] [stdout]  --> dex/raydium.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::dex::dex_trait::DexTrait;
[INFO] [stdout]   |                 ^^^^^^^^^ could not find `dex_trait` in `dex`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::error`
[INFO] [stdout]  --> dex/raydium.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::error::Result;
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout]   |            |
[INFO] [stdout]   |            unresolved import
[INFO] [stdout]   |            help: a similar path exists: `core::error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::market`
[INFO] [stdout]  --> dex/raydium.rs:3:20
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::market::Market;
[INFO] [stdout]   |                    ^^^^^^ could not find `market` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::order`
[INFO] [stdout]  --> dex/raydium.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::models::order::{Order, OrderSide, OrderStatus, OrderType};
[INFO] [stdout]   |                    ^^^^^ could not find `order` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::dex::dex_trait`
[INFO] [stdout]  --> dex/serum.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::dex::dex_trait::DexTrait;
[INFO] [stdout]   |                 ^^^^^^^^^ could not find `dex_trait` in `dex`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::error`
[INFO] [stdout]  --> dex/serum.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::error::Result;
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout]   |            |
[INFO] [stdout]   |            unresolved import
[INFO] [stdout]   |            help: a similar path exists: `core::error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::market`
[INFO] [stdout]  --> dex/serum.rs:3:20
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::market::Market;
[INFO] [stdout]   |                    ^^^^^^ could not find `market` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::order`
[INFO] [stdout]  --> dex/serum.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::models::order::{Order, OrderSide, OrderStatus, OrderType};
[INFO] [stdout]   |                    ^^^^^ could not find `order` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::dex::dex_trait`
[INFO] [stdout]  --> dex/orca.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::dex::dex_trait::DexTrait;
[INFO] [stdout]   |                 ^^^^^^^^^ could not find `dex_trait` in `dex`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::error`
[INFO] [stdout]  --> dex/orca.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::error::Result;
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout]   |            |
[INFO] [stdout]   |            unresolved import
[INFO] [stdout]   |            help: a similar path exists: `core::error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::market`
[INFO] [stdout]  --> dex/orca.rs:3:20
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::market::Market;
[INFO] [stdout]   |                    ^^^^^^ could not find `market` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::order`
[INFO] [stdout]  --> dex/orca.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::models::order::{Order, OrderSide, OrderStatus, OrderType};
[INFO] [stdout]   |                    ^^^^^ could not find `order` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/raydium.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdk::pubkey::Pubkey;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/raydium.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdk::signature::Keypair;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/raydium.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use sdk::signer::Signer;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/raydium.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use sdk::transaction::Transaction;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/serum.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdk::pubkey::Pubkey;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/serum.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdk::signature::Keypair;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/serum.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use sdk::signer::Signer;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/serum.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use sdk::transaction::Transaction;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/orca.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdk::pubkey::Pubkey;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/orca.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdk::signature::Keypair;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/orca.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use sdk::signer::Signer;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/orca.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use sdk::transaction::Transaction;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `async_trait`
[INFO] [stdout]  --> dex/dex_integration.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_trait::async_trait;
[INFO] [stdout]   |     ^^^^^^^^^^^ use of unresolved module or unlinked crate `async_trait`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `async_trait`, use `cargo add async_trait` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `async_trait`
[INFO] [stdout]  --> strategies/strategy.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use async_trait::async_trait;
[INFO] [stdout]   |     ^^^^^^^^^^^ use of unresolved module or unlinked crate `async_trait`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `async_trait`, use `cargo add async_trait` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `async_trait`
[INFO] [stdout]  --> strategies/arbitrage.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use async_trait::async_trait;
[INFO] [stdout]   |     ^^^^^^^^^^^ use of unresolved module or unlinked crate `async_trait`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `async_trait`, use `cargo add async_trait` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `async_trait`
[INFO] [stdout]  --> strategies/liquidation.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use async_trait::async_trait;
[INFO] [stdout]   |     ^^^^^^^^^^^ use of unresolved module or unlinked crate `async_trait`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `async_trait`, use `cargo add async_trait` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `async_trait`
[INFO] [stdout]  --> strategies/sandwich.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use async_trait::async_trait;
[INFO] [stdout]   |     ^^^^^^^^^^^ use of unresolved module or unlinked crate `async_trait`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `async_trait`, use `cargo add async_trait` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::utils::solana::send_transaction`
[INFO] [stdout]  --> bot/flashbots_client.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::utils::solana::send_transaction;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ no `send_transaction` in `utils::solana`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::dex::dex_trait`
[INFO] [stdout]  --> dex/raydium.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::dex::dex_trait::DexTrait;
[INFO] [stdout]   |                 ^^^^^^^^^ could not find `dex_trait` in `dex`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::error`
[INFO] [stdout]  --> dex/raydium.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::error::Result;
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout]   |            |
[INFO] [stdout]   |            unresolved import
[INFO] [stdout]   |            help: a similar path exists: `core::error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::market`
[INFO] [stdout]  --> dex/raydium.rs:3:20
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::market::Market;
[INFO] [stdout]   |                    ^^^^^^ could not find `market` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::order`
[INFO] [stdout]  --> dex/raydium.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::models::order::{Order, OrderSide, OrderStatus, OrderType};
[INFO] [stdout]   |                    ^^^^^ could not find `order` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: cannot find attribute `async_trait` in this scope
[INFO] [stdout]   --> dex/raydium.rs:38:3
[INFO] [stdout]    |
[INFO] [stdout] 38 | #[async_trait]
[INFO] [stdout]    |   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: cannot find attribute `async_trait` in this scope
[INFO] [stdout]   --> dex/serum.rs:28:3
[INFO] [stdout]    |
[INFO] [stdout] 28 | #[async_trait]
[INFO] [stdout]    |   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::dex::dex_trait`
[INFO] [stdout]  --> dex/serum.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::dex::dex_trait::DexTrait;
[INFO] [stdout]   |                 ^^^^^^^^^ could not find `dex_trait` in `dex`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::error`
[INFO] [stdout]  --> dex/serum.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::error::Result;
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout]   |            |
[INFO] [stdout]   |            unresolved import
[INFO] [stdout]   |            help: a similar path exists: `core::error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::market`
[INFO] [stdout]  --> dex/serum.rs:3:20
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::market::Market;
[INFO] [stdout]   |                    ^^^^^^ could not find `market` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::order`
[INFO] [stdout]  --> dex/serum.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::models::order::{Order, OrderSide, OrderStatus, OrderType};
[INFO] [stdout]   |                    ^^^^^ could not find `order` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: cannot find attribute `async_trait` in this scope
[INFO] [stdout]   --> dex/orca.rs:28:3
[INFO] [stdout]    |
[INFO] [stdout] 28 | #[async_trait]
[INFO] [stdout]    |   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::dex::dex_trait`
[INFO] [stdout]  --> dex/orca.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::dex::dex_trait::DexTrait;
[INFO] [stdout]   |                 ^^^^^^^^^ could not find `dex_trait` in `dex`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::error`
[INFO] [stdout]  --> dex/orca.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::error::Result;
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout]   |            |
[INFO] [stdout]   |            unresolved import
[INFO] [stdout]   |            help: a similar path exists: `core::error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::market`
[INFO] [stdout]  --> dex/orca.rs:3:20
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::models::market::Market;
[INFO] [stdout]   |                    ^^^^^^ could not find `market` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::models::order`
[INFO] [stdout]  --> dex/orca.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::models::order::{Order, OrderSide, OrderStatus, OrderType};
[INFO] [stdout]   |                    ^^^^^ could not find `order` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/raydium.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdk::pubkey::Pubkey;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/raydium.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdk::signature::Keypair;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/raydium.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use sdk::signer::Signer;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/raydium.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use sdk::transaction::Transaction;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/serum.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdk::pubkey::Pubkey;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/serum.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdk::signature::Keypair;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/serum.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use sdk::signer::Signer;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/serum.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use sdk::transaction::Transaction;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/orca.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdk::pubkey::Pubkey;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/orca.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdk::signature::Keypair;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/orca.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use sdk::signer::Signer;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]  --> dex/orca.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use sdk::transaction::Transaction;
[INFO] [stdout]   |     ^^^ use of unresolved module or unlinked crate `sdk`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `sdk`, use `cargo add sdk` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `async_trait`
[INFO] [stdout]  --> dex/dex_integration.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_trait::async_trait;
[INFO] [stdout]   |     ^^^^^^^^^^^ use of unresolved module or unlinked crate `async_trait`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `async_trait`, use `cargo add async_trait` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `async_trait`
[INFO] [stdout]  --> strategies/strategy.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use async_trait::async_trait;
[INFO] [stdout]   |     ^^^^^^^^^^^ use of unresolved module or unlinked crate `async_trait`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `async_trait`, use `cargo add async_trait` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `async_trait`
[INFO] [stdout]  --> strategies/arbitrage.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use async_trait::async_trait;
[INFO] [stdout]   |     ^^^^^^^^^^^ use of unresolved module or unlinked crate `async_trait`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `async_trait`, use `cargo add async_trait` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `async_trait`
[INFO] [stdout]  --> strategies/liquidation.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use async_trait::async_trait;
[INFO] [stdout]   |     ^^^^^^^^^^^ use of unresolved module or unlinked crate `async_trait`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `async_trait`, use `cargo add async_trait` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `async_trait`
[INFO] [stdout]  --> strategies/sandwich.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use async_trait::async_trait;
[INFO] [stdout]   |     ^^^^^^^^^^^ use of unresolved module or unlinked crate `async_trait`
[INFO] [stdout]   |
[INFO] [stdout]   = help: if you wanted to use a crate named `async_trait`, use `cargo add async_trait` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: cannot find attribute `async_trait` in this scope
[INFO] [stdout]   --> dex/raydium.rs:38:3
[INFO] [stdout]    |
[INFO] [stdout] 38 | #[async_trait]
[INFO] [stdout]    |   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: cannot find attribute `async_trait` in this scope
[INFO] [stdout]   --> dex/serum.rs:28:3
[INFO] [stdout]    |
[INFO] [stdout] 28 | #[async_trait]
[INFO] [stdout]    |   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: cannot find attribute `async_trait` in this scope
[INFO] [stdout]   --> dex/orca.rs:28:3
[INFO] [stdout]    |
[INFO] [stdout] 28 | #[async_trait]
[INFO] [stdout]    |   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `orca_swap`
[INFO] [stdout]   --> dex/orca.rs:76:27
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let instruction = orca_swap::instruction::swap(
[INFO] [stdout]    |                           ^^^^^^^^^ use of unresolved module or unlinked crate `orca_swap`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `orca_swap`, use `cargo add orca_swap` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: could not find `transaction_analysis` in `models`
[INFO] [stdout]  --> utils/solana.rs:4:80
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn analyze_transaction(transaction: &Transaction) -> Result<crate::models::transaction_analysis::TransactionAnalysis, Box<dyn Error>> {
[INFO] [stdout]   |                                                                                ^^^^^^^^^^^^^^^^^^^^ could not find `transaction_analysis` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: could not find `transaction_analysis` in `models`
[INFO] [stdout]  --> utils/solana.rs:5:39
[INFO] [stdout]   |
[INFO] [stdout] 5 |     let mut analysis = crate::models::transaction_analysis::TransactionAnalysis::default();
[INFO] [stdout]   |                                       ^^^^^^^^^^^^^^^^^^^^ could not find `transaction_analysis` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: could not find `transaction_analysis` in `models`
[INFO] [stdout]   --> utils/solana.rs:15:51
[INFO] [stdout]    |
[INFO] [stdout] 15 |         analysis.instructions.push(crate::models::transaction_analysis::InstructionAnalysis {
[INFO] [stdout]    |                                                   ^^^^^^^^^^^^^^^^^^^^ could not find `transaction_analysis` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]   --> utils/solana.rs:32:42
[INFO] [stdout]    |
[INFO] [stdout] 32 |             if let Ok(transfer_amount) = spl_token::instruction::unpack_amount(transfer_instruction.data) {
[INFO] [stdout]    |                                          ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:17:38
[INFO] [stdout]    |
[INFO] [stdout] 17 |     target_accounts: HashMap<Pubkey, AccountInfo>,
[INFO] [stdout]    |                                      ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `FlashbotsClient` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:20:33
[INFO] [stdout]    |
[INFO] [stdout] 20 |     flashbots_client: Arc<Mutex<FlashbotsClient>>,
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::flashbots_client::FlashbotsClient;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `SimulationEngine` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:21:34
[INFO] [stdout]    |
[INFO] [stdout] 21 |     simulation_engine: Arc<Mutex<SimulationEngine>>,
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::simulation_engine::SimulationEngine;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Optimizer` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:22:26
[INFO] [stdout]    |
[INFO] [stdout] 22 |     optimizer: Arc<Mutex<Optimizer>>,
[INFO] [stdout]    |                          ^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::optimizer::Optimizer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `RiskManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:23:29
[INFO] [stdout]    |
[INFO] [stdout] 23 |     risk_manager: Arc<Mutex<RiskManager>>,
[INFO] [stdout]    |                             ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::risk_manager::RiskManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MarketAnalyzer` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:24:32
[INFO] [stdout]    |
[INFO] [stdout] 24 |     market_analyzer: Arc<Mutex<MarketAnalyzer>>,
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::market_analyzer::MarketAnalyzer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `StrategyManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:25:33
[INFO] [stdout]    |
[INFO] [stdout] 25 |     strategy_manager: Arc<Mutex<StrategyManager>>,
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::strategy_manager::StrategyManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MonitoringManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:26:35
[INFO] [stdout]    |
[INFO] [stdout] 26 |     monitoring_manager: Arc<Mutex<MonitoringManager>>,
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::monitoring_manager::MonitoringManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `CopyTradeManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:27:35
[INFO] [stdout]    |
[INFO] [stdout] 27 |     copy_trade_manager: Arc<Mutex<CopyTradeManager>>,
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::copy_trade_manager::CopyTradeManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `SnipingManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:28:32
[INFO] [stdout]    |
[INFO] [stdout] 28 |     sniping_manager: Arc<Mutex<SnipingManager>>,
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::sniping_manager::SnipingManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `GasOptimizer` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:29:30
[INFO] [stdout]    |
[INFO] [stdout] 29 |     gas_optimizer: Arc<Mutex<GasOptimizer>>,
[INFO] [stdout]    |                              ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::gas_optimizer::GasOptimizer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `PathFinder` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:30:28
[INFO] [stdout]    |
[INFO] [stdout] 30 |     path_finder: Arc<Mutex<PathFinder>>,
[INFO] [stdout]    |                            ^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::path_finder::PathFinder;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `TradeExecutor` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:31:31
[INFO] [stdout]    |
[INFO] [stdout] 31 |     trade_executor: Arc<Mutex<TradeExecutor>>,
[INFO] [stdout]    |                               ^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::trade_executor::TradeExecutor;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `CrossChainManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:32:36
[INFO] [stdout]    |
[INFO] [stdout] 32 |     cross_chain_manager: Arc<Mutex<CrossChainManager>>,
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::cross_chain_manager::CrossChainManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `OrderManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:33:30
[INFO] [stdout]    |
[INFO] [stdout] 33 |     order_manager: Arc<Mutex<OrderManager>>,
[INFO] [stdout]    |                              ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::order_manager::OrderManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:40:42
[INFO] [stdout]    |
[INFO] [stdout] 40 |         target_accounts: HashMap<Pubkey, AccountInfo>,
[INFO] [stdout]    |                                          ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `FlashbotsClient`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:45:52
[INFO] [stdout]    |
[INFO] [stdout] 45 |         let flashbots_client = Arc::new(Mutex::new(FlashbotsClient::new(rpc_client.clone())));
[INFO] [stdout]    |                                                    ^^^^^^^^^^^^^^^ use of undeclared type `FlashbotsClient`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::flashbots_client::FlashbotsClient;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SimulationEngine`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:46:53
[INFO] [stdout]    |
[INFO] [stdout] 46 |         let simulation_engine = Arc::new(Mutex::new(SimulationEngine::new(rpc_client.clone())));
[INFO] [stdout]    |                                                     ^^^^^^^^^^^^^^^^ use of undeclared type `SimulationEngine`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::simulation_engine::SimulationEngine;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Optimizer`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:47:45
[INFO] [stdout]    |
[INFO] [stdout] 47 |         let optimizer = Arc::new(Mutex::new(Optimizer::new(rpc_client.clone())));
[INFO] [stdout]    |                                             ^^^^^^^^^ use of undeclared type `Optimizer`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::optimizer::Optimizer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `RiskManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:48:48
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let risk_manager = Arc::new(Mutex::new(RiskManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                ^^^^^^^^^^^ use of undeclared type `RiskManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::risk_manager::RiskManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MarketAnalyzer`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:49:51
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let market_analyzer = Arc::new(Mutex::new(MarketAnalyzer::new(rpc_client.clone())));
[INFO] [stdout]    |                                                   ^^^^^^^^^^^^^^ use of undeclared type `MarketAnalyzer`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::market_analyzer::MarketAnalyzer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `StrategyManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:50:52
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let strategy_manager = Arc::new(Mutex::new(StrategyManager::new(rpc_client.clone(), dex_integrations.clone())));
[INFO] [stdout]    |                                                    ^^^^^^^^^^^^^^^ use of undeclared type `StrategyManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::strategy_manager::StrategyManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MonitoringManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:51:54
[INFO] [stdout]    |
[INFO] [stdout] 51 |         let monitoring_manager = Arc::new(Mutex::new(MonitoringManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^^ use of undeclared type `MonitoringManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::monitoring_manager::MonitoringManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `CopyTradeManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:52:54
[INFO] [stdout]    |
[INFO] [stdout] 52 |         let copy_trade_manager = Arc::new(Mutex::new(CopyTradeManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^ use of undeclared type `CopyTradeManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::copy_trade_manager::CopyTradeManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SnipingManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:53:51
[INFO] [stdout]    |
[INFO] [stdout] 53 |         let sniping_manager = Arc::new(Mutex::new(SnipingManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                   ^^^^^^^^^^^^^^ use of undeclared type `SnipingManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::sniping_manager::SnipingManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `GasOptimizer`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:54:49
[INFO] [stdout]    |
[INFO] [stdout] 54 |         let gas_optimizer = Arc::new(Mutex::new(GasOptimizer::new(rpc_client.clone())));
[INFO] [stdout]    |                                                 ^^^^^^^^^^^^ use of undeclared type `GasOptimizer`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::gas_optimizer::GasOptimizer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `PathFinder`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:55:47
[INFO] [stdout]    |
[INFO] [stdout] 55 |         let path_finder = Arc::new(Mutex::new(PathFinder::new(rpc_client.clone())));
[INFO] [stdout]    |                                               ^^^^^^^^^^ use of undeclared type `PathFinder`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::path_finder::PathFinder;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `TradeExecutor`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:56:50
[INFO] [stdout]    |
[INFO] [stdout] 56 |         let trade_executor = Arc::new(Mutex::new(TradeExecutor::new(rpc_client.clone())));
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^ use of undeclared type `TradeExecutor`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::trade_executor::TradeExecutor;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `CrossChainManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:57:55
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let cross_chain_manager = Arc::new(Mutex::new(CrossChainManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                       ^^^^^^^^^^^^^^^^^ use of undeclared type `CrossChainManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::cross_chain_manager::CrossChainManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `OrderManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:58:49
[INFO] [stdout]    |
[INFO] [stdout] 58 |         let order_manager = Arc::new(Mutex::new(OrderManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                 ^^^^^^^^^^^^ use of undeclared type `OrderManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::order_manager::OrderManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> bot/strategy_manager.rs:34:85
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |                                                                                     ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 34 -     pub async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout] 34 +     pub async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> bot/path_finder.rs:14:86
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 14 -     pub async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout] 14 +     pub async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AmmInfo` in this scope
[INFO] [stdout]   --> dex/raydium.rs:44:26
[INFO] [stdout]    |
[INFO] [stdout] 44 |         let market_data: AmmInfo = bincode::deserialize(&market_infos.data)?;
[INFO] [stdout]    |                          ^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MarketState` in this scope
[INFO] [stdout]   --> dex/raydium.rs:63:26
[INFO] [stdout]    |
[INFO] [stdout] 63 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]    |                          ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:114:17
[INFO] [stdout]     |
[INFO] [stdout] 114 |                 AccountMeta::new(market.address, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:115:17
[INFO] [stdout]     |
[INFO] [stdout] 115 |                 AccountMeta::new(order_account.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:116:17
[INFO] [stdout]     |
[INFO] [stdout] 116 |                 AccountMeta::new(self.authority.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:117:17
[INFO] [stdout]     |
[INFO] [stdout] 117 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:118:17
[INFO] [stdout]     |
[INFO] [stdout] 118 |                 AccountMeta::new(token_b_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:119:17
[INFO] [stdout]     |
[INFO] [stdout] 119 |                 AccountMeta::new(vault_b, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:120:17
[INFO] [stdout]     |
[INFO] [stdout] 120 |                 AccountMeta::new(vault_a, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:121:17
[INFO] [stdout]     |
[INFO] [stdout] 121 |                 AccountMeta::new(token_a_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:122:17
[INFO] [stdout]     |
[INFO] [stdout] 122 |                 AccountMeta::new_readonly(solana_sdk::sysvar::rent::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:125:17
[INFO] [stdout]     |
[INFO] [stdout] 125 |                 AccountMeta::new(market.address, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:126:17
[INFO] [stdout]     |
[INFO] [stdout] 126 |                 AccountMeta::new(order_account.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:127:17
[INFO] [stdout]     |
[INFO] [stdout] 127 |                 AccountMeta::new(self.authority.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:128:17
[INFO] [stdout]     |
[INFO] [stdout] 128 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:129:17
[INFO] [stdout]     |
[INFO] [stdout] 129 |                 AccountMeta::new(token_a_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:130:17
[INFO] [stdout]     |
[INFO] [stdout] 130 |                 AccountMeta::new(vault_a, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:131:17
[INFO] [stdout]     |
[INFO] [stdout] 131 |                 AccountMeta::new(vault_b, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:132:17
[INFO] [stdout]     |
[INFO] [stdout] 132 |                 AccountMeta::new(token_b_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:133:17
[INFO] [stdout]     |
[INFO] [stdout] 133 |                 AccountMeta::new_readonly(solana_sdk::sysvar::rent::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `Instruction` in this scope
[INFO] [stdout]    --> dex/raydium.rs:137:27
[INFO] [stdout]     |
[INFO] [stdout] 137 |         let instruction = Instruction {
[INFO] [stdout]     |                           ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::Instruction;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:168:13
[INFO] [stdout]     |
[INFO] [stdout] 168 |             AccountMeta::new(order.market.address, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:169:13
[INFO] [stdout]     |
[INFO] [stdout] 169 |             AccountMeta::new_readonly(self.authority.pubkey(), true),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:170:13
[INFO] [stdout]     |
[INFO] [stdout] 170 |             AccountMeta::new(self.get_bids_address(&order.market)?, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:171:13
[INFO] [stdout]     |
[INFO] [stdout] 171 |             AccountMeta::new(self.get_asks_address(&order.market)?, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `Instruction` in this scope
[INFO] [stdout]    --> dex/raydium.rs:174:27
[INFO] [stdout]     |
[INFO] [stdout] 174 |         let instruction = Instruction {
[INFO] [stdout]     |                           ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::Instruction;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MarketState` in this scope
[INFO] [stdout]    --> dex/raydium.rs:214:26
[INFO] [stdout]     |
[INFO] [stdout] 214 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]     |                          ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MarketState` in this scope
[INFO] [stdout]   --> dex/serum.rs:36:30
[INFO] [stdout]    |
[INFO] [stdout] 36 |             let market_data: MarketState = bincode::deserialize(&market_info.account.data)?;
[INFO] [stdout]    |                              ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MarketState` in this scope
[INFO] [stdout]   --> dex/serum.rs:54:26
[INFO] [stdout]    |
[INFO] [stdout] 54 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]    |                          ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `NewOrderInstructionV3` in this scope
[INFO] [stdout]   --> dex/serum.rs:78:26
[INFO] [stdout]    |
[INFO] [stdout] 78 |         let order_data = NewOrderInstructionV3 {
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:94:17
[INFO] [stdout]    |
[INFO] [stdout] 94 |                 AccountMeta::new(market.address, false),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:95:17
[INFO] [stdout]    |
[INFO] [stdout] 95 |                 AccountMeta::new(order_account.pubkey(), true),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:96:17
[INFO] [stdout]    |
[INFO] [stdout] 96 |                 AccountMeta::new(self.authority.pubkey(), true),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:97:17
[INFO] [stdout]    |
[INFO] [stdout] 97 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:98:17
[INFO] [stdout]    |
[INFO] [stdout] 98 |                 AccountMeta::new(token_b_account, false),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:99:17
[INFO] [stdout]    |
[INFO] [stdout] 99 |                 AccountMeta::new(self.get_bids_address(&market)?, false),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:100:17
[INFO] [stdout]     |
[INFO] [stdout] 100 |                 AccountMeta::new(self.get_asks_address(&market)?, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:101:17
[INFO] [stdout]     |
[INFO] [stdout] 101 |                 AccountMeta::new(self.get_event_queue_address(&market)?, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:102:17
[INFO] [stdout]     |
[INFO] [stdout] 102 |                 AccountMeta::new(token_a_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:103:17
[INFO] [stdout]     |
[INFO] [stdout] 103 |                 AccountMeta::new_readonly(solana_sdk::sysvar::rent::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:106:17
[INFO] [stdout]     |
[INFO] [stdout] 106 |                 AccountMeta::new(market.address, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:107:17
[INFO] [stdout]     |
[INFO] [stdout] 107 |                 AccountMeta::new(order_account.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:108:17
[INFO] [stdout]     |
[INFO] [stdout] 108 |                 AccountMeta::new(self.authority.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:109:17
[INFO] [stdout]     |
[INFO] [stdout] 109 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:110:17
[INFO] [stdout]     |
[INFO] [stdout] 110 |                 AccountMeta::new(token_a_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:111:17
[INFO] [stdout]     |
[INFO] [stdout] 111 |                 AccountMeta::new(self.get_asks_address(&market)?, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:112:17
[INFO] [stdout]     |
[INFO] [stdout] 112 |                 AccountMeta::new(self.get_bids_address(&market)?, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:113:17
[INFO] [stdout]     |
[INFO] [stdout] 113 |                 AccountMeta::new(self.get_event_queue_address(&market)?, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:114:17
[INFO] [stdout]     |
[INFO] [stdout] 114 |                 AccountMeta::new(token_b_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:115:17
[INFO] [stdout]     |
[INFO] [stdout] 115 |                 AccountMeta::new_readonly(solana_sdk::sysvar::rent::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `Instruction` in this scope
[INFO] [stdout]    --> dex/serum.rs:119:27
[INFO] [stdout]     |
[INFO] [stdout] 119 |         let instruction = Instruction {
[INFO] [stdout]     |                           ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::Instruction;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:153:13
[INFO] [stdout]     |
[INFO] [stdout] 153 |             AccountMeta::new(order.market.address, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:154:13
[INFO] [stdout]     |
[INFO] [stdout] 154 |             AccountMeta::new_readonly(self.authority.pubkey(), true),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:155:13
[INFO] [stdout]     |
[INFO] [stdout] 155 |             AccountMeta::new(self.get_bids_address(&order.market)?, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:156:13
[INFO] [stdout]     |
[INFO] [stdout] 156 |             AccountMeta::new(self.get_asks_address(&order.market)?, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:157:13
[INFO] [stdout]     |
[INFO] [stdout] 157 |             AccountMeta::new(self.get_event_queue_address(&order.market)?, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `Instruction` in this scope
[INFO] [stdout]    --> dex/serum.rs:160:27
[INFO] [stdout]     |
[INFO] [stdout] 160 |         let instruction = Instruction {
[INFO] [stdout]     |                           ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::Instruction;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `PoolData` in this scope
[INFO] [stdout]   --> dex/orca.rs:36:28
[INFO] [stdout]    |
[INFO] [stdout] 36 |             let pool_data: PoolData = bincode::deserialize(&pool.account.data)?;
[INFO] [stdout]    |                            ^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> strategies/strategy.rs:10:81
[INFO] [stdout]    |
[INFO] [stdout] 10 |     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |                                                                                 ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 10 -     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout] 10 +     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> strategies/arbitrage.rs:14:82
[INFO] [stdout]    |
[INFO] [stdout] 14 |     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |                                                                                  ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 14 -     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout] 14 +     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> strategies/liquidation.rs:13:82
[INFO] [stdout]    |
[INFO] [stdout] 13 |     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |                                                                                  ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 13 -     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout] 13 +     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> strategies/sandwich.rs:14:82
[INFO] [stdout]    |
[INFO] [stdout] 14 |     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |                                                                                  ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 14 -     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout] 14 +     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::models::market_conditions::MarketConditions`
[INFO] [stdout]  --> bot/solana_mev_bot.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::models::market_conditions::MarketConditions;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::models::transaction_log::TransactionLog`
[INFO] [stdout]  --> bot/solana_mev_bot.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::models::transaction_log::TransactionLog;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]   --> bot/solana_mev_bot.rs:19:31
[INFO] [stdout]    |
[INFO] [stdout] 19 |     dex_integrations: Vec<Box<dyn DexIntegration>>,
[INFO] [stdout]    |                               ^^^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> dex/dex_integration.rs:7:14
[INFO] [stdout]    |
[INFO] [stdout] 6  | pub trait DexIntegration {
[INFO] [stdout]    |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7  |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8  |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9  |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]    |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10 |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]    |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]    = help: consider moving `get_prices` to another trait
[INFO] [stdout]    = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]    = help: consider moving `place_order` to another trait
[INFO] [stdout]    = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]   --> bot/solana_mev_bot.rs:42:35
[INFO] [stdout]    |
[INFO] [stdout] 42 |         dex_integrations: Vec<Box<dyn DexIntegration>>,
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> dex/dex_integration.rs:7:14
[INFO] [stdout]    |
[INFO] [stdout] 6  | pub trait DexIntegration {
[INFO] [stdout]    |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7  |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8  |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9  |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]    |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10 |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]    |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]    = help: consider moving `get_prices` to another trait
[INFO] [stdout]    = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]    = help: consider moving `place_order` to another trait
[INFO] [stdout]    = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `orca_swap`
[INFO] [stdout]   --> dex/orca.rs:76:27
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let instruction = orca_swap::instruction::swap(
[INFO] [stdout]    |                           ^^^^^^^^^ use of unresolved module or unlinked crate `orca_swap`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `orca_swap`, use `cargo add orca_swap` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: could not find `transaction_analysis` in `models`
[INFO] [stdout]  --> utils/solana.rs:4:80
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn analyze_transaction(transaction: &Transaction) -> Result<crate::models::transaction_analysis::TransactionAnalysis, Box<dyn Error>> {
[INFO] [stdout]   |                                                                                ^^^^^^^^^^^^^^^^^^^^ could not find `transaction_analysis` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: could not find `transaction_analysis` in `models`
[INFO] [stdout]  --> utils/solana.rs:5:39
[INFO] [stdout]   |
[INFO] [stdout] 5 |     let mut analysis = crate::models::transaction_analysis::TransactionAnalysis::default();
[INFO] [stdout]   |                                       ^^^^^^^^^^^^^^^^^^^^ could not find `transaction_analysis` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: could not find `transaction_analysis` in `models`
[INFO] [stdout]   --> utils/solana.rs:15:51
[INFO] [stdout]    |
[INFO] [stdout] 15 |         analysis.instructions.push(crate::models::transaction_analysis::InstructionAnalysis {
[INFO] [stdout]    |                                                   ^^^^^^^^^^^^^^^^^^^^ could not find `transaction_analysis` in `models`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]   --> utils/solana.rs:32:42
[INFO] [stdout]    |
[INFO] [stdout] 32 |             if let Ok(transfer_amount) = spl_token::instruction::unpack_amount(transfer_instruction.data) {
[INFO] [stdout]    |                                          ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:17:38
[INFO] [stdout]    |
[INFO] [stdout] 17 |     target_accounts: HashMap<Pubkey, AccountInfo>,
[INFO] [stdout]    |                                      ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `FlashbotsClient` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:20:33
[INFO] [stdout]    |
[INFO] [stdout] 20 |     flashbots_client: Arc<Mutex<FlashbotsClient>>,
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::flashbots_client::FlashbotsClient;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `SimulationEngine` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:21:34
[INFO] [stdout]    |
[INFO] [stdout] 21 |     simulation_engine: Arc<Mutex<SimulationEngine>>,
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::simulation_engine::SimulationEngine;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Optimizer` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:22:26
[INFO] [stdout]    |
[INFO] [stdout] 22 |     optimizer: Arc<Mutex<Optimizer>>,
[INFO] [stdout]    |                          ^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::optimizer::Optimizer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `RiskManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:23:29
[INFO] [stdout]    |
[INFO] [stdout] 23 |     risk_manager: Arc<Mutex<RiskManager>>,
[INFO] [stdout]    |                             ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::risk_manager::RiskManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MarketAnalyzer` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:24:32
[INFO] [stdout]    |
[INFO] [stdout] 24 |     market_analyzer: Arc<Mutex<MarketAnalyzer>>,
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::market_analyzer::MarketAnalyzer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `StrategyManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:25:33
[INFO] [stdout]    |
[INFO] [stdout] 25 |     strategy_manager: Arc<Mutex<StrategyManager>>,
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::strategy_manager::StrategyManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MonitoringManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:26:35
[INFO] [stdout]    |
[INFO] [stdout] 26 |     monitoring_manager: Arc<Mutex<MonitoringManager>>,
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::monitoring_manager::MonitoringManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `CopyTradeManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:27:35
[INFO] [stdout]    |
[INFO] [stdout] 27 |     copy_trade_manager: Arc<Mutex<CopyTradeManager>>,
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::copy_trade_manager::CopyTradeManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `SnipingManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:28:32
[INFO] [stdout]    |
[INFO] [stdout] 28 |     sniping_manager: Arc<Mutex<SnipingManager>>,
[INFO] [stdout]    |                                ^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::sniping_manager::SnipingManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `GasOptimizer` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:29:30
[INFO] [stdout]    |
[INFO] [stdout] 29 |     gas_optimizer: Arc<Mutex<GasOptimizer>>,
[INFO] [stdout]    |                              ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::gas_optimizer::GasOptimizer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `PathFinder` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:30:28
[INFO] [stdout]    |
[INFO] [stdout] 30 |     path_finder: Arc<Mutex<PathFinder>>,
[INFO] [stdout]    |                            ^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::path_finder::PathFinder;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `TradeExecutor` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:31:31
[INFO] [stdout]    |
[INFO] [stdout] 31 |     trade_executor: Arc<Mutex<TradeExecutor>>,
[INFO] [stdout]    |                               ^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::trade_executor::TradeExecutor;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `CrossChainManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:32:36
[INFO] [stdout]    |
[INFO] [stdout] 32 |     cross_chain_manager: Arc<Mutex<CrossChainManager>>,
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::cross_chain_manager::CrossChainManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `OrderManager` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:33:30
[INFO] [stdout]    |
[INFO] [stdout] 33 |     order_manager: Arc<Mutex<OrderManager>>,
[INFO] [stdout]    |                              ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::order_manager::OrderManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in this scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:40:42
[INFO] [stdout]    |
[INFO] [stdout] 40 |         target_accounts: HashMap<Pubkey, AccountInfo>,
[INFO] [stdout]    |                                          ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `FlashbotsClient`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:45:52
[INFO] [stdout]    |
[INFO] [stdout] 45 |         let flashbots_client = Arc::new(Mutex::new(FlashbotsClient::new(rpc_client.clone())));
[INFO] [stdout]    |                                                    ^^^^^^^^^^^^^^^ use of undeclared type `FlashbotsClient`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::flashbots_client::FlashbotsClient;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SimulationEngine`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:46:53
[INFO] [stdout]    |
[INFO] [stdout] 46 |         let simulation_engine = Arc::new(Mutex::new(SimulationEngine::new(rpc_client.clone())));
[INFO] [stdout]    |                                                     ^^^^^^^^^^^^^^^^ use of undeclared type `SimulationEngine`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::simulation_engine::SimulationEngine;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Optimizer`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:47:45
[INFO] [stdout]    |
[INFO] [stdout] 47 |         let optimizer = Arc::new(Mutex::new(Optimizer::new(rpc_client.clone())));
[INFO] [stdout]    |                                             ^^^^^^^^^ use of undeclared type `Optimizer`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::optimizer::Optimizer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `RiskManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:48:48
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let risk_manager = Arc::new(Mutex::new(RiskManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                ^^^^^^^^^^^ use of undeclared type `RiskManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::risk_manager::RiskManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MarketAnalyzer`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:49:51
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let market_analyzer = Arc::new(Mutex::new(MarketAnalyzer::new(rpc_client.clone())));
[INFO] [stdout]    |                                                   ^^^^^^^^^^^^^^ use of undeclared type `MarketAnalyzer`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::market_analyzer::MarketAnalyzer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `StrategyManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:50:52
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let strategy_manager = Arc::new(Mutex::new(StrategyManager::new(rpc_client.clone(), dex_integrations.clone())));
[INFO] [stdout]    |                                                    ^^^^^^^^^^^^^^^ use of undeclared type `StrategyManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::strategy_manager::StrategyManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MonitoringManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:51:54
[INFO] [stdout]    |
[INFO] [stdout] 51 |         let monitoring_manager = Arc::new(Mutex::new(MonitoringManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^^ use of undeclared type `MonitoringManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::monitoring_manager::MonitoringManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `CopyTradeManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:52:54
[INFO] [stdout]    |
[INFO] [stdout] 52 |         let copy_trade_manager = Arc::new(Mutex::new(CopyTradeManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^ use of undeclared type `CopyTradeManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::copy_trade_manager::CopyTradeManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SnipingManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:53:51
[INFO] [stdout]    |
[INFO] [stdout] 53 |         let sniping_manager = Arc::new(Mutex::new(SnipingManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                   ^^^^^^^^^^^^^^ use of undeclared type `SnipingManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::sniping_manager::SnipingManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `GasOptimizer`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:54:49
[INFO] [stdout]    |
[INFO] [stdout] 54 |         let gas_optimizer = Arc::new(Mutex::new(GasOptimizer::new(rpc_client.clone())));
[INFO] [stdout]    |                                                 ^^^^^^^^^^^^ use of undeclared type `GasOptimizer`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::gas_optimizer::GasOptimizer;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `PathFinder`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:55:47
[INFO] [stdout]    |
[INFO] [stdout] 55 |         let path_finder = Arc::new(Mutex::new(PathFinder::new(rpc_client.clone())));
[INFO] [stdout]    |                                               ^^^^^^^^^^ use of undeclared type `PathFinder`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::path_finder::PathFinder;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `TradeExecutor`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:56:50
[INFO] [stdout]    |
[INFO] [stdout] 56 |         let trade_executor = Arc::new(Mutex::new(TradeExecutor::new(rpc_client.clone())));
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^ use of undeclared type `TradeExecutor`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::trade_executor::TradeExecutor;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `CrossChainManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:57:55
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let cross_chain_manager = Arc::new(Mutex::new(CrossChainManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                       ^^^^^^^^^^^^^^^^^ use of undeclared type `CrossChainManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::cross_chain_manager::CrossChainManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `OrderManager`
[INFO] [stdout]   --> bot/solana_mev_bot.rs:58:49
[INFO] [stdout]    |
[INFO] [stdout] 58 |         let order_manager = Arc::new(Mutex::new(OrderManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                 ^^^^^^^^^^^^ use of undeclared type `OrderManager`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use crate::bot::order_manager::OrderManager;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> bot/strategy_manager.rs:34:85
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |                                                                                     ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 34 -     pub async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout] 34 +     pub async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> bot/path_finder.rs:14:86
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |                                                                                      ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 14 -     pub async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout] 14 +     pub async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AmmInfo` in this scope
[INFO] [stdout]   --> dex/raydium.rs:44:26
[INFO] [stdout]    |
[INFO] [stdout] 44 |         let market_data: AmmInfo = bincode::deserialize(&market_infos.data)?;
[INFO] [stdout]    |                          ^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MarketState` in this scope
[INFO] [stdout]   --> dex/raydium.rs:63:26
[INFO] [stdout]    |
[INFO] [stdout] 63 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]    |                          ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:114:17
[INFO] [stdout]     |
[INFO] [stdout] 114 |                 AccountMeta::new(market.address, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:115:17
[INFO] [stdout]     |
[INFO] [stdout] 115 |                 AccountMeta::new(order_account.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:116:17
[INFO] [stdout]     |
[INFO] [stdout] 116 |                 AccountMeta::new(self.authority.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:117:17
[INFO] [stdout]     |
[INFO] [stdout] 117 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:118:17
[INFO] [stdout]     |
[INFO] [stdout] 118 |                 AccountMeta::new(token_b_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:119:17
[INFO] [stdout]     |
[INFO] [stdout] 119 |                 AccountMeta::new(vault_b, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:120:17
[INFO] [stdout]     |
[INFO] [stdout] 120 |                 AccountMeta::new(vault_a, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:121:17
[INFO] [stdout]     |
[INFO] [stdout] 121 |                 AccountMeta::new(token_a_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:122:17
[INFO] [stdout]     |
[INFO] [stdout] 122 |                 AccountMeta::new_readonly(solana_sdk::sysvar::rent::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:125:17
[INFO] [stdout]     |
[INFO] [stdout] 125 |                 AccountMeta::new(market.address, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:126:17
[INFO] [stdout]     |
[INFO] [stdout] 126 |                 AccountMeta::new(order_account.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:127:17
[INFO] [stdout]     |
[INFO] [stdout] 127 |                 AccountMeta::new(self.authority.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:128:17
[INFO] [stdout]     |
[INFO] [stdout] 128 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:129:17
[INFO] [stdout]     |
[INFO] [stdout] 129 |                 AccountMeta::new(token_a_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:130:17
[INFO] [stdout]     |
[INFO] [stdout] 130 |                 AccountMeta::new(vault_a, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:131:17
[INFO] [stdout]     |
[INFO] [stdout] 131 |                 AccountMeta::new(vault_b, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:132:17
[INFO] [stdout]     |
[INFO] [stdout] 132 |                 AccountMeta::new(token_b_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:133:17
[INFO] [stdout]     |
[INFO] [stdout] 133 |                 AccountMeta::new_readonly(solana_sdk::sysvar::rent::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `Instruction` in this scope
[INFO] [stdout]    --> dex/raydium.rs:137:27
[INFO] [stdout]     |
[INFO] [stdout] 137 |         let instruction = Instruction {
[INFO] [stdout]     |                           ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::Instruction;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:168:13
[INFO] [stdout]     |
[INFO] [stdout] 168 |             AccountMeta::new(order.market.address, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:169:13
[INFO] [stdout]     |
[INFO] [stdout] 169 |             AccountMeta::new_readonly(self.authority.pubkey(), true),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:170:13
[INFO] [stdout]     |
[INFO] [stdout] 170 |             AccountMeta::new(self.get_bids_address(&order.market)?, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/raydium.rs:171:13
[INFO] [stdout]     |
[INFO] [stdout] 171 |             AccountMeta::new(self.get_asks_address(&order.market)?, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `Instruction` in this scope
[INFO] [stdout]    --> dex/raydium.rs:174:27
[INFO] [stdout]     |
[INFO] [stdout] 174 |         let instruction = Instruction {
[INFO] [stdout]     |                           ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::Instruction;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MarketState` in this scope
[INFO] [stdout]    --> dex/raydium.rs:214:26
[INFO] [stdout]     |
[INFO] [stdout] 214 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]     |                          ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MarketState` in this scope
[INFO] [stdout]   --> dex/serum.rs:36:30
[INFO] [stdout]    |
[INFO] [stdout] 36 |             let market_data: MarketState = bincode::deserialize(&market_info.account.data)?;
[INFO] [stdout]    |                              ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `MarketState` in this scope
[INFO] [stdout]   --> dex/serum.rs:54:26
[INFO] [stdout]    |
[INFO] [stdout] 54 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]    |                          ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `NewOrderInstructionV3` in this scope
[INFO] [stdout]   --> dex/serum.rs:78:26
[INFO] [stdout]    |
[INFO] [stdout] 78 |         let order_data = NewOrderInstructionV3 {
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:94:17
[INFO] [stdout]    |
[INFO] [stdout] 94 |                 AccountMeta::new(market.address, false),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:95:17
[INFO] [stdout]    |
[INFO] [stdout] 95 |                 AccountMeta::new(order_account.pubkey(), true),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:96:17
[INFO] [stdout]    |
[INFO] [stdout] 96 |                 AccountMeta::new(self.authority.pubkey(), true),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:97:17
[INFO] [stdout]    |
[INFO] [stdout] 97 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:98:17
[INFO] [stdout]    |
[INFO] [stdout] 98 |                 AccountMeta::new(token_b_account, false),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]   --> dex/serum.rs:99:17
[INFO] [stdout]    |
[INFO] [stdout] 99 |                 AccountMeta::new(self.get_bids_address(&market)?, false),
[INFO] [stdout]    |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:100:17
[INFO] [stdout]     |
[INFO] [stdout] 100 |                 AccountMeta::new(self.get_asks_address(&market)?, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:101:17
[INFO] [stdout]     |
[INFO] [stdout] 101 |                 AccountMeta::new(self.get_event_queue_address(&market)?, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:102:17
[INFO] [stdout]     |
[INFO] [stdout] 102 |                 AccountMeta::new(token_a_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:103:17
[INFO] [stdout]     |
[INFO] [stdout] 103 |                 AccountMeta::new_readonly(solana_sdk::sysvar::rent::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:106:17
[INFO] [stdout]     |
[INFO] [stdout] 106 |                 AccountMeta::new(market.address, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:107:17
[INFO] [stdout]     |
[INFO] [stdout] 107 |                 AccountMeta::new(order_account.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:108:17
[INFO] [stdout]     |
[INFO] [stdout] 108 |                 AccountMeta::new(self.authority.pubkey(), true),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:109:17
[INFO] [stdout]     |
[INFO] [stdout] 109 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:110:17
[INFO] [stdout]     |
[INFO] [stdout] 110 |                 AccountMeta::new(token_a_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:111:17
[INFO] [stdout]     |
[INFO] [stdout] 111 |                 AccountMeta::new(self.get_asks_address(&market)?, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:112:17
[INFO] [stdout]     |
[INFO] [stdout] 112 |                 AccountMeta::new(self.get_bids_address(&market)?, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:113:17
[INFO] [stdout]     |
[INFO] [stdout] 113 |                 AccountMeta::new(self.get_event_queue_address(&market)?, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:114:17
[INFO] [stdout]     |
[INFO] [stdout] 114 |                 AccountMeta::new(token_b_account, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:115:17
[INFO] [stdout]     |
[INFO] [stdout] 115 |                 AccountMeta::new_readonly(solana_sdk::sysvar::rent::ID, false),
[INFO] [stdout]     |                 ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `Instruction` in this scope
[INFO] [stdout]    --> dex/serum.rs:119:27
[INFO] [stdout]     |
[INFO] [stdout] 119 |         let instruction = Instruction {
[INFO] [stdout]     |                           ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::Instruction;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:153:13
[INFO] [stdout]     |
[INFO] [stdout] 153 |             AccountMeta::new(order.market.address, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:154:13
[INFO] [stdout]     |
[INFO] [stdout] 154 |             AccountMeta::new_readonly(self.authority.pubkey(), true),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:155:13
[INFO] [stdout]     |
[INFO] [stdout] 155 |             AccountMeta::new(self.get_bids_address(&order.market)?, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:156:13
[INFO] [stdout]     |
[INFO] [stdout] 156 |             AccountMeta::new(self.get_asks_address(&order.market)?, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `AccountMeta`
[INFO] [stdout]    --> dex/serum.rs:157:13
[INFO] [stdout]     |
[INFO] [stdout] 157 |             AccountMeta::new(self.get_event_queue_address(&order.market)?, false),
[INFO] [stdout]     |             ^^^^^^^^^^^ use of undeclared type `AccountMeta`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::AccountMeta;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0422]: cannot find struct, variant or union type `Instruction` in this scope
[INFO] [stdout]    --> dex/serum.rs:160:27
[INFO] [stdout]     |
[INFO] [stdout] 160 |         let instruction = Instruction {
[INFO] [stdout]     |                           ^^^^^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 1   + use solana_sdk::instruction::Instruction;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `PoolData` in this scope
[INFO] [stdout]   --> dex/orca.rs:36:28
[INFO] [stdout]    |
[INFO] [stdout] 36 |             let pool_data: PoolData = bincode::deserialize(&pool.account.data)?;
[INFO] [stdout]    |                            ^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> strategies/strategy.rs:10:81
[INFO] [stdout]    |
[INFO] [stdout] 10 |     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |                                                                                 ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 10 -     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout] 10 +     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:45:84
[INFO] [stdout]    |
[INFO] [stdout] 45 |         let flashbots_client = Arc::new(Mutex::new(FlashbotsClient::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                    ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> strategies/arbitrage.rs:14:82
[INFO] [stdout]    |
[INFO] [stdout] 14 |     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |                                                                                  ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 14 -     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout] 14 +     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> strategies/liquidation.rs:13:82
[INFO] [stdout]    |
[INFO] [stdout] 13 |     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |                                                                                  ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 13 -     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout] 13 +     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `AccountInfo` in the crate root
[INFO] [stdout]   --> strategies/sandwich.rs:14:82
[INFO] [stdout]    |
[INFO] [stdout] 14 |     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |                                                                                  ^^^^^^^^^^^ not found in the crate root
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 1  + use solana_sdk::sysvar::slot_history::AccountInfo;
[INFO] [stdout]    |
[INFO] [stdout] help: if you import `AccountInfo`, refer to it directly
[INFO] [stdout]    |
[INFO] [stdout] 14 -     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout] 14 +     async fn find_opportunities(&self, _target_accounts: &HashMap<Pubkey, AccountInfo>) -> Vec<MevOpportunity> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::models::market_conditions::MarketConditions`
[INFO] [stdout]  --> bot/solana_mev_bot.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::models::market_conditions::MarketConditions;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::models::transaction_log::TransactionLog`
[INFO] [stdout]  --> bot/solana_mev_bot.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::models::transaction_log::TransactionLog;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]   --> bot/solana_mev_bot.rs:19:31
[INFO] [stdout]    |
[INFO] [stdout] 19 |     dex_integrations: Vec<Box<dyn DexIntegration>>,
[INFO] [stdout]    |                               ^^^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> dex/dex_integration.rs:7:14
[INFO] [stdout]    |
[INFO] [stdout] 6  | pub trait DexIntegration {
[INFO] [stdout]    |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7  |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8  |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9  |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]    |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10 |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]    |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]    = help: consider moving `get_prices` to another trait
[INFO] [stdout]    = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]    = help: consider moving `place_order` to another trait
[INFO] [stdout]    = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]   --> bot/solana_mev_bot.rs:42:35
[INFO] [stdout]    |
[INFO] [stdout] 42 |         dex_integrations: Vec<Box<dyn DexIntegration>>,
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> dex/dex_integration.rs:7:14
[INFO] [stdout]    |
[INFO] [stdout] 6  | pub trait DexIntegration {
[INFO] [stdout]    |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7  |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8  |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9  |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]    |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10 |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]    |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]    = help: consider moving `get_prices` to another trait
[INFO] [stdout]    = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]    = help: consider moving `place_order` to another trait
[INFO] [stdout]    = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:46:86
[INFO] [stdout]    |
[INFO] [stdout] 46 |         let simulation_engine = Arc::new(Mutex::new(SimulationEngine::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                      ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:47:71
[INFO] [stdout]    |
[INFO] [stdout] 47 |         let optimizer = Arc::new(Mutex::new(Optimizer::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                       ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:45:84
[INFO] [stdout]    |
[INFO] [stdout] 45 |         let flashbots_client = Arc::new(Mutex::new(FlashbotsClient::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                    ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:48:76
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let risk_manager = Arc::new(Mutex::new(RiskManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                            ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:46:86
[INFO] [stdout]    |
[INFO] [stdout] 46 |         let simulation_engine = Arc::new(Mutex::new(SimulationEngine::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                      ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:49:82
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let market_analyzer = Arc::new(Mutex::new(MarketAnalyzer::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                  ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:47:71
[INFO] [stdout]    |
[INFO] [stdout] 47 |         let optimizer = Arc::new(Mutex::new(Optimizer::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                       ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:50:84
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let strategy_manager = Arc::new(Mutex::new(StrategyManager::new(rpc_client.clone(), dex_integrations.clone())));
[INFO] [stdout]    |                                                                                    ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `clone` exists for struct `Vec<Box<dyn DexIntegration>>`, but its trait bounds were not satisfied
[INFO] [stdout]   --> bot/solana_mev_bot.rs:50:110
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let strategy_manager = Arc::new(Mutex::new(StrategyManager::new(rpc_client.clone(), dex_integrations.clone())));
[INFO] [stdout]    |                                                                                                              ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: the following trait bounds were not satisfied:
[INFO] [stdout]            `Box<dyn DexIntegration>: Clone`
[INFO] [stdout]            which is required by `Vec<Box<dyn DexIntegration>>: Clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:48:76
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let risk_manager = Arc::new(Mutex::new(RiskManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                            ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:51:88
[INFO] [stdout]    |
[INFO] [stdout] 51 |         let monitoring_manager = Arc::new(Mutex::new(MonitoringManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                        ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:52:87
[INFO] [stdout]    |
[INFO] [stdout] 52 |         let copy_trade_manager = Arc::new(Mutex::new(CopyTradeManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                       ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:49:82
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let market_analyzer = Arc::new(Mutex::new(MarketAnalyzer::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                  ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:53:82
[INFO] [stdout]    |
[INFO] [stdout] 53 |         let sniping_manager = Arc::new(Mutex::new(SnipingManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                  ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:50:84
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let strategy_manager = Arc::new(Mutex::new(StrategyManager::new(rpc_client.clone(), dex_integrations.clone())));
[INFO] [stdout]    |                                                                                    ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:54:78
[INFO] [stdout]    |
[INFO] [stdout] 54 |         let gas_optimizer = Arc::new(Mutex::new(GasOptimizer::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                              ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `clone` exists for struct `Vec<Box<dyn DexIntegration>>`, but its trait bounds were not satisfied
[INFO] [stdout]   --> bot/solana_mev_bot.rs:50:110
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let strategy_manager = Arc::new(Mutex::new(StrategyManager::new(rpc_client.clone(), dex_integrations.clone())));
[INFO] [stdout]    |                                                                                                              ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: the following trait bounds were not satisfied:
[INFO] [stdout]            `Box<dyn DexIntegration>: Clone`
[INFO] [stdout]            which is required by `Vec<Box<dyn DexIntegration>>: Clone`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:55:74
[INFO] [stdout]    |
[INFO] [stdout] 55 |         let path_finder = Arc::new(Mutex::new(PathFinder::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                          ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:51:88
[INFO] [stdout]    |
[INFO] [stdout] 51 |         let monitoring_manager = Arc::new(Mutex::new(MonitoringManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                        ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:56:80
[INFO] [stdout]    |
[INFO] [stdout] 56 |         let trade_executor = Arc::new(Mutex::new(TradeExecutor::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:52:87
[INFO] [stdout]    |
[INFO] [stdout] 52 |         let copy_trade_manager = Arc::new(Mutex::new(CopyTradeManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                       ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:53:82
[INFO] [stdout]    |
[INFO] [stdout] 53 |         let sniping_manager = Arc::new(Mutex::new(SnipingManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                  ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:57:89
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let cross_chain_manager = Arc::new(Mutex::new(CrossChainManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                         ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:58:78
[INFO] [stdout]    |
[INFO] [stdout] 58 |         let order_manager = Arc::new(Mutex::new(OrderManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                              ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]   --> bot/solana_mev_bot.rs:65:13
[INFO] [stdout]    |
[INFO] [stdout] 65 |             dex_integrations,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> dex/dex_integration.rs:7:14
[INFO] [stdout]    |
[INFO] [stdout] 6  | pub trait DexIntegration {
[INFO] [stdout]    |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7  |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8  |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9  |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]    |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10 |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]    |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]    = help: consider moving `get_prices` to another trait
[INFO] [stdout]    = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]    = help: consider moving `place_order` to another trait
[INFO] [stdout]    = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:54:78
[INFO] [stdout]    |
[INFO] [stdout] 54 |         let gas_optimizer = Arc::new(Mutex::new(GasOptimizer::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                              ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:55:74
[INFO] [stdout]    |
[INFO] [stdout] 55 |         let path_finder = Arc::new(Mutex::new(PathFinder::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                          ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:56:80
[INFO] [stdout]    |
[INFO] [stdout] 56 |         let trade_executor = Arc::new(Mutex::new(TradeExecutor::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:57:89
[INFO] [stdout]    |
[INFO] [stdout] 57 |         let cross_chain_manager = Arc::new(Mutex::new(CrossChainManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                                         ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `clone` found for struct `solana_client::rpc_client::RpcClient` in the current scope
[INFO] [stdout]   --> bot/solana_mev_bot.rs:58:78
[INFO] [stdout]    |
[INFO] [stdout] 58 |         let order_manager = Arc::new(Mutex::new(OrderManager::new(rpc_client.clone())));
[INFO] [stdout]    |                                                                              ^^^^^ method not found in `RpcClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]   --> bot/solana_mev_bot.rs:65:13
[INFO] [stdout]    |
[INFO] [stdout] 65 |             dex_integrations,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> dex/dex_integration.rs:7:14
[INFO] [stdout]    |
[INFO] [stdout] 6  | pub trait DexIntegration {
[INFO] [stdout]    |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7  |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8  |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9  |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]    |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10 |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]    |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]    = help: consider moving `get_prices` to another trait
[INFO] [stdout]    = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]    = help: consider moving `place_order` to another trait
[INFO] [stdout]    = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]    --> bot/solana_mev_bot.rs:123:32
[INFO] [stdout]     |
[INFO] [stdout] 123 |         for dex_integration in &self.dex_integrations {
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]     |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]    --> dex/dex_integration.rs:7:14
[INFO] [stdout]     |
[INFO] [stdout] 6   | pub trait DexIntegration {
[INFO] [stdout]     |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7   |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]     |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8   |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9   |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]     |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10  |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]     |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]     = help: consider moving `get_prices` to another trait
[INFO] [stdout]     = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]     = help: consider moving `place_order` to another trait
[INFO] [stdout]     = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `find_opportunities` found for reference `&Box<dyn DexIntegration>` in the current scope
[INFO] [stdout]    --> bot/solana_mev_bot.rs:124:53
[INFO] [stdout]     |
[INFO] [stdout] 124 |             let dex_opportunities = dex_integration.find_opportunities(
[INFO] [stdout]     |                                     ----------------^^^^^^^^^^^^^^^^^^ method not found in `&Box<dyn DexIntegration>`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout] note: `Strategy` defines an item `find_opportunities`, perhaps you need to implement it
[INFO] [stdout]    --> strategies/strategy.rs:8:1
[INFO] [stdout]     |
[INFO] [stdout] 8   | pub trait Strategy {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]   --> bot/simulation_engine.rs:14:68
[INFO] [stdout]    |
[INFO] [stdout] 14 |         let (result, _) = self.rpc_client.simulate_transaction(tx).await.unwrap();
[INFO] [stdout]    |                                                                   -^^^^^
[INFO] [stdout]    |                                                                   ||
[INFO] [stdout]    |                                                                   |`Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]    |                                                                   help: remove the `.await`
[INFO] [stdout]    |
[INFO] [stdout]    = help: the trait `std::future::Future` is not implemented for `Result<Response<RpcSimulateTransactionResult>, ClientError>`
[INFO] [stdout]    = note: Result<Response<RpcSimulateTransactionResult>, ClientError> must be a future or must implement `IntoFuture` to be awaited
[INFO] [stdout]    = note: required for `Result<Response<RpcSimulateTransactionResult>, ClientError>` to implement `IntoFuture`
[INFO] [stdout]    = note: the full name for the type has been written to '/opt/rustwide/target/debug/deps/mev_bot_solana-70bf9be864b66fa9.long-type-17293551860781254238.txt'
[INFO] [stdout]    = note: consider using `--verbose` to print the full type name to the console
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]    --> bot/solana_mev_bot.rs:123:32
[INFO] [stdout]     |
[INFO] [stdout] 123 |         for dex_integration in &self.dex_integrations {
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]     |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]    --> dex/dex_integration.rs:7:14
[INFO] [stdout]     |
[INFO] [stdout] 6   | pub trait DexIntegration {
[INFO] [stdout]     |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7   |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]     |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8   |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9   |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]     |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10  |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]     |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]     = help: consider moving `get_prices` to another trait
[INFO] [stdout]     = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]     = help: consider moving `place_order` to another trait
[INFO] [stdout]     = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]   --> bot/risk_manager.rs:30:68
[INFO] [stdout]    |
[INFO] [stdout] 30 |         let (result, _) = self.rpc_client.simulate_transaction(tx).await.unwrap();
[INFO] [stdout]    |                                                                   -^^^^^
[INFO] [stdout]    |                                                                   ||
[INFO] [stdout]    |                                                                   |`Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]    |                                                                   help: remove the `.await`
[INFO] [stdout]    |
[INFO] [stdout]    = help: the trait `std::future::Future` is not implemented for `Result<Response<RpcSimulateTransactionResult>, ClientError>`
[INFO] [stdout]    = note: Result<Response<RpcSimulateTransactionResult>, ClientError> must be a future or must implement `IntoFuture` to be awaited
[INFO] [stdout]    = note: required for `Result<Response<RpcSimulateTransactionResult>, ClientError>` to implement `IntoFuture`
[INFO] [stdout]    = note: the full name for the type has been written to '/opt/rustwide/target/debug/deps/mev_bot_solana-70bf9be864b66fa9.long-type-17293551860781254238.txt'
[INFO] [stdout]    = note: consider using `--verbose` to print the full type name to the console
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]   --> bot/risk_manager.rs:41:68
[INFO] [stdout]    |
[INFO] [stdout] 41 |         let (result, _) = self.rpc_client.simulate_transaction(tx).await.unwrap();
[INFO] [stdout]    |                                                                   -^^^^^
[INFO] [stdout]    |                                                                   ||
[INFO] [stdout]    |                                                                   |`Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]    |                                                                   help: remove the `.await`
[INFO] [stdout]    |
[INFO] [stdout]    = help: the trait `std::future::Future` is not implemented for `Result<Response<RpcSimulateTransactionResult>, ClientError>`
[INFO] [stdout]    = note: Result<Response<RpcSimulateTransactionResult>, ClientError> must be a future or must implement `IntoFuture` to be awaited
[INFO] [stdout]    = note: required for `Result<Response<RpcSimulateTransactionResult>, ClientError>` to implement `IntoFuture`
[INFO] [stdout]    = note: the full name for the type has been written to '/opt/rustwide/target/debug/deps/mev_bot_solana-70bf9be864b66fa9.long-type-17293551860781254238.txt'
[INFO] [stdout]    = note: consider using `--verbose` to print the full type name to the console
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `find_opportunities` found for reference `&Box<dyn DexIntegration>` in the current scope
[INFO] [stdout]    --> bot/solana_mev_bot.rs:124:53
[INFO] [stdout]     |
[INFO] [stdout] 124 |             let dex_opportunities = dex_integration.find_opportunities(
[INFO] [stdout]     |                                     ----------------^^^^^^^^^^^^^^^^^^ method not found in `&Box<dyn DexIntegration>`
[INFO] [stdout]     |
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout] note: `Strategy` defines an item `find_opportunities`, perhaps you need to implement it
[INFO] [stdout]    --> strategies/strategy.rs:8:1
[INFO] [stdout]     |
[INFO] [stdout] 8   | pub trait Strategy {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0063]: missing field `account_balances` in initializer of `MarketConditions`
[INFO] [stdout]   --> bot/market_analyzer.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |         MarketConditions {
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^ missing `account_balances`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `Strategy` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:11:25
[INFO] [stdout]    |
[INFO] [stdout] 11 |     strategies: Vec<Box<dyn Strategy>>,
[INFO] [stdout]    |                         ^^^^^^^^^^^^ `Strategy` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> strategies/strategy.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub trait Strategy {
[INFO] [stdout]    |           -------- this trait is not dyn compatible...
[INFO] [stdout] 9  |     fn update(&mut self, market_conditions: &MarketConditions);
[INFO] [stdout] 10 |     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^ ...because method `find_opportunities` is `async`
[INFO] [stdout]    = help: consider moving `find_opportunities` to another trait
[INFO] [stdout]    = help: the following types implement `Strategy`:
[INFO] [stdout]              strategies::arbitrage::ArbitrageStrategy
[INFO] [stdout]              strategies::liquidation::LiquidationStrategy
[INFO] [stdout]              strategies::sandwich::SandwichStrategy
[INFO] [stdout]            consider defining an enum where each variant holds one of these types,
[INFO] [stdout]            implementing `Strategy` for this new enum and using it instead
[INFO] [stdout]    = note: `Strategy` may be implemented in other crates; if you want to support your users passing their own types here, you can't refer to a specific type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:12:31
[INFO] [stdout]    |
[INFO] [stdout] 12 |     dex_integrations: Vec<Box<dyn DexIntegration>>,
[INFO] [stdout]    |                               ^^^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> dex/dex_integration.rs:7:14
[INFO] [stdout]    |
[INFO] [stdout] 6  | pub trait DexIntegration {
[INFO] [stdout]    |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7  |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8  |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9  |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]    |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10 |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]    |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]    = help: consider moving `get_prices` to another trait
[INFO] [stdout]    = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]    = help: consider moving `place_order` to another trait
[INFO] [stdout]    = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:16:65
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub fn new(rpc_client: RpcClient, dex_integrations: Vec<Box<dyn DexIntegration>>) -> Self {
[INFO] [stdout]    |                                                                 ^^^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> dex/dex_integration.rs:7:14
[INFO] [stdout]    |
[INFO] [stdout] 6  | pub trait DexIntegration {
[INFO] [stdout]    |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7  |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8  |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9  |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]    |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10 |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]    |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]    = help: consider moving `get_prices` to another trait
[INFO] [stdout]    = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]    = help: consider moving `place_order` to another trait
[INFO] [stdout]    = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `Strategy` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:36:25
[INFO] [stdout]    |
[INFO] [stdout] 36 |         for strategy in &self.strategies {
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^ `Strategy` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> strategies/strategy.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub trait Strategy {
[INFO] [stdout]    |           -------- this trait is not dyn compatible...
[INFO] [stdout] 9  |     fn update(&mut self, market_conditions: &MarketConditions);
[INFO] [stdout] 10 |     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^ ...because method `find_opportunities` is `async`
[INFO] [stdout]    = help: consider moving `find_opportunities` to another trait
[INFO] [stdout]    = help: the following types implement `Strategy`:
[INFO] [stdout]              strategies::arbitrage::ArbitrageStrategy
[INFO] [stdout]              strategies::liquidation::LiquidationStrategy
[INFO] [stdout]              strategies::sandwich::SandwichStrategy
[INFO] [stdout]            consider defining an enum where each variant holds one of these types,
[INFO] [stdout]            implementing `Strategy` for this new enum and using it instead
[INFO] [stdout]    = note: `Strategy` may be implemented in other crates; if you want to support your users passing their own types here, you can't refer to a specific type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `Strategy` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:37:51
[INFO] [stdout]    |
[INFO] [stdout] 37 |             let strategy_opportunities = strategy.find_opportunities(target_accounts).await;
[INFO] [stdout]    |                                                   ^^^^^^^^^^^^^^^^^^ `Strategy` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> strategies/strategy.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub trait Strategy {
[INFO] [stdout]    |           -------- this trait is not dyn compatible...
[INFO] [stdout] 9  |     fn update(&mut self, market_conditions: &MarketConditions);
[INFO] [stdout] 10 |     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^ ...because method `find_opportunities` is `async`
[INFO] [stdout]    = help: consider moving `find_opportunities` to another trait
[INFO] [stdout]    = help: the following types implement `Strategy`:
[INFO] [stdout]              strategies::arbitrage::ArbitrageStrategy
[INFO] [stdout]              strategies::liquidation::LiquidationStrategy
[INFO] [stdout]              strategies::sandwich::SandwichStrategy
[INFO] [stdout]            consider defining an enum where each variant holds one of these types,
[INFO] [stdout]            implementing `Strategy` for this new enum and using it instead
[INFO] [stdout]    = note: `Strategy` may be implemented in other crates; if you want to support your users passing their own types here, you can't refer to a specific type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `Strategy` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:37:42
[INFO] [stdout]    |
[INFO] [stdout] 37 |             let strategy_opportunities = strategy.find_opportunities(target_accounts).await;
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `Strategy` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> strategies/strategy.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub trait Strategy {
[INFO] [stdout]    |           -------- this trait is not dyn compatible...
[INFO] [stdout] 9  |     fn update(&mut self, market_conditions: &MarketConditions);
[INFO] [stdout] 10 |     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^ ...because method `find_opportunities` is `async`
[INFO] [stdout]    = help: consider moving `find_opportunities` to another trait
[INFO] [stdout]    = help: the following types implement `Strategy`:
[INFO] [stdout]              strategies::arbitrage::ArbitrageStrategy
[INFO] [stdout]              strategies::liquidation::LiquidationStrategy
[INFO] [stdout]              strategies::sandwich::SandwichStrategy
[INFO] [stdout]            consider defining an enum where each variant holds one of these types,
[INFO] [stdout]            implementing `Strategy` for this new enum and using it instead
[INFO] [stdout]    = note: `Strategy` may be implemented in other crates; if you want to support your users passing their own types here, you can't refer to a specific type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/copy_trade_manager.rs:57:64
[INFO] [stdout]    |
[INFO] [stdout] 57 |     async fn get_recent_trades(&self, account: &Pubkey) -> Vec<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                                ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/copy_trade_manager.rs:62:49
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn find_profitable_trade(&self, trades: Vec<solana_transaction::Transaction>) -> Option<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                 ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/copy_trade_manager.rs:62:93
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn find_profitable_trade(&self, trades: Vec<solana_transaction::Transaction>) -> Option<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                                                             ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/copy_trade_manager.rs:67:54
[INFO] [stdout]    |
[INFO] [stdout] 67 |     fn create_copy_trade_transactions(&self, trade: &solana_transaction::Transaction) -> Vec<(solana_sdk::transaction::Transaction, f64)> {
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/sniping_manager.rs:57:53
[INFO] [stdout]    |
[INFO] [stdout] 57 |     async fn get_mempool_transactions(&self) -> Vec<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                     ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/sniping_manager.rs:62:61
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn find_profitable_transaction(&self, transactions: Vec<solana_transaction::Transaction>) -> Option<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                             ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/sniping_manager.rs:62:105
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn find_profitable_transaction(&self, transactions: Vec<solana_transaction::Transaction>) -> Option<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                                                                         ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/sniping_manager.rs:67:57
[INFO] [stdout]    |
[INFO] [stdout] 67 | ...ions(&self, transaction: &solana_transaction::Transaction) -> Vec<(solana_sdk::transaction::Transaction, f64)> {
[INFO] [stdout]    |                              ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]   --> dex/raydium.rs:44:36
[INFO] [stdout]    |
[INFO] [stdout] 44 |         let market_data: AmmInfo = bincode::deserialize(&market_infos.data)?;
[INFO] [stdout]    |                                    ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]   --> dex/raydium.rs:63:40
[INFO] [stdout]    |
[INFO] [stdout] 63 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]    |                                        ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MarketInstruction`
[INFO] [stdout]   --> dex/raydium.rs:96:31
[INFO] [stdout]    |
[INFO] [stdout] 96 |             OrderSide::Bid => MarketInstruction::NewOrder {
[INFO] [stdout]    |                               ^^^^^^^^^^^^^^^^^ use of undeclared type `MarketInstruction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Side`
[INFO] [stdout]   --> dex/raydium.rs:98:23
[INFO] [stdout]    |
[INFO] [stdout] 98 |                 side: Side::Bid,
[INFO] [stdout]    |                       ^^^^ use of undeclared type `Side`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MarketInstruction`
[INFO] [stdout]    --> dex/raydium.rs:103:31
[INFO] [stdout]     |
[INFO] [stdout] 103 |             OrderSide::Ask => MarketInstruction::NewOrder {
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^ use of undeclared type `MarketInstruction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Side`
[INFO] [stdout]    --> dex/raydium.rs:105:23
[INFO] [stdout]     |
[INFO] [stdout] 105 |                 side: Side::Ask,
[INFO] [stdout]     |                       ^^^^ use of undeclared type `Side`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/raydium.rs:117:43
[INFO] [stdout]     |
[INFO] [stdout] 117 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                                           ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/raydium.rs:128:43
[INFO] [stdout]     |
[INFO] [stdout] 128 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                                           ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MarketInstruction`
[INFO] [stdout]    --> dex/raydium.rs:165:27
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let cancel_data = MarketInstruction::CancelOrder { order_id: order.id };
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^ use of undeclared type `MarketInstruction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `rand`
[INFO] [stdout]    --> dex/raydium.rs:209:9
[INFO] [stdout]     |
[INFO] [stdout] 209 |         rand::random()
[INFO] [stdout]     |         ^^^^ use of unresolved module or unlinked crate `rand`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `rand`, use `cargo add rand` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    --> dex/raydium.rs:214:40
[INFO] [stdout]     |
[INFO] [stdout] 214 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]     |                                        ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]    --> dex/raydium.rs:220:31
[INFO] [stdout]     |
[INFO] [stdout] 220 |         let token_a_account = spl_associated_token_account::get_associated_token_address(
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_associated_token_account`, use `cargo add spl_associated_token_account` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]    --> dex/raydium.rs:224:31
[INFO] [stdout]     |
[INFO] [stdout] 224 |         let token_b_account = spl_associated_token_account::get_associated_token_address(
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_associated_token_account`, use `cargo add spl_associated_token_account` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/raydium.rs:236:18
[INFO] [stdout]     |
[INFO] [stdout] 236 |                 &spl_token::ID.to_bytes(),
[INFO] [stdout]     |                  ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/raydium.rs:250:18
[INFO] [stdout]     |
[INFO] [stdout] 250 |                 &spl_token::ID.to_bytes(),
[INFO] [stdout]     |                  ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]   --> dex/serum.rs:36:44
[INFO] [stdout]    |
[INFO] [stdout] 36 |             let market_data: MarketState = bincode::deserialize(&market_info.account.data)?;
[INFO] [stdout]    |                                            ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]   --> dex/serum.rs:54:40
[INFO] [stdout]    |
[INFO] [stdout] 54 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]    |                                        ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SelfTradeBehavior`
[INFO] [stdout]   --> dex/serum.rs:84:34
[INFO] [stdout]    |
[INFO] [stdout] 84 |             self_trade_behavior: SelfTradeBehavior::DecrementTake,
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^^^^^ use of undeclared type `SelfTradeBehavior`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SelfTradeBehaviorV2`
[INFO] [stdout]   --> dex/serum.rs:88:37
[INFO] [stdout]    |
[INFO] [stdout] 88 |             self_trade_behavior_v2: SelfTradeBehaviorV2::CancelProvide,
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^^^^^^^ use of undeclared type `SelfTradeBehaviorV2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]   --> dex/serum.rs:97:43
[INFO] [stdout]    |
[INFO] [stdout] 97 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]    |                                           ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/serum.rs:109:43
[INFO] [stdout]     |
[INFO] [stdout] 109 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                                           ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MarketInstruction`
[INFO] [stdout]    --> dex/serum.rs:147:27
[INFO] [stdout]     |
[INFO] [stdout] 147 |         let cancel_data = MarketInstruction::CancelOrderV2 {
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^ use of undeclared type `MarketInstruction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `rand`
[INFO] [stdout]    --> dex/serum.rs:197:9
[INFO] [stdout]     |
[INFO] [stdout] 197 |         rand::random()
[INFO] [stdout]     |         ^^^^ use of unresolved module or unlinked crate `rand`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `rand`, use `cargo add rand` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]    --> dex/serum.rs:201:31
[INFO] [stdout]     |
[INFO] [stdout] 201 |         let token_a_account = spl_associated_token_account::get_associated_token_address(
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_associated_token_account`, use `cargo add spl_associated_token_account` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]    --> dex/serum.rs:205:31
[INFO] [stdout]     |
[INFO] [stdout] 205 |         let token_b_account = spl_associated_token_account::get_associated_token_address(
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_associated_token_account`, use `cargo add spl_associated_token_account` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/serum.rs:268:14
[INFO] [stdout]     |
[INFO] [stdout] 268 |             &spl_token::ID,
[INFO] [stdout]     |              ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]   --> dex/orca.rs:36:39
[INFO] [stdout]    |
[INFO] [stdout] 36 |             let pool_data: PoolData = bincode::deserialize(&pool.account.data)?;
[INFO] [stdout]    |                                       ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `rand`
[INFO] [stdout]    --> dex/orca.rs:129:9
[INFO] [stdout]     |
[INFO] [stdout] 129 |         rand::random()
[INFO] [stdout]     |         ^^^^ use of unresolved module or unlinked crate `rand`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `rand`, use `cargo add rand` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]    --> dex/orca.rs:140:29
[INFO] [stdout]     |
[INFO] [stdout] 140 |         let token_account = spl_associated_token_account::get_associated_token_address(
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_associated_token_account`, use `cargo add spl_associated_token_account` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]   --> utils/solana.rs:31:69
[INFO] [stdout]    |
[INFO] [stdout] 31 |         if let Some(transfer_instruction) = instruction.program_id(&spl_token::ID) {
[INFO] [stdout]    |                                                                     ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0038, E0063, E0277, E0412, E0422, E0432, E0433, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0038`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `mev-bot-solana` (lib test) due to 200 previous errors; 2 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error[E0277]: `Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]   --> bot/simulation_engine.rs:14:68
[INFO] [stdout]    |
[INFO] [stdout] 14 |         let (result, _) = self.rpc_client.simulate_transaction(tx).await.unwrap();
[INFO] [stdout]    |                                                                   -^^^^^
[INFO] [stdout]    |                                                                   ||
[INFO] [stdout]    |                                                                   |`Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]    |                                                                   help: remove the `.await`
[INFO] [stdout]    |
[INFO] [stdout]    = help: the trait `std::future::Future` is not implemented for `Result<Response<RpcSimulateTransactionResult>, ClientError>`
[INFO] [stdout]    = note: Result<Response<RpcSimulateTransactionResult>, ClientError> must be a future or must implement `IntoFuture` to be awaited
[INFO] [stdout]    = note: required for `Result<Response<RpcSimulateTransactionResult>, ClientError>` to implement `IntoFuture`
[INFO] [stdout]    = note: the full name for the type has been written to '/opt/rustwide/target/debug/deps/mev_bot_solana-1a3a246638c8b883.long-type-5764589300984860267.txt'
[INFO] [stdout]    = note: consider using `--verbose` to print the full type name to the console
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]   --> bot/risk_manager.rs:30:68
[INFO] [stdout]    |
[INFO] [stdout] 30 |         let (result, _) = self.rpc_client.simulate_transaction(tx).await.unwrap();
[INFO] [stdout]    |                                                                   -^^^^^
[INFO] [stdout]    |                                                                   ||
[INFO] [stdout]    |                                                                   |`Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]    |                                                                   help: remove the `.await`
[INFO] [stdout]    |
[INFO] [stdout]    = help: the trait `std::future::Future` is not implemented for `Result<Response<RpcSimulateTransactionResult>, ClientError>`
[INFO] [stdout]    = note: Result<Response<RpcSimulateTransactionResult>, ClientError> must be a future or must implement `IntoFuture` to be awaited
[INFO] [stdout]    = note: required for `Result<Response<RpcSimulateTransactionResult>, ClientError>` to implement `IntoFuture`
[INFO] [stdout]    = note: the full name for the type has been written to '/opt/rustwide/target/debug/deps/mev_bot_solana-1a3a246638c8b883.long-type-5764589300984860267.txt'
[INFO] [stdout]    = note: consider using `--verbose` to print the full type name to the console
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]   --> bot/risk_manager.rs:41:68
[INFO] [stdout]    |
[INFO] [stdout] 41 |         let (result, _) = self.rpc_client.simulate_transaction(tx).await.unwrap();
[INFO] [stdout]    |                                                                   -^^^^^
[INFO] [stdout]    |                                                                   ||
[INFO] [stdout]    |                                                                   |`Result<Response<RpcSimulateTransactionResult>, ClientError>` is not a future
[INFO] [stdout]    |                                                                   help: remove the `.await`
[INFO] [stdout]    |
[INFO] [stdout]    = help: the trait `std::future::Future` is not implemented for `Result<Response<RpcSimulateTransactionResult>, ClientError>`
[INFO] [stdout]    = note: Result<Response<RpcSimulateTransactionResult>, ClientError> must be a future or must implement `IntoFuture` to be awaited
[INFO] [stdout]    = note: required for `Result<Response<RpcSimulateTransactionResult>, ClientError>` to implement `IntoFuture`
[INFO] [stdout]    = note: the full name for the type has been written to '/opt/rustwide/target/debug/deps/mev_bot_solana-1a3a246638c8b883.long-type-5764589300984860267.txt'
[INFO] [stdout]    = note: consider using `--verbose` to print the full type name to the console
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0063]: missing field `account_balances` in initializer of `MarketConditions`
[INFO] [stdout]   --> bot/market_analyzer.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |         MarketConditions {
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^ missing `account_balances`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `Strategy` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:11:25
[INFO] [stdout]    |
[INFO] [stdout] 11 |     strategies: Vec<Box<dyn Strategy>>,
[INFO] [stdout]    |                         ^^^^^^^^^^^^ `Strategy` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> strategies/strategy.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub trait Strategy {
[INFO] [stdout]    |           -------- this trait is not dyn compatible...
[INFO] [stdout] 9  |     fn update(&mut self, market_conditions: &MarketConditions);
[INFO] [stdout] 10 |     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^ ...because method `find_opportunities` is `async`
[INFO] [stdout]    = help: consider moving `find_opportunities` to another trait
[INFO] [stdout]    = help: the following types implement `Strategy`:
[INFO] [stdout]              strategies::arbitrage::ArbitrageStrategy
[INFO] [stdout]              strategies::liquidation::LiquidationStrategy
[INFO] [stdout]              strategies::sandwich::SandwichStrategy
[INFO] [stdout]            consider defining an enum where each variant holds one of these types,
[INFO] [stdout]            implementing `Strategy` for this new enum and using it instead
[INFO] [stdout]    = note: `Strategy` may be implemented in other crates; if you want to support your users passing their own types here, you can't refer to a specific type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:12:31
[INFO] [stdout]    |
[INFO] [stdout] 12 |     dex_integrations: Vec<Box<dyn DexIntegration>>,
[INFO] [stdout]    |                               ^^^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> dex/dex_integration.rs:7:14
[INFO] [stdout]    |
[INFO] [stdout] 6  | pub trait DexIntegration {
[INFO] [stdout]    |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7  |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8  |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9  |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]    |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10 |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]    |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]    = help: consider moving `get_prices` to another trait
[INFO] [stdout]    = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]    = help: consider moving `place_order` to another trait
[INFO] [stdout]    = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `DexIntegration` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:16:65
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub fn new(rpc_client: RpcClient, dex_integrations: Vec<Box<dyn DexIntegration>>) -> Self {
[INFO] [stdout]    |                                                                 ^^^^^^^^^^^^^^^^^^ `DexIntegration` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> dex/dex_integration.rs:7:14
[INFO] [stdout]    |
[INFO] [stdout] 6  | pub trait DexIntegration {
[INFO] [stdout]    |           -------------- this trait is not dyn compatible...
[INFO] [stdout] 7  |     async fn get_prices(&self) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^ ...because method `get_prices` is `async`
[INFO] [stdout] 8  |     async fn get_account_balances(&self, account: &Pubkey) -> HashMap<String, f64>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^ ...because method `get_account_balances` is `async`
[INFO] [stdout] 9  |     async fn place_order(&self, market: &str, side: &str, size: f64, price: f64) -> Option<String>;
[INFO] [stdout]    |              ^^^^^^^^^^^ ...because method `place_order` is `async`
[INFO] [stdout] 10 |     async fn cancel_order(&self, order_id: &str) -> bool;
[INFO] [stdout]    |              ^^^^^^^^^^^^ ...because method `cancel_order` is `async`
[INFO] [stdout]    = help: consider moving `get_prices` to another trait
[INFO] [stdout]    = help: consider moving `get_account_balances` to another trait
[INFO] [stdout]    = help: consider moving `place_order` to another trait
[INFO] [stdout]    = help: consider moving `cancel_order` to another trait
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `Strategy` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:36:25
[INFO] [stdout]    |
[INFO] [stdout] 36 |         for strategy in &self.strategies {
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^ `Strategy` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> strategies/strategy.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub trait Strategy {
[INFO] [stdout]    |           -------- this trait is not dyn compatible...
[INFO] [stdout] 9  |     fn update(&mut self, market_conditions: &MarketConditions);
[INFO] [stdout] 10 |     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^ ...because method `find_opportunities` is `async`
[INFO] [stdout]    = help: consider moving `find_opportunities` to another trait
[INFO] [stdout]    = help: the following types implement `Strategy`:
[INFO] [stdout]              strategies::arbitrage::ArbitrageStrategy
[INFO] [stdout]              strategies::liquidation::LiquidationStrategy
[INFO] [stdout]              strategies::sandwich::SandwichStrategy
[INFO] [stdout]            consider defining an enum where each variant holds one of these types,
[INFO] [stdout]            implementing `Strategy` for this new enum and using it instead
[INFO] [stdout]    = note: `Strategy` may be implemented in other crates; if you want to support your users passing their own types here, you can't refer to a specific type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `Strategy` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:37:51
[INFO] [stdout]    |
[INFO] [stdout] 37 |             let strategy_opportunities = strategy.find_opportunities(target_accounts).await;
[INFO] [stdout]    |                                                   ^^^^^^^^^^^^^^^^^^ `Strategy` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> strategies/strategy.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub trait Strategy {
[INFO] [stdout]    |           -------- this trait is not dyn compatible...
[INFO] [stdout] 9  |     fn update(&mut self, market_conditions: &MarketConditions);
[INFO] [stdout] 10 |     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^ ...because method `find_opportunities` is `async`
[INFO] [stdout]    = help: consider moving `find_opportunities` to another trait
[INFO] [stdout]    = help: the following types implement `Strategy`:
[INFO] [stdout]              strategies::arbitrage::ArbitrageStrategy
[INFO] [stdout]              strategies::liquidation::LiquidationStrategy
[INFO] [stdout]              strategies::sandwich::SandwichStrategy
[INFO] [stdout]            consider defining an enum where each variant holds one of these types,
[INFO] [stdout]            implementing `Strategy` for this new enum and using it instead
[INFO] [stdout]    = note: `Strategy` may be implemented in other crates; if you want to support your users passing their own types here, you can't refer to a specific type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `Strategy` is not dyn compatible
[INFO] [stdout]   --> bot/strategy_manager.rs:37:42
[INFO] [stdout]    |
[INFO] [stdout] 37 |             let strategy_opportunities = strategy.find_opportunities(target_accounts).await;
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `Strategy` is not dyn compatible
[INFO] [stdout]    |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]   --> strategies/strategy.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub trait Strategy {
[INFO] [stdout]    |           -------- this trait is not dyn compatible...
[INFO] [stdout] 9  |     fn update(&mut self, market_conditions: &MarketConditions);
[INFO] [stdout] 10 |     async fn find_opportunities(&self, target_accounts: &HashMap<Pubkey, crate::AccountInfo>) -> Vec<MevOpportunity>;
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^ ...because method `find_opportunities` is `async`
[INFO] [stdout]    = help: consider moving `find_opportunities` to another trait
[INFO] [stdout]    = help: the following types implement `Strategy`:
[INFO] [stdout]              strategies::arbitrage::ArbitrageStrategy
[INFO] [stdout]              strategies::liquidation::LiquidationStrategy
[INFO] [stdout]              strategies::sandwich::SandwichStrategy
[INFO] [stdout]            consider defining an enum where each variant holds one of these types,
[INFO] [stdout]            implementing `Strategy` for this new enum and using it instead
[INFO] [stdout]    = note: `Strategy` may be implemented in other crates; if you want to support your users passing their own types here, you can't refer to a specific type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/copy_trade_manager.rs:57:64
[INFO] [stdout]    |
[INFO] [stdout] 57 |     async fn get_recent_trades(&self, account: &Pubkey) -> Vec<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                                ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/copy_trade_manager.rs:62:49
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn find_profitable_trade(&self, trades: Vec<solana_transaction::Transaction>) -> Option<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                 ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/copy_trade_manager.rs:62:93
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn find_profitable_trade(&self, trades: Vec<solana_transaction::Transaction>) -> Option<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                                                             ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/copy_trade_manager.rs:67:54
[INFO] [stdout]    |
[INFO] [stdout] 67 |     fn create_copy_trade_transactions(&self, trade: &solana_transaction::Transaction) -> Vec<(solana_sdk::transaction::Transaction, f64)> {
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/sniping_manager.rs:57:53
[INFO] [stdout]    |
[INFO] [stdout] 57 |     async fn get_mempool_transactions(&self) -> Vec<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                     ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/sniping_manager.rs:62:61
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn find_profitable_transaction(&self, transactions: Vec<solana_transaction::Transaction>) -> Option<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                             ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/sniping_manager.rs:62:105
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn find_profitable_transaction(&self, transactions: Vec<solana_transaction::Transaction>) -> Option<solana_transaction::Transaction> {
[INFO] [stdout]    |                                                                                                         ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]   --> bot/sniping_manager.rs:67:57
[INFO] [stdout]    |
[INFO] [stdout] 67 | ...ions(&self, transaction: &solana_transaction::Transaction) -> Vec<(solana_sdk::transaction::Transaction, f64)> {
[INFO] [stdout]    |                              ^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `solana_transaction`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `solana_transaction`, use `cargo add solana_transaction` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]   --> dex/raydium.rs:44:36
[INFO] [stdout]    |
[INFO] [stdout] 44 |         let market_data: AmmInfo = bincode::deserialize(&market_infos.data)?;
[INFO] [stdout]    |                                    ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]   --> dex/raydium.rs:63:40
[INFO] [stdout]    |
[INFO] [stdout] 63 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]    |                                        ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MarketInstruction`
[INFO] [stdout]   --> dex/raydium.rs:96:31
[INFO] [stdout]    |
[INFO] [stdout] 96 |             OrderSide::Bid => MarketInstruction::NewOrder {
[INFO] [stdout]    |                               ^^^^^^^^^^^^^^^^^ use of undeclared type `MarketInstruction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Side`
[INFO] [stdout]   --> dex/raydium.rs:98:23
[INFO] [stdout]    |
[INFO] [stdout] 98 |                 side: Side::Bid,
[INFO] [stdout]    |                       ^^^^ use of undeclared type `Side`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MarketInstruction`
[INFO] [stdout]    --> dex/raydium.rs:103:31
[INFO] [stdout]     |
[INFO] [stdout] 103 |             OrderSide::Ask => MarketInstruction::NewOrder {
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^ use of undeclared type `MarketInstruction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Side`
[INFO] [stdout]    --> dex/raydium.rs:105:23
[INFO] [stdout]     |
[INFO] [stdout] 105 |                 side: Side::Ask,
[INFO] [stdout]     |                       ^^^^ use of undeclared type `Side`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/raydium.rs:117:43
[INFO] [stdout]     |
[INFO] [stdout] 117 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                                           ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/raydium.rs:128:43
[INFO] [stdout]     |
[INFO] [stdout] 128 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                                           ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MarketInstruction`
[INFO] [stdout]    --> dex/raydium.rs:165:27
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let cancel_data = MarketInstruction::CancelOrder { order_id: order.id };
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^ use of undeclared type `MarketInstruction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `rand`
[INFO] [stdout]    --> dex/raydium.rs:209:9
[INFO] [stdout]     |
[INFO] [stdout] 209 |         rand::random()
[INFO] [stdout]     |         ^^^^ use of unresolved module or unlinked crate `rand`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `rand`, use `cargo add rand` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    --> dex/raydium.rs:214:40
[INFO] [stdout]     |
[INFO] [stdout] 214 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]     |                                        ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]    --> dex/raydium.rs:220:31
[INFO] [stdout]     |
[INFO] [stdout] 220 |         let token_a_account = spl_associated_token_account::get_associated_token_address(
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_associated_token_account`, use `cargo add spl_associated_token_account` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]    --> dex/raydium.rs:224:31
[INFO] [stdout]     |
[INFO] [stdout] 224 |         let token_b_account = spl_associated_token_account::get_associated_token_address(
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_associated_token_account`, use `cargo add spl_associated_token_account` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/raydium.rs:236:18
[INFO] [stdout]     |
[INFO] [stdout] 236 |                 &spl_token::ID.to_bytes(),
[INFO] [stdout]     |                  ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/raydium.rs:250:18
[INFO] [stdout]     |
[INFO] [stdout] 250 |                 &spl_token::ID.to_bytes(),
[INFO] [stdout]     |                  ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]   --> dex/serum.rs:36:44
[INFO] [stdout]    |
[INFO] [stdout] 36 |             let market_data: MarketState = bincode::deserialize(&market_info.account.data)?;
[INFO] [stdout]    |                                            ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]   --> dex/serum.rs:54:40
[INFO] [stdout]    |
[INFO] [stdout] 54 |         let market_data: MarketState = bincode::deserialize(&market_account_info.data)?;
[INFO] [stdout]    |                                        ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SelfTradeBehavior`
[INFO] [stdout]   --> dex/serum.rs:84:34
[INFO] [stdout]    |
[INFO] [stdout] 84 |             self_trade_behavior: SelfTradeBehavior::DecrementTake,
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^^^^^ use of undeclared type `SelfTradeBehavior`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SelfTradeBehaviorV2`
[INFO] [stdout]   --> dex/serum.rs:88:37
[INFO] [stdout]    |
[INFO] [stdout] 88 |             self_trade_behavior_v2: SelfTradeBehaviorV2::CancelProvide,
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^^^^^^^ use of undeclared type `SelfTradeBehaviorV2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]   --> dex/serum.rs:97:43
[INFO] [stdout]    |
[INFO] [stdout] 97 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]    |                                           ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/serum.rs:109:43
[INFO] [stdout]     |
[INFO] [stdout] 109 |                 AccountMeta::new_readonly(spl_token::ID, false),
[INFO] [stdout]     |                                           ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `MarketInstruction`
[INFO] [stdout]    --> dex/serum.rs:147:27
[INFO] [stdout]     |
[INFO] [stdout] 147 |         let cancel_data = MarketInstruction::CancelOrderV2 {
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^ use of undeclared type `MarketInstruction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `rand`
[INFO] [stdout]    --> dex/serum.rs:197:9
[INFO] [stdout]     |
[INFO] [stdout] 197 |         rand::random()
[INFO] [stdout]     |         ^^^^ use of unresolved module or unlinked crate `rand`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `rand`, use `cargo add rand` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]    --> dex/serum.rs:201:31
[INFO] [stdout]     |
[INFO] [stdout] 201 |         let token_a_account = spl_associated_token_account::get_associated_token_address(
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_associated_token_account`, use `cargo add spl_associated_token_account` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]    --> dex/serum.rs:205:31
[INFO] [stdout]     |
[INFO] [stdout] 205 |         let token_b_account = spl_associated_token_account::get_associated_token_address(
[INFO] [stdout]     |                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_associated_token_account`, use `cargo add spl_associated_token_account` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    --> dex/serum.rs:268:14
[INFO] [stdout]     |
[INFO] [stdout] 268 |             &spl_token::ID,
[INFO] [stdout]     |              ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]   --> dex/orca.rs:36:39
[INFO] [stdout]    |
[INFO] [stdout] 36 |             let pool_data: PoolData = bincode::deserialize(&pool.account.data)?;
[INFO] [stdout]    |                                       ^^^^^^^ use of unresolved module or unlinked crate `bincode`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `bincode`, use `cargo add bincode` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `rand`
[INFO] [stdout]    --> dex/orca.rs:129:9
[INFO] [stdout]     |
[INFO] [stdout] 129 |         rand::random()
[INFO] [stdout]     |         ^^^^ use of unresolved module or unlinked crate `rand`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `rand`, use `cargo add rand` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]    --> dex/orca.rs:140:29
[INFO] [stdout]     |
[INFO] [stdout] 140 |         let token_account = spl_associated_token_account::get_associated_token_address(
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ use of unresolved module or unlinked crate `spl_associated_token_account`
[INFO] [stdout]     |
[INFO] [stdout]     = help: if you wanted to use a crate named `spl_associated_token_account`, use `cargo add spl_associated_token_account` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]   --> utils/solana.rs:31:69
[INFO] [stdout]    |
[INFO] [stdout] 31 |         if let Some(transfer_instruction) = instruction.program_id(&spl_token::ID) {
[INFO] [stdout]    |                                                                     ^^^^^^^^^ use of unresolved module or unlinked crate `spl_token`
[INFO] [stdout]    |
[INFO] [stdout]    = help: if you wanted to use a crate named `spl_token`, use `cargo add spl_token` to add it to your `Cargo.toml`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0038, E0063, E0277, E0412, E0422, E0432, E0433, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0038`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `mev-bot-solana` (lib) due to 200 previous errors; 2 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "2622c31394bbfea58efb5898c7dbc7b2dfab8dcdb2cb7b16bd00e04af2efc9aa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2622c31394bbfea58efb5898c7dbc7b2dfab8dcdb2cb7b16bd00e04af2efc9aa", kill_on_drop: false }`
[INFO] [stdout] 2622c31394bbfea58efb5898c7dbc7b2dfab8dcdb2cb7b16bd00e04af2efc9aa
