[INFO] cloning repository https://github.com/TikTzuki/tradeon
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/TikTzuki/tradeon" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTikTzuki%2Ftradeon", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTikTzuki%2Ftradeon'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 39bb3ab35681b2bdfd290efe846b77d1c2586fa8
[INFO] checking TikTzuki/tradeon against master#540f43a224317d894a9a0710a8d67704f179a33c for pr-155193
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTikTzuki%2Ftradeon" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/TikTzuki/tradeon
[INFO] finished tweaking git repo https://github.com/TikTzuki/tradeon
[INFO] tweaked toml for git repo https://github.com/TikTzuki/tradeon written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/TikTzuki/tradeon on toolchain 540f43a224317d894a9a0710a8d67704f179a33c
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+540f43a224317d894a9a0710a8d67704f179a33c" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/TikTzuki/tradeon 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" "+540f43a224317d894a9a0710a8d67704f179a33c" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: /workspace/builds/worker-0-tc1/source/crates/dataset/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr] warning: /workspace/builds/worker-0-tc1/source/crates/tradeon-core/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded toml v1.0.2+spec-1.1.0
[INFO] [stderr]   Downloaded rust-embed-utils v8.11.0
[INFO] [stderr]   Downloaded criterion-plot v0.6.0
[INFO] [stderr]   Downloaded boolinator v2.4.0
[INFO] [stderr]   Downloaded console-api v0.8.1
[INFO] [stderr]   Downloaded dyson_boot v0.1.1
[INFO] [stderr]   Downloaded utoipa-redoc v6.0.0
[INFO] [stderr]   Downloaded utoipa-rapidoc v6.0.0
[INFO] [stderr]   Downloaded utoipa-scalar v0.3.0
[INFO] [stderr]   Downloaded tracing-appender v0.2.3
[INFO] [stderr]   Downloaded dyson_http v0.1.1
[INFO] [stderr]   Downloaded utoipa-axum v0.2.0
[INFO] [stderr]   Downloaded serde_with_macros v3.16.0
[INFO] [stderr]   Downloaded utoipa-swagger-ui v9.0.2
[INFO] [stderr]   Downloaded rstest_macros v0.26.1
[INFO] [stderr]   Downloaded binance-rs-async v1.3.3
[INFO] [stderr]   Downloaded sqlx-sqlite v0.9.0-alpha.1
[INFO] [stderr]   Downloaded serde-xml-rs v0.8.1
[INFO] [stderr]   Downloaded sqlx-postgres v0.9.0-alpha.1
[INFO] [stderr]   Downloaded sqlx-core v0.9.0-alpha.1
[INFO] [stderr]   Downloaded console-subscriber v0.4.1
[INFO] [stderr]   Downloaded sqlx v0.9.0-alpha.1
[INFO] [stderr]   Downloaded serde_with v3.16.0
[INFO] [stderr]   Downloaded criterion v0.7.0
[INFO] [stderr]   Downloaded openssl-sys v0.9.110
[INFO] [stderr]   Downloaded schemars v1.1.0
[INFO] [stderr]   Downloaded openssl v0.10.74
[INFO] [stderr]   Downloaded utoipa v5.4.0
[INFO] [stderr]   Downloaded rustls v0.23.34
[INFO] [stderr]   Downloaded serde_qs v0.12.0
[INFO] [stderr]   Downloaded relative-path v1.9.3
[INFO] [stderr]   Downloaded rstest v0.26.1
[INFO] [stderr]   Downloaded sqlx-mysql v0.9.0-alpha.1
[INFO] [stderr]   Downloaded sqlx-macros v0.9.0-alpha.1
[INFO] [stderr]   Downloaded rust-embed-impl v8.11.0
[INFO] [stderr]   Downloaded async-nats v0.45.0
[INFO] [stderr]   Downloaded sqlx-macros-core v0.9.0-alpha.1
[INFO] [stderr]   Downloaded dyson_log v0.1.0
[INFO] [stderr]   Downloaded rust-embed v8.11.0
[INFO] [stderr]   Downloaded utoipa-swagger-ui-vendored v0.1.2
[INFO] [stderr]   Downloaded libsqlite3-sys v0.35.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+540f43a224317d894a9a0710a8d67704f179a33c" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 91b114f3500456fe291cdad715b6d53cd234220ab730d57869263e2ed17e693b
[INFO] running `Command { std: "docker" "start" "-a" "91b114f3500456fe291cdad715b6d53cd234220ab730d57869263e2ed17e693b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "91b114f3500456fe291cdad715b6d53cd234220ab730d57869263e2ed17e693b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "91b114f3500456fe291cdad715b6d53cd234220ab730d57869263e2ed17e693b", kill_on_drop: false }`
[INFO] [stdout] 91b114f3500456fe291cdad715b6d53cd234220ab730d57869263e2ed17e693b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+540f43a224317d894a9a0710a8d67704f179a33c" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 09868de4fed94ae6d125017ff4c0e51d59b78923dc6003200f9d0cd160485352
[INFO] running `Command { std: "docker" "start" "-a" "09868de4fed94ae6d125017ff4c0e51d59b78923dc6003200f9d0cd160485352", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/crates/tradeon-core/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr] warning: /opt/rustwide/workdir/crates/dataset/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr]    Compiling quote v1.0.41
[INFO] [stderr]    Compiling libc v0.2.177
[INFO] [stderr]     Checking log v0.4.28
[INFO] [stderr]    Compiling generic-array v0.14.9
[INFO] [stderr]     Checking tracing-core v0.1.34
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]    Compiling find-msvc-tools v0.1.4
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]     Checking hashbrown v0.16.1
[INFO] [stderr]    Compiling icu_properties_data v2.1.1
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking sync_wrapper v1.0.2
[INFO] [stderr]    Compiling pin-project-lite v0.2.16
[INFO] [stderr]    Compiling bytes v1.10.1
[INFO] [stderr]    Compiling futures-core v0.3.31
[INFO] [stderr]    Compiling subtle v2.6.1
[INFO] [stderr]     Checking aho-corasick v1.1.4
[INFO] [stderr]    Compiling itoa v1.0.15
[INFO] [stderr]    Compiling cc v1.2.44
[INFO] [stderr]     Checking regex-syntax v0.8.8
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling foldhash v0.2.0
[INFO] [stderr]    Compiling pin-utils v0.1.0
[INFO] [stderr]    Compiling anyhow v1.0.100
[INFO] [stderr]     Checking bitflags v2.10.0
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling slab v0.4.11
[INFO] [stderr]    Compiling futures-task v0.3.31
[INFO] [stderr]    Compiling syn v2.0.108
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]     Checking indexmap v2.12.1
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]     Checking base64 v0.21.7
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]     Checking matchit v0.7.3
[INFO] [stderr]     Checking simd-adler32 v0.3.7
[INFO] [stderr]     Checking deranged v0.5.5
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking mio v1.1.0
[INFO] [stderr]     Checking signal-hook-registry v1.4.6
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking socket2 v0.6.1
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]    Compiling openssl-sys v0.9.110
[INFO] [stderr]    Compiling crunchy v0.2.4
[INFO] [stderr]     Checking time-core v0.1.6
[INFO] [stderr]     Checking anstyle-query v1.1.4
[INFO] [stderr]    Compiling ryu v1.0.20
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking anstream v0.6.21
[INFO] [stderr]    Compiling tokio v1.48.0
[INFO] [stderr]     Checking flate2 v1.1.5
[INFO] [stderr]     Checking crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]    Compiling semver v1.0.27
[INFO] [stderr]     Checking clap_lex v0.7.6
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]     Checking humantime v2.3.0
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]     Checking clap_builder v4.5.51
[INFO] [stderr]     Checking iana-time-zone v0.1.64
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling ucd-trie v0.1.7
[INFO] [stderr]    Compiling openssl v0.10.74
[INFO] [stderr]     Checking openssl-probe v0.1.6
[INFO] [stderr]    Compiling pest v2.8.3
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]     Checking typeid v1.0.3
[INFO] [stderr]    Compiling const-random-macro v0.1.16
[INFO] [stderr]     Checking rustls-pki-types v1.13.0
[INFO] [stderr]     Checking base64ct v1.8.0
[INFO] [stderr]     Checking const-random v0.1.18
[INFO] [stderr]    Compiling tinyvec_macros v0.1.1
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling erased-serde v0.4.9
[INFO] [stderr]     Checking winnow v0.7.13
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling tinyvec v1.10.0
[INFO] [stderr]     Checking dlv-list v0.5.2
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]     Checking pem-rfc7468 v0.7.0
[INFO] [stderr]     Checking serde_spanned v1.0.4
[INFO] [stderr]     Checking hdrhistogram v7.5.4
[INFO] [stderr]     Checking const-oid v0.9.6
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking der v0.7.10
[INFO] [stderr]    Compiling hashlink v0.10.0
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling pest_meta v2.8.3
[INFO] [stderr]     Checking ordered-multimap v0.7.3
[INFO] [stderr]    Compiling event-listener v5.4.1
[INFO] [stderr]    Compiling unicode-normalization v0.1.25
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]    Compiling curve25519-dalek v4.1.3
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]     Checking signature v2.2.0
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]     Checking toml_datetime v0.7.3
[INFO] [stderr]     Checking data-encoding v2.9.0
[INFO] [stderr]     Checking arraydeque v0.5.1
[INFO] [stderr]    Compiling unicode-properties v0.1.4
[INFO] [stderr]    Compiling unicode-bidi v0.3.18
[INFO] [stderr]     Checking yaml-rust2 v0.10.4
[INFO] [stderr]     Checking convert_case v0.6.0
[INFO] [stderr]    Compiling hkdf v0.12.4
[INFO] [stderr]     Checking serde-untagged v0.1.9
[INFO] [stderr]     Checking spki v0.7.3
[INFO] [stderr]     Checking regex v1.12.2
[INFO] [stderr]     Checking rust-ini v0.21.3
[INFO] [stderr]    Compiling atoi v2.0.0
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]     Checking toml_parser v1.0.9+spec-1.1.0
[INFO] [stderr]    Compiling home v0.5.12
[INFO] [stderr]    Compiling stringprep v0.1.5
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling whoami v1.6.1
[INFO] [stderr]     Checking pathdiff v0.2.3
[INFO] [stderr]    Compiling rustls v0.23.34
[INFO] [stderr]     Checking pkcs8 v0.10.2
[INFO] [stderr]     Checking ed25519 v2.2.3
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]     Checking toml_datetime v1.0.0+spec-1.1.0
[INFO] [stderr]     Checking toml_writer v1.0.6+spec-1.1.0
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]     Checking xml-rs v0.8.28
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling pest_generator v2.8.3
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]     Checking toml v0.9.8
[INFO] [stderr]     Checking toml v1.0.2+spec-1.1.0
[INFO] [stderr]     Checking rustls-webpki v0.103.8
[INFO] [stderr]     Checking signatory v0.27.1
[INFO] [stderr]     Checking rustls-pemfile v2.2.0
[INFO] [stderr]     Checking rustls-pemfile v1.0.4
[INFO] [stderr]     Checking inventory v0.3.21
[INFO] [stderr]     Checking sync_wrapper v0.1.2
[INFO] [stderr]     Checking rustls-native-certs v0.7.3
[INFO] [stderr]     Checking rustls-webpki v0.102.8
[INFO] [stderr]    Compiling http v1.3.1
[INFO] [stderr]     Checking boolinator v2.4.0
[INFO] [stderr]    Compiling untrusted v0.9.0
[INFO] [stderr]    Compiling try-lock v0.2.5
[INFO] [stderr]    Compiling tower-service v0.3.3
[INFO] [stderr]    Compiling want v0.3.1
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling atomic-waker v1.1.2
[INFO] [stderr]     Checking serde_path_to_error v0.1.20
[INFO] [stderr]    Compiling tower-layer v0.3.3
[INFO] [stderr]    Compiling zlib-rs v0.5.5
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling bumpalo v3.19.0
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling webpki-roots v1.0.4
[INFO] [stderr]    Compiling iri-string v0.7.10
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling zopfli v0.8.3
[INFO] [stderr]    Compiling rust-embed-utils v8.11.0
[INFO] [stderr]     Checking inout v0.1.4
[INFO] [stderr]    Compiling utoipa-swagger-ui-vendored v0.1.2
[INFO] [stderr]     Checking cipher v0.4.4
[INFO] [stderr]    Compiling rstest_macros v0.26.1
[INFO] [stderr]     Checking universal-hash v0.5.1
[INFO] [stderr]     Checking opaque-debug v0.3.1
[INFO] [stderr]     Checking plotters-backend v0.3.7
[INFO] [stderr]     Checking ciborium-io v0.2.2
[INFO] [stderr]     Checking cast v0.3.0
[INFO] [stderr]     Checking polyval v0.6.2
[INFO] [stderr]    Compiling relative-path v1.9.3
[INFO] [stderr]     Checking ctr v0.9.2
[INFO] [stderr]     Checking plotters-svg v0.3.7
[INFO] [stderr]     Checking aes v0.8.4
[INFO] [stderr]     Checking aead v0.5.2
[INFO] [stderr]     Checking plotters v0.3.7
[INFO] [stderr]     Checking oorandom v11.1.5
[INFO] [stderr]     Checking anes v0.1.6
[INFO] [stderr]     Checking futures-timer v3.0.3
[INFO] [stderr]     Checking ghash v0.5.1
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling zerocopy-derive v0.8.27
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling utoipa-gen v5.4.0
[INFO] [stderr]     Checking async-stream v0.3.6
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking yoke v0.8.1
[INFO] [stderr]     Checking zerovec v0.11.5
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]     Checking tinystr v0.8.2
[INFO] [stderr]     Checking icu_locale_core v2.1.1
[INFO] [stderr]     Checking potential_utf v0.1.4
[INFO] [stderr]     Checking icu_collections v2.1.1
[INFO] [stderr]     Checking pin-project v1.1.10
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]    Compiling pest_derive v2.8.3
[INFO] [stderr]    Compiling curve25519-dalek-derive v0.1.1
[INFO] [stderr]    Compiling serde_repr v0.1.20
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]     Checking clap v4.5.51
[INFO] [stderr]    Compiling serde_with_macros v3.16.0
[INFO] [stderr]    Compiling rust-embed-impl v8.11.0
[INFO] [stderr]     Checking aes-gcm v0.10.3
[INFO] [stderr]    Compiling toml_edit v0.23.7
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking rust-embed v8.11.0
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]     Checking tracing-serde v0.2.0
[INFO] [stderr]     Checking time v0.3.44
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking icu_properties v2.1.1
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking tracing-subscriber v0.3.20
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking ron v0.12.0
[INFO] [stderr]     Checking json5 v0.4.1
[INFO] [stderr]     Checking futures-intrusive v0.5.0
[INFO] [stderr]     Checking serde_with v3.16.0
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking http v0.2.12
[INFO] [stderr]     Checking url v2.5.7
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking utils v0.1.0 (/opt/rustwide/workdir/crates/utils)
[INFO] [stderr]     Checking ed25519-dalek v2.2.0
[INFO] [stderr]     Checking serde-xml-rs v0.8.1
[INFO] [stderr]     Checking nuid v0.5.0
[INFO] [stderr]     Checking config v0.15.19
[INFO] [stderr]     Checking tracing-appender v0.2.3
[INFO] [stderr]     Checking nkeys v0.4.5
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking serde_nanos v0.1.4
[INFO] [stderr]     Checking serde_qs v0.12.0
[INFO] [stderr]    Compiling hyper v1.7.0
[INFO] [stderr]     Checking http-body v0.4.6
[INFO] [stderr]    Compiling libz-rs-sys v0.5.5
[INFO] [stderr]     Checking half v2.7.1
[INFO] [stderr]     Checking itertools v0.13.0
[INFO] [stderr]    Compiling proc-macro-crate v3.4.0
[INFO] [stderr]     Checking tungstenite v0.21.0
[INFO] [stderr]     Checking ciborium-ll v0.2.2
[INFO] [stderr]     Checking rayon v1.11.0
[INFO] [stderr]     Checking tinytemplate v1.2.1
[INFO] [stderr]     Checking ciborium v0.2.2
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling zip v3.0.0
[INFO] [stderr]     Checking dyson_boot v0.1.1
[INFO] [stderr]    Compiling prost-derive v0.13.5
[INFO] [stderr]     Checking axum-core v0.4.5
[INFO] [stderr]     Checking axum-core v0.5.6
[INFO] [stderr]    Compiling hyper-util v0.1.17
[INFO] [stderr]    Compiling sqlx-core v0.9.0-alpha.1
[INFO] [stderr]     Checking criterion-plot v0.6.0
[INFO] [stderr]     Checking utoipa v5.4.0
[INFO] [stderr]     Checking prost v0.13.5
[INFO] [stderr]     Checking rstest v0.26.1
[INFO] [stderr]     Checking prost-types v0.13.5
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]     Checking tokio-util v0.7.16
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking tryhard v0.5.2
[INFO] [stderr]     Checking criterion v0.7.0
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]     Checking tokio-tungstenite v0.21.0
[INFO] [stderr]    Compiling sqlx-postgres v0.9.0-alpha.1
[INFO] [stderr]     Checking h2 v0.4.12
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking h2 v0.3.27
[INFO] [stderr]     Checking async-nats v0.45.0
[INFO] [stderr]     Checking axum v0.7.9
[INFO] [stderr]    Compiling utoipa-swagger-ui v9.0.2
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]    Compiling sqlx-macros-core v0.9.0-alpha.1
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]    Compiling sqlx-macros v0.9.0-alpha.1
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking hyper-timeout v0.5.2
[INFO] [stderr]     Checking axum v0.8.8
[INFO] [stderr]     Checking tonic v0.12.3
[INFO] [stderr]     Checking binance-rs-async v1.3.3
[INFO] [stderr]     Checking sqlx v0.9.0-alpha.1
[INFO] [stderr]     Checking console-api v0.8.1
[INFO] [stderr]     Checking console-subscriber v0.4.1
[INFO] [stderr]     Checking dyson_log v0.1.0
[INFO] [stderr]     Checking tradeon-core v0.1.0 (/opt/rustwide/workdir/crates/tradeon-core)
[INFO] [stderr]     Checking sim v0.1.0 (/opt/rustwide/workdir/crates/sim)
[INFO] [stderr]     Checking utoipa-redoc v6.0.0
[INFO] [stderr]     Checking utoipa-axum v0.2.0
[INFO] [stderr]     Checking utoipa-scalar v0.3.0
[INFO] [stderr]     Checking utoipa-rapidoc v6.0.0
[INFO] [stderr]     Checking dyson_http v0.1.1
[INFO] [stderr]     Checking dataset v0.1.0 (/opt/rustwide/workdir/crates/dataset)
[INFO] [stdout] warning: unused import: `oneshot`
[INFO] [stdout]   --> crates/dataset/src/dataset/generic_kline.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 | use tokio::sync::{RwLock, oneshot};
[INFO] [stdout]    |                           ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `oneshot`
[INFO] [stdout]   --> crates/dataset/src/dataset/generic_kline.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 | use tokio::sync::{RwLock, oneshot};
[INFO] [stdout]    |                           ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `run_live_data` is never used
[INFO] [stdout]    --> crates/dataset/src/dataset/generic_kline.rs:104:14
[INFO] [stdout]     |
[INFO] [stdout]  89 | impl GenericKlineDataset {
[INFO] [stdout]     | ------------------------ associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 104 |     async fn run_live_data(_self: Arc<&Self>) -> anyhow::Result<u128> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEST_DATASOURCE_XML` is never used
[INFO] [stdout]    --> crates/dataset/src/dataset/generic_kline.rs:267:11
[INFO] [stdout]     |
[INFO] [stdout] 267 |     const TEST_DATASOURCE_XML: &str = r#"
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for the crate
[INFO] [stdout]  --> crates/dataset/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | / pub mod binance;
[INFO] [stdout] 2 | | pub mod dataset;
[INFO] [stdout] 3 | | pub mod domain;
[INFO] [stdout] 4 | | pub mod error;
[INFO] [stdout] 5 | | pub mod persistence;
[INFO] [stdout] 6 | | pub mod prelude;
[INFO] [stdout] 7 | | pub mod sync;
[INFO] [stdout]   | |_____________^
[INFO] [stdout]   |
[INFO] [stdout]   = note: requested on the command line with `-W missing-docs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod dataset;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub mod error;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod persistence;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:6:1
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub mod prelude;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/binance/mod.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod market;
[INFO] [stdout]   | ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub order_id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub side: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub position_side: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub quote_qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 |     pub realized_pnl: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub commission: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub commission_asset: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub time: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 44 |     pub maker: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub buyer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:49:1
[INFO] [stdout]    |
[INFO] [stdout] 49 | / pub struct FuturesBinanceClient {
[INFO] [stdout] 50 | |     account: FuturesAccount,
[INFO] [stdout] 51 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:16:1
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct OHLCVCandle(pub i64, pub f64, pub f64, pub f64, pub f64, pub f64);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:17:1
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub trait OHLCV {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     fn timestamp(&self) -> &i64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn open(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     fn high(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     fn low(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn close(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn volume(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:53:1
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub trait KlineHistory: Send + Sync {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 | /     async fn get_hist<T: Send + Sync>(
[INFO] [stdout] 55 | |         &self,
[INFO] [stdout] 56 | |         symbol: &str,
[INFO] [stdout] 57 | |         interval: &Interval,
[INFO] [stdout] ...  |
[INFO] [stdout] 62 | |     where
[INFO] [stdout] 63 | |         T: Into<Option<u64>>;
[INFO] [stdout]    | |_____________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 65 |     fn kline_limit(&self) -> u16;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stdout]    |
[INFO] [stdout] 68 | / pub enum Exchange {
[INFO] [stdout] 69 | |     BINANCE(BinanceExchange),
[INFO] [stdout] 70 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an enum
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub enum Exchange {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     BINANCE(BinanceExchange),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> crates/dataset/src/binance/market.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct BinanceExchange {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/market.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn new() -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub order_id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 31 |     pub price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub quote_qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub commission: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub commission_asset: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub time: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub is_buyer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub is_maker: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub is_best_match: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:43:1
[INFO] [stdout]    |
[INFO] [stdout] 43 | / pub struct BinanceClient {
[INFO] [stdout] 44 | |     account: Account,
[INFO] [stdout] 45 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/dataset/mod.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub mod factory;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct UniverseImpl {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub interval: Interval,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub fn ti_to_ts(&self, ti: u128) -> u128 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     pub fn ts_to_ti(&self, ts: u128) -> u128 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub fn format_path(&self) -> String {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a macro
[INFO] [stdout]  --> crates/dataset/src/dataset/factory.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | macro_rules! register_datasource {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:30:1
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn make_dataset(cfg: DatasetConfig) -> Option<Box<dyn Dataset>> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:37:1
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn build_datasource_from_xml(xml_str: &str) -> anyhow::Result<Box<dyn Dataset>> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/persistence/mod.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod error;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/persistence/mod.rs:3:1
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub mod kline_repos;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]  --> crates/dataset/src/persistence/error.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 |     Database(#[from] SqlxError),
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     DuplicateKey {
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 12 |         symbol: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |         interval: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |         time: DateTime<Utc>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     PoolExhausted,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     InvalidData(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Config(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct FuturesTradeRepo {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | /     pub async fn upsert_from_exchange(
[INFO] [stdout] 33 | |         &self,
[INFO] [stdout] 34 | |         user_id: &str,
[INFO] [stdout] 35 | |         trades: &[NewFuturesTrade],
[INFO] [stdout] 36 | |     ) -> Result<u64, DatasetError> {
[INFO] [stdout]    | |__________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:94:5
[INFO] [stdout]    |
[INFO] [stdout] 94 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<FuturesTrade>, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/futures_trade_repo.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 110 | /     pub async fn get_last_trade_time(
[INFO] [stdout] 111 | |         &self,
[INFO] [stdout] 112 | |         user_id: &str,
[INFO] [stdout] 113 | |         exchange: &str,
[INFO] [stdout] 114 | |         symbol: &str,
[INFO] [stdout] 115 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stdout]     | |____________________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub time: DateTime<Utc>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub interval: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     pub open: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     pub high: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     pub low: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     pub close: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     pub volume: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:30:1
[INFO] [stdout]    |
[INFO] [stdout] 30 | / pub struct KlineRepo {
[INFO] [stdout] 31 | |     pool: PgPool,
[INFO] [stdout] 32 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/persistence/trade_repo.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/trade_repo.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub async fn insert(&self, user_id: &str, t: &NewTrade) -> Result<i64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:112:5
[INFO] [stdout]     |
[INFO] [stdout] 112 | /     pub async fn get_trades_for_symbol(
[INFO] [stdout] 113 | |         &self,
[INFO] [stdout] 114 | |         user_id: &str,
[INFO] [stdout] 115 | |         symbol: &str,
[INFO] [stdout] 116 | |     ) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stdout]     | |_________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:133:5
[INFO] [stdout]     |
[INFO] [stdout] 133 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:149:5
[INFO] [stdout]     |
[INFO] [stdout] 149 |     pub async fn list_symbols(&self, user_id: &str) -> Result<Vec<String>, DatasetError> {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 158 | /     pub async fn get_last_trade_time(
[INFO] [stdout] 159 | |         &self,
[INFO] [stdout] 160 | |         user_id: &str,
[INFO] [stdout] 161 | |         exchange: &str,
[INFO] [stdout] 162 | |         symbol: &str,
[INFO] [stdout] 163 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stdout]     | |____________________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | /     pub fn new(
[INFO] [stdout] 21 | |         api_key: &str,
[INFO] [stdout] 22 | |         secret_key: &str,
[INFO] [stdout] 23 | |         store: TradeRepo,
[INFO] [stdout] 24 | |         symbols: Vec<String>,
[INFO] [stdout] 25 | |         user_id: String,
[INFO] [stdout] 26 | |     ) -> Self {
[INFO] [stdout]    | |_____________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:11:1
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct FuturesTradeSync {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | /     pub fn new(
[INFO] [stdout] 20 | |         api_key: &str,
[INFO] [stdout] 21 | |         secret_key: &str,
[INFO] [stdout] 22 | |         store: FuturesTradeRepo,
[INFO] [stdout] 23 | |         symbols: Vec<String>,
[INFO] [stdout] 24 | |         user_id: String,
[INFO] [stdout] 25 | |     ) -> Self {
[INFO] [stdout]    | |_____________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `run_live_data` is never used
[INFO] [stdout]    --> crates/dataset/src/dataset/generic_kline.rs:104:14
[INFO] [stdout]     |
[INFO] [stdout]  89 | impl GenericKlineDataset {
[INFO] [stdout]     | ------------------------ associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 104 |     async fn run_live_data(_self: Arc<&Self>) -> anyhow::Result<u128> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for the crate
[INFO] [stdout]  --> crates/dataset/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | / pub mod binance;
[INFO] [stdout] 2 | | pub mod dataset;
[INFO] [stdout] 3 | | pub mod domain;
[INFO] [stdout] 4 | | pub mod error;
[INFO] [stdout] 5 | | pub mod persistence;
[INFO] [stdout] 6 | | pub mod prelude;
[INFO] [stdout] 7 | | pub mod sync;
[INFO] [stdout]   | |_____________^
[INFO] [stdout]   |
[INFO] [stdout]   = note: requested on the command line with `-W missing-docs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod dataset;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub mod error;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod persistence;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:6:1
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub mod prelude;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/binance/mod.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod market;
[INFO] [stdout]   | ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub order_id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub side: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub position_side: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub quote_qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 |     pub realized_pnl: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub commission: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub commission_asset: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub time: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 44 |     pub maker: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub buyer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:49:1
[INFO] [stdout]    |
[INFO] [stdout] 49 | / pub struct FuturesBinanceClient {
[INFO] [stdout] 50 | |     account: FuturesAccount,
[INFO] [stdout] 51 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:16:1
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct OHLCVCandle(pub i64, pub f64, pub f64, pub f64, pub f64, pub f64);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:17:1
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub trait OHLCV {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     fn timestamp(&self) -> &i64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn open(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     fn high(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     fn low(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn close(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn volume(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:53:1
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub trait KlineHistory: Send + Sync {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 | /     async fn get_hist<T: Send + Sync>(
[INFO] [stdout] 55 | |         &self,
[INFO] [stdout] 56 | |         symbol: &str,
[INFO] [stdout] 57 | |         interval: &Interval,
[INFO] [stdout] ...  |
[INFO] [stdout] 62 | |     where
[INFO] [stdout] 63 | |         T: Into<Option<u64>>;
[INFO] [stdout]    | |_____________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 65 |     fn kline_limit(&self) -> u16;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stdout]    |
[INFO] [stdout] 68 | / pub enum Exchange {
[INFO] [stdout] 69 | |     BINANCE(BinanceExchange),
[INFO] [stdout] 70 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an enum
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub enum Exchange {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     BINANCE(BinanceExchange),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> crates/dataset/src/binance/market.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct BinanceExchange {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/market.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn new() -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub order_id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 31 |     pub price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub quote_qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub commission: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub commission_asset: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub time: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub is_buyer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub is_maker: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub is_best_match: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:43:1
[INFO] [stdout]    |
[INFO] [stdout] 43 | / pub struct BinanceClient {
[INFO] [stdout] 44 | |     account: Account,
[INFO] [stdout] 45 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/dataset/mod.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub mod factory;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct UniverseImpl {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub interval: Interval,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub fn ti_to_ts(&self, ti: u128) -> u128 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     pub fn ts_to_ti(&self, ts: u128) -> u128 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub fn format_path(&self) -> String {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a macro
[INFO] [stdout]  --> crates/dataset/src/dataset/factory.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | macro_rules! register_datasource {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:30:1
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn make_dataset(cfg: DatasetConfig) -> Option<Box<dyn Dataset>> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:37:1
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn build_datasource_from_xml(xml_str: &str) -> anyhow::Result<Box<dyn Dataset>> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/persistence/mod.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod error;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/persistence/mod.rs:3:1
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub mod kline_repos;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]  --> crates/dataset/src/persistence/error.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 |     Database(#[from] SqlxError),
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     DuplicateKey {
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 12 |         symbol: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |         interval: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |         time: DateTime<Utc>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     PoolExhausted,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     InvalidData(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Config(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct FuturesTradeRepo {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | /     pub async fn upsert_from_exchange(
[INFO] [stdout] 33 | |         &self,
[INFO] [stdout] 34 | |         user_id: &str,
[INFO] [stdout] 35 | |         trades: &[NewFuturesTrade],
[INFO] [stdout] 36 | |     ) -> Result<u64, DatasetError> {
[INFO] [stdout]    | |__________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:94:5
[INFO] [stdout]    |
[INFO] [stdout] 94 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<FuturesTrade>, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/futures_trade_repo.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 110 | /     pub async fn get_last_trade_time(
[INFO] [stdout] 111 | |         &self,
[INFO] [stdout] 112 | |         user_id: &str,
[INFO] [stdout] 113 | |         exchange: &str,
[INFO] [stdout] 114 | |         symbol: &str,
[INFO] [stdout] 115 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stdout]     | |____________________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub time: DateTime<Utc>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub interval: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     pub open: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     pub high: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     pub low: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     pub close: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     pub volume: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:30:1
[INFO] [stdout]    |
[INFO] [stdout] 30 | / pub struct KlineRepo {
[INFO] [stdout] 31 | |     pool: PgPool,
[INFO] [stdout] 32 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/persistence/trade_repo.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/trade_repo.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub async fn insert(&self, user_id: &str, t: &NewTrade) -> Result<i64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:112:5
[INFO] [stdout]     |
[INFO] [stdout] 112 | /     pub async fn get_trades_for_symbol(
[INFO] [stdout] 113 | |         &self,
[INFO] [stdout] 114 | |         user_id: &str,
[INFO] [stdout] 115 | |         symbol: &str,
[INFO] [stdout] 116 | |     ) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stdout]     | |_________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:133:5
[INFO] [stdout]     |
[INFO] [stdout] 133 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:149:5
[INFO] [stdout]     |
[INFO] [stdout] 149 |     pub async fn list_symbols(&self, user_id: &str) -> Result<Vec<String>, DatasetError> {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 158 | /     pub async fn get_last_trade_time(
[INFO] [stdout] 159 | |         &self,
[INFO] [stdout] 160 | |         user_id: &str,
[INFO] [stdout] 161 | |         exchange: &str,
[INFO] [stdout] 162 | |         symbol: &str,
[INFO] [stdout] 163 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stdout]     | |____________________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | /     pub fn new(
[INFO] [stdout] 21 | |         api_key: &str,
[INFO] [stdout] 22 | |         secret_key: &str,
[INFO] [stdout] 23 | |         store: TradeRepo,
[INFO] [stdout] 24 | |         symbols: Vec<String>,
[INFO] [stdout] 25 | |         user_id: String,
[INFO] [stdout] 26 | |     ) -> Self {
[INFO] [stdout]    | |_____________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:11:1
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct FuturesTradeSync {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | /     pub fn new(
[INFO] [stdout] 20 | |         api_key: &str,
[INFO] [stdout] 21 | |         secret_key: &str,
[INFO] [stdout] 22 | |         store: FuturesTradeRepo,
[INFO] [stdout] 23 | |         symbols: Vec<String>,
[INFO] [stdout] 24 | |         user_id: String,
[INFO] [stdout] 25 | |     ) -> Self {
[INFO] [stdout]    | |_____________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking portfolio v0.1.0 (/opt/rustwide/workdir/crates/portfolio)
[INFO] [stderr]     Checking strategy v0.1.0 (/opt/rustwide/workdir/crates/strategy)
[INFO] [stderr]     Checking my_first_strategy v0.1.0 (/opt/rustwide/workdir/crates/my_first_strategy)
[INFO] [stdout] warning: function `crossover` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:551:4
[INFO] [stdout]     |
[INFO] [stdout] 551 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossunder` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:565:4
[INFO] [stdout]     |
[INFO] [stdout] 565 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `export_tradingview_html` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/html_visualizer.rs:361:15
[INFO] [stdout]     |
[INFO] [stdout] 361 | pub(super) fn export_tradingview_html(
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for the crate
[INFO] [stdout]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | / pub mod indicator;
[INFO] [stdout] 2 | | pub mod strategy;
[INFO] [stdout]   | |_________________^
[INFO] [stdout]   |
[INFO] [stdout]   = note: requested on the command line with `-W missing-docs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod indicator;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/strategy/src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod strategy;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 67 |     pub open: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub high: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub low: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:70:5
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub close: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub volume: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:161:5
[INFO] [stdout]     |
[INFO] [stdout] 161 |     pub ma: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:162:5
[INFO] [stdout]     |
[INFO] [stdout] 162 |     pub ma_trend_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:163:5
[INFO] [stdout]     |
[INFO] [stdout] 163 |     pub ma_trend_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:166:5
[INFO] [stdout]     |
[INFO] [stdout] 166 |     pub top_fractals: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:167:5
[INFO] [stdout]     |
[INFO] [stdout] 167 |     pub bot_fractals: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub macd_line: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:171:5
[INFO] [stdout]     |
[INFO] [stdout] 171 |     pub macd_signal: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:172:5
[INFO] [stdout]     |
[INFO] [stdout] 172 |     pub macd_hist: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub macd_color_green: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:176:5
[INFO] [stdout]     |
[INFO] [stdout] 176 |     pub bearish_pinbar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:177:5
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub bullish_pinbar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:178:5
[INFO] [stdout]     |
[INFO] [stdout] 178 |     pub dark_cloud_cover: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:179:5
[INFO] [stdout]     |
[INFO] [stdout] 179 |     pub piercing_line: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:180:5
[INFO] [stdout]     |
[INFO] [stdout] 180 |     pub bearish_harami: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:181:5
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub bullish_harami: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:182:5
[INFO] [stdout]     |
[INFO] [stdout] 182 |     pub bearish_engulfing: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:183:5
[INFO] [stdout]     |
[INFO] [stdout] 183 |     pub bullish_engulfing: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:184:5
[INFO] [stdout]     |
[INFO] [stdout] 184 |     pub bearish_fractal_cross: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:185:5
[INFO] [stdout]     |
[INFO] [stdout] 185 |     pub bullish_fractal_cross: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:188:5
[INFO] [stdout]     |
[INFO] [stdout] 188 |     pub reversal_pinbar_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:189:5
[INFO] [stdout]     |
[INFO] [stdout] 189 |     pub reversal_pinbar_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:190:5
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub shaved_bar_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:191:5
[INFO] [stdout]     |
[INFO] [stdout] 191 |     pub shaved_bar_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:192:5
[INFO] [stdout]     |
[INFO] [stdout] 192 |     pub inside_bar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:193:5
[INFO] [stdout]     |
[INFO] [stdout] 193 |     pub outside_bar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:196:5
[INFO] [stdout]     |
[INFO] [stdout] 196 |     pub bar_color_up: Vec<bool>,   // Lime - confirmed bullish
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:197:5
[INFO] [stdout]     |
[INFO] [stdout] 197 |     pub bar_color_down: Vec<bool>, // Maroon - confirmed bearish
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:200:5
[INFO] [stdout]     |
[INFO] [stdout] 200 |     pub bar_alert: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:201:5
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub bar_alert_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:202:5
[INFO] [stdout]     |
[INFO] [stdout] 202 |     pub bar_alert_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]     --> crates/strategy/src/indicator/cds_trend.rs:1017:1
[INFO] [stdout]      |
[INFO] [stdout] 1017 | / pub fn write_html_visualization(
[INFO] [stdout] 1018 | |     path: &str,
[INFO] [stdout] 1019 | |     candles: &[Candle],
[INFO] [stdout] 1020 | |     out: &CdsTrendOutput,
[INFO] [stdout] 1021 | | ) -> std::io::Result<()> {
[INFO] [stdout]      | |________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]  --> crates/strategy/src/strategy.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub trait Strategy {}
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossover` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:551:4
[INFO] [stdout]     |
[INFO] [stdout] 551 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossunder` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:565:4
[INFO] [stdout]     |
[INFO] [stdout] 565 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `export_tradingview_html` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/html_visualizer.rs:361:15
[INFO] [stdout]     |
[INFO] [stdout] 361 | pub(super) fn export_tradingview_html(
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for the crate
[INFO] [stdout]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | / pub mod indicator;
[INFO] [stdout] 2 | | pub mod strategy;
[INFO] [stdout]   | |_________________^
[INFO] [stdout]   |
[INFO] [stdout]   = note: requested on the command line with `-W missing-docs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod indicator;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/strategy/src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod strategy;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 67 |     pub open: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub high: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub low: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:70:5
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub close: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub volume: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:161:5
[INFO] [stdout]     |
[INFO] [stdout] 161 |     pub ma: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:162:5
[INFO] [stdout]     |
[INFO] [stdout] 162 |     pub ma_trend_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:163:5
[INFO] [stdout]     |
[INFO] [stdout] 163 |     pub ma_trend_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:166:5
[INFO] [stdout]     |
[INFO] [stdout] 166 |     pub top_fractals: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:167:5
[INFO] [stdout]     |
[INFO] [stdout] 167 |     pub bot_fractals: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub macd_line: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:171:5
[INFO] [stdout]     |
[INFO] [stdout] 171 |     pub macd_signal: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:172:5
[INFO] [stdout]     |
[INFO] [stdout] 172 |     pub macd_hist: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub macd_color_green: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:176:5
[INFO] [stdout]     |
[INFO] [stdout] 176 |     pub bearish_pinbar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:177:5
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub bullish_pinbar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:178:5
[INFO] [stdout]     |
[INFO] [stdout] 178 |     pub dark_cloud_cover: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:179:5
[INFO] [stdout]     |
[INFO] [stdout] 179 |     pub piercing_line: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:180:5
[INFO] [stdout]     |
[INFO] [stdout] 180 |     pub bearish_harami: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:181:5
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub bullish_harami: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:182:5
[INFO] [stdout]     |
[INFO] [stdout] 182 |     pub bearish_engulfing: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:183:5
[INFO] [stdout]     |
[INFO] [stdout] 183 |     pub bullish_engulfing: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:184:5
[INFO] [stdout]     |
[INFO] [stdout] 184 |     pub bearish_fractal_cross: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:185:5
[INFO] [stdout]     |
[INFO] [stdout] 185 |     pub bullish_fractal_cross: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:188:5
[INFO] [stdout]     |
[INFO] [stdout] 188 |     pub reversal_pinbar_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:189:5
[INFO] [stdout]     |
[INFO] [stdout] 189 |     pub reversal_pinbar_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:190:5
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub shaved_bar_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:191:5
[INFO] [stdout]     |
[INFO] [stdout] 191 |     pub shaved_bar_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:192:5
[INFO] [stdout]     |
[INFO] [stdout] 192 |     pub inside_bar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:193:5
[INFO] [stdout]     |
[INFO] [stdout] 193 |     pub outside_bar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:196:5
[INFO] [stdout]     |
[INFO] [stdout] 196 |     pub bar_color_up: Vec<bool>,   // Lime - confirmed bullish
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:197:5
[INFO] [stdout]     |
[INFO] [stdout] 197 |     pub bar_color_down: Vec<bool>, // Maroon - confirmed bearish
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:200:5
[INFO] [stdout]     |
[INFO] [stdout] 200 |     pub bar_alert: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:201:5
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub bar_alert_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:202:5
[INFO] [stdout]     |
[INFO] [stdout] 202 |     pub bar_alert_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]     --> crates/strategy/src/indicator/cds_trend.rs:1017:1
[INFO] [stdout]      |
[INFO] [stdout] 1017 | / pub fn write_html_visualization(
[INFO] [stdout] 1018 | |     path: &str,
[INFO] [stdout] 1019 | |     candles: &[Candle],
[INFO] [stdout] 1020 | |     out: &CdsTrendOutput,
[INFO] [stdout] 1021 | | ) -> std::io::Result<()> {
[INFO] [stdout]      | |________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]  --> crates/strategy/src/strategy.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub trait Strategy {}
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CdsTrendOutput` is never constructed
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:162:19
[INFO] [stdout]     |
[INFO] [stdout] 162 | pub(crate) struct CdsTrendOutput {
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:213:4
[INFO] [stdout]     |
[INFO] [stdout] 213 | fn sma(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `ema` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:234:4
[INFO] [stdout]     |
[INFO] [stdout] 234 | fn ema(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `wma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:253:4
[INFO] [stdout]     |
[INFO] [stdout] 253 | fn wma(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `vwma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:274:4
[INFO] [stdout]     |
[INFO] [stdout] 274 | fn vwma(candles: &[Candle], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `smma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:297:4
[INFO] [stdout]     |
[INFO] [stdout] 297 | fn smma(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dema` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:321:4
[INFO] [stdout]     |
[INFO] [stdout] 321 | fn dema(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tema` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:337:4
[INFO] [stdout]     |
[INFO] [stdout] 337 | fn tema(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hull_ma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:355:4
[INFO] [stdout]     |
[INFO] [stdout] 355 | fn hull_ma(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `zema` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:379:4
[INFO] [stdout]     |
[INFO] [stdout] 379 | fn zema(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:395:4
[INFO] [stdout]     |
[INFO] [stdout] 395 | fn tma(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `variant` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:402:4
[INFO] [stdout]     |
[INFO] [stdout] 402 | fn variant(
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `detect_fractals` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:429:4
[INFO] [stdout]     |
[INFO] [stdout] 429 | fn detect_fractals(candles: &[Candle]) -> (Vec<Option<f64>>, Vec<Option<f64>>) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_macd` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:488:4
[INFO] [stdout]     |
[INFO] [stdout] 488 | fn calculate_macd(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `lowest` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:530:4
[INFO] [stdout]     |
[INFO] [stdout] 530 | fn lowest(candles: &[Candle], end_idx: usize, length: usize) -> f64 {
[INFO] [stdout]     |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `highest` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:542:4
[INFO] [stdout]     |
[INFO] [stdout] 542 | fn highest(candles: &[Candle], end_idx: usize, length: usize) -> f64 {
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossover` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:554:4
[INFO] [stdout]     |
[INFO] [stdout] 554 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossunder` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:568:4
[INFO] [stdout]     |
[INFO] [stdout] 568 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `detect_patterns` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:587:4
[INFO] [stdout]     |
[INFO] [stdout] 587 | fn detect_patterns(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_cds_trend` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:836:15
[INFO] [stdout]     |
[INFO] [stdout] 836 | pub(crate) fn run_cds_trend(candles: &[Candle], config: &CdsTrendConfig) -> CdsTrendOutput {
[INFO] [stdout]     |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `length` is never read
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1023:5
[INFO] [stdout]      |
[INFO] [stdout] 1022 | struct EmaState {
[INFO] [stdout]      |        -------- field in this struct
[INFO] [stdout] 1023 |     length: usize,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `EmaState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `length` and `buffer` are never read
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1118:5
[INFO] [stdout]      |
[INFO] [stdout] 1117 | struct HullMaState {
[INFO] [stdout]      |        ----------- fields in this struct
[INFO] [stdout] 1118 |     length: usize,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1122 |     buffer: VecDeque<f64>,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `HullMaState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `reset` is never used
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1674:19
[INFO] [stdout]      |
[INFO] [stdout] 1294 | impl CdsTrendStream {
[INFO] [stdout]      | ------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1674 |     pub(crate) fn reset(&mut self) {
[INFO] [stdout]      |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/my_first_strategy/src/main.rs:36:1
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct MyChannelHub {}
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/my_first_strategy/src/main.rs:39:1
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct Payload {}
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking api v0.1.0 (/opt/rustwide/workdir/crates/api)
[INFO] [stdout] warning: function `crossover` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:554:4
[INFO] [stdout]     |
[INFO] [stdout] 554 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossunder` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:568:4
[INFO] [stdout]     |
[INFO] [stdout] 568 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `length` is never read
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1023:5
[INFO] [stdout]      |
[INFO] [stdout] 1022 | struct EmaState {
[INFO] [stdout]      |        -------- field in this struct
[INFO] [stdout] 1023 |     length: usize,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `EmaState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `length` and `buffer` are never read
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1118:5
[INFO] [stdout]      |
[INFO] [stdout] 1117 | struct HullMaState {
[INFO] [stdout]      |        ----------- fields in this struct
[INFO] [stdout] 1118 |     length: usize,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1122 |     buffer: VecDeque<f64>,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `HullMaState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `reset` is never used
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1674:19
[INFO] [stdout]      |
[INFO] [stdout] 1294 | impl CdsTrendStream {
[INFO] [stdout]      | ------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1674 |     pub(crate) fn reset(&mut self) {
[INFO] [stdout]      |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/my_first_strategy/src/main.rs:36:1
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct MyChannelHub {}
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/my_first_strategy/src/main.rs:39:1
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct Payload {}
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:10:33
[INFO] [stdout]    |
[INFO] [stdout] 10 |     let key = Key::<Aes256Gcm>::from_slice(key);
[INFO] [stdout]    |                                 ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:33:33
[INFO] [stdout]    |
[INFO] [stdout] 33 |     let key = Key::<Aes256Gcm>::from_slice(key);
[INFO] [stdout]    |                                 ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:35:24
[INFO] [stdout]    |
[INFO] [stdout] 35 |     let nonce = Nonce::from_slice(nonce_bytes);
[INFO] [stdout]    |                        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:10:33
[INFO] [stdout]    |
[INFO] [stdout] 10 |     let key = Key::<Aes256Gcm>::from_slice(key);
[INFO] [stdout]    |                                 ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:33:33
[INFO] [stdout]    |
[INFO] [stdout] 33 |     let key = Key::<Aes256Gcm>::from_slice(key);
[INFO] [stdout]    |                                 ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:35:24
[INFO] [stdout]    |
[INFO] [stdout] 35 |     let nonce = Nonce::from_slice(nonce_bytes);
[INFO] [stdout]    |                        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `decrypt` is never used
[INFO] [stdout]   --> crates/api/src/crypto.rs:23:15
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub(crate) fn decrypt(encrypted: &str, key: &[u8]) -> Result<String, String> {
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `decrypt` is never used
[INFO] [stdout]   --> crates/api/src/crypto.rs:23:15
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub(crate) fn decrypt(encrypted: &str, key: &[u8]) -> Result<String, String> {
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 13s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: binance-rs-async v1.3.3
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] running `Command { std: "docker" "inspect" "09868de4fed94ae6d125017ff4c0e51d59b78923dc6003200f9d0cd160485352", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "09868de4fed94ae6d125017ff4c0e51d59b78923dc6003200f9d0cd160485352", kill_on_drop: false }`
[INFO] [stdout] 09868de4fed94ae6d125017ff4c0e51d59b78923dc6003200f9d0cd160485352
