[INFO] cloning repository https://github.com/yutiansut/quantaxis-rs [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/yutiansut/quantaxis-rs" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fyutiansut%2Fquantaxis-rs", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fyutiansut%2Fquantaxis-rs'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 4d4399bacf08bb286f98e181602cca104eb14a1f [INFO] testing yutiansut/quantaxis-rs against try#613d1972a772987ed4ee06faccbab0e2fc839871+rustflags=-Copt-level=3 for pr-107051 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fyutiansut%2Fquantaxis-rs" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/yutiansut/quantaxis-rs on toolchain 613d1972a772987ed4ee06faccbab0e2fc839871 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+613d1972a772987ed4ee06faccbab0e2fc839871" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/yutiansut/quantaxis-rs [INFO] finished tweaking git repo https://github.com/yutiansut/quantaxis-rs [INFO] tweaked toml for git repo https://github.com/yutiansut/quantaxis-rs written to /workspace/builds/worker-1-tc2/source/Cargo.toml [INFO] crate git repo https://github.com/yutiansut/quantaxis-rs 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" "+613d1972a772987ed4ee06faccbab0e2fc839871" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7c93e6f9a94679f34221d1005849d4c83862f85b14a264fa0883942f4d043a66" "/opt/rustwide/cargo-home/bin/cargo" "+613d1972a772987ed4ee06faccbab0e2fc839871" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] cc183653a884fbaac7022997f0cafefa094ff473bb54275d4b85e9fb698cf952 [INFO] running `Command { std: "docker" "start" "-a" "cc183653a884fbaac7022997f0cafefa094ff473bb54275d4b85e9fb698cf952", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "cc183653a884fbaac7022997f0cafefa094ff473bb54275d4b85e9fb698cf952", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cc183653a884fbaac7022997f0cafefa094ff473bb54275d4b85e9fb698cf952", kill_on_drop: false }` [INFO] [stdout] cc183653a884fbaac7022997f0cafefa094ff473bb54275d4b85e9fb698cf952 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-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:7c93e6f9a94679f34221d1005849d4c83862f85b14a264fa0883942f4d043a66" "/opt/rustwide/cargo-home/bin/cargo" "+613d1972a772987ed4ee06faccbab0e2fc839871" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 27c78736a64af3f3f4ba9c83bfec836cd3ee10b2e58e590c2b7d109f8b1dbc4d [INFO] running `Command { std: "docker" "start" "-a" "27c78736a64af3f3f4ba9c83bfec836cd3ee10b2e58e590c2b7d109f8b1dbc4d", kill_on_drop: false }` [INFO] [stderr] Compiling syn v1.0.60 [INFO] [stderr] Compiling libc v0.2.86 [INFO] [stderr] Compiling memchr v2.3.4 [INFO] [stderr] Compiling once_cell v1.6.0 [INFO] [stderr] Compiling num-traits v0.2.14 [INFO] [stderr] Compiling value-bag v1.0.0-alpha.6 [INFO] [stderr] Compiling log v0.4.14 [INFO] [stderr] Compiling futures-core v0.3.12 [INFO] [stderr] Compiling num-integer v0.1.44 [INFO] [stderr] Compiling futures-io v0.3.12 [INFO] [stderr] Compiling slab v0.4.2 [INFO] [stderr] Compiling serde_derive v1.0.123 [INFO] [stderr] Compiling serde v1.0.123 [INFO] [stderr] Compiling quote v1.0.9 [INFO] [stderr] Compiling byteorder v1.4.2 [INFO] [stderr] Compiling generic-array v0.12.3 [INFO] [stderr] Compiling crossbeam-utils v0.8.2 [INFO] [stderr] Compiling proc-macro-hack v0.5.19 [INFO] [stderr] Compiling cc v1.0.67 [INFO] [stderr] Compiling rand_core v0.4.2 [INFO] [stderr] Compiling cache-padded v1.1.1 [INFO] [stderr] Compiling futures-sink v0.3.12 [INFO] [stderr] Compiling autocfg v0.1.7 [INFO] [stderr] Compiling proc-macro-nested v0.1.7 [INFO] [stderr] Compiling tinyvec_macros v0.1.0 [INFO] [stderr] Compiling matches v0.1.8 [INFO] [stderr] Compiling tinyvec v1.1.1 [INFO] [stderr] Compiling concurrent-queue v1.2.2 [INFO] [stderr] Compiling event-listener v2.5.1 [INFO] [stderr] Compiling waker-fn v1.1.0 [INFO] [stderr] Compiling pin-utils v0.1.0 [INFO] [stderr] Compiling spin v0.5.2 [INFO] [stderr] Compiling parking v2.0.0 [INFO] [stderr] Compiling fastrand v1.4.0 [INFO] [stderr] Compiling untrusted v0.7.1 [INFO] [stderr] Compiling unicode-bidi v0.3.4 [INFO] [stderr] Compiling futures-channel v0.3.12 [INFO] [stderr] Compiling futures-task v0.3.12 [INFO] [stderr] Compiling futures-lite v1.11.3 [INFO] [stderr] Compiling rustversion v1.0.4 [INFO] [stderr] Compiling pin-project-lite v0.1.11 [INFO] [stderr] Compiling byte-tools v0.3.1 [INFO] [stderr] Compiling bytes v0.5.6 [INFO] [stderr] Compiling num_cpus v1.13.0 [INFO] [stderr] Compiling getrandom v0.1.16 [INFO] [stderr] Compiling net2 v0.2.37 [INFO] [stderr] Compiling iovec v0.1.4 [INFO] [stderr] Compiling rand_core v0.5.1 [INFO] [stderr] Compiling signal-hook-registry v1.3.0 [INFO] [stderr] Compiling block-padding v0.1.5 [INFO] [stderr] Compiling rand_pcg v0.2.1 [INFO] [stderr] Compiling rand_chacha v0.2.2 [INFO] [stderr] Compiling socket2 v0.3.19 [INFO] [stderr] Compiling digest v0.8.1 [INFO] [stderr] Compiling indexmap v1.6.1 [INFO] [stderr] Compiling getrandom v0.2.2 [INFO] [stderr] Compiling unicode-segmentation v1.7.1 [INFO] [stderr] Compiling itoa v0.4.7 [INFO] [stderr] Compiling unicode-normalization v0.1.17 [INFO] [stderr] Compiling percent-encoding v2.1.0 [INFO] [stderr] Compiling vec-arena v1.0.0 [INFO] [stderr] Compiling async-task v4.0.3 [INFO] [stderr] Compiling heck v0.3.2 [INFO] [stderr] Compiling form_urlencoded v1.0.1 [INFO] [stderr] Compiling backtrace v0.3.56 [INFO] [stderr] Compiling nb-connect v1.0.3 [INFO] [stderr] Compiling rand v0.7.3 [INFO] [stderr] Compiling block-buffer v0.7.3 [INFO] [stderr] Compiling async-channel v1.6.1 [INFO] [stderr] Compiling rand_core v0.3.1 [INFO] [stderr] Compiling num-complex v0.2.4 [INFO] [stderr] Compiling num-iter v0.1.42 [INFO] [stderr] Compiling match_cfg v0.1.0 [INFO] [stderr] Compiling subtle v1.0.0 [INFO] [stderr] Compiling rustc-serialize v0.3.24 [INFO] [stderr] Compiling linked-hash-map v0.5.4 [INFO] [stderr] Compiling atomic-waker v1.0.0 [INFO] [stderr] Compiling serde_json v1.0.62 [INFO] [stderr] Compiling opaque-debug v0.2.3 [INFO] [stderr] Compiling blocking v1.0.2 [INFO] [stderr] Compiling crypto-mac v0.7.0 [INFO] [stderr] Compiling hostname v0.3.1 [INFO] [stderr] Compiling proc-macro-error-attr v1.0.4 [INFO] [stderr] Compiling idna v0.2.2 [INFO] [stderr] Compiling async-executor v1.4.0 [INFO] [stderr] Compiling time v0.1.44 [INFO] [stderr] Compiling rand v0.4.6 [INFO] [stderr] Compiling async-mutex v1.4.0 [INFO] [stderr] Compiling url v2.2.1 [INFO] [stderr] Compiling num-bigint v0.2.6 [INFO] [stderr] Compiling quick-error v1.2.3 [INFO] [stderr] Compiling fake-simd v0.1.2 [INFO] [stderr] Compiling base64 v0.11.0 [INFO] [stderr] Compiling crossbeam-epoch v0.9.2 [INFO] [stderr] Compiling resolv-conf v0.7.0 [INFO] [stderr] Compiling chrono v0.4.19 [INFO] [stderr] Compiling lru-cache v0.1.2 [INFO] [stderr] Compiling rand_chacha v0.1.1 [INFO] [stderr] Compiling rand_pcg v0.1.2 [INFO] [stderr] Compiling async-lock v2.3.0 [INFO] [stderr] Compiling regex-automata v0.1.9 [INFO] [stderr] Compiling num-rational v0.2.4 [INFO] [stderr] Compiling base64 v0.12.3 [INFO] [stderr] Compiling ndarray v0.13.1 [INFO] [stderr] Compiling rawpointer v0.2.1 [INFO] [stderr] Compiling matrixmultiply v0.2.4 [INFO] [stderr] Compiling crossbeam-deque v0.8.0 [INFO] [stderr] Compiling sha-1 v0.8.2 [INFO] [stderr] Compiling sha2 v0.8.2 [INFO] [stderr] Compiling err-derive v0.2.4 [INFO] [stderr] Compiling darling_core v0.12.1 [INFO] [stderr] Compiling proc-macro-error v1.0.4 [INFO] [stderr] Compiling synstructure v0.12.4 [INFO] [stderr] Compiling num-bigint v0.1.44 [INFO] [stderr] Compiling num-complex v0.1.43 [INFO] [stderr] Compiling stringprep v0.1.2 [INFO] [stderr] Compiling pbkdf2 v0.3.0 [INFO] [stderr] Compiling hmac v0.7.1 [INFO] [stderr] Compiling md-5 v0.8.0 [INFO] [stderr] Compiling rand v0.6.5 [INFO] [stderr] Compiling num-rational v0.1.42 [INFO] [stderr] Compiling crossbeam-channel v0.5.0 [INFO] [stderr] Compiling csv-core v0.1.10 [INFO] [stderr] Compiling ring v0.16.20 [INFO] [stderr] Compiling error-chain v0.12.4 [INFO] [stderr] Compiling either v1.6.1 [INFO] [stderr] Compiling take_mut v0.2.2 [INFO] [stderr] Compiling rayon-core v1.9.0 [INFO] [stderr] Compiling num v0.1.42 [INFO] [stderr] Compiling rand_xorshift v0.1.1 [INFO] [stderr] Compiling rand_isaac v0.1.1 [INFO] [stderr] Compiling rand_hc v0.1.0 [INFO] [stderr] Compiling rand_os v0.1.3 [INFO] [stderr] Compiling aho-corasick v0.7.15 [INFO] [stderr] Compiling rand_jitter v0.1.4 [INFO] [stderr] Compiling thread_local v1.1.3 [INFO] [stderr] Compiling regex-syntax v0.6.22 [INFO] [stderr] Compiling rayon v1.5.0 [INFO] [stderr] Compiling num v0.2.1 [INFO] [stderr] Compiling stopwatch v0.0.7 [INFO] [stderr] Compiling float-cmp v0.4.0 [INFO] [stderr] Compiling bencher v0.1.5 [INFO] [stderr] Compiling regex v1.4.3 [INFO] [stderr] Compiling webpki v0.21.4 [INFO] [stderr] Compiling sct v0.6.0 [INFO] [stderr] Compiling webpki-roots v0.18.0 [INFO] [stderr] Compiling ctor v0.1.19 [INFO] [stderr] Compiling tokio-macros v0.2.6 [INFO] [stderr] Compiling futures-macro v0.3.12 [INFO] [stderr] Compiling thiserror-impl v1.0.24 [INFO] [stderr] Compiling darling_macro v0.12.1 [INFO] [stderr] Compiling enum-as-inner v0.3.3 [INFO] [stderr] Compiling async-trait v0.1.42 [INFO] [stderr] Compiling async-attributes v1.1.2 [INFO] [stderr] Compiling derivative v2.2.0 [INFO] [stderr] Compiling typed-builder v0.4.1 [INFO] [stderr] Compiling darling v0.12.1 [INFO] [stderr] Compiling serde_with_macros v1.4.1 [INFO] [stderr] Compiling mio v0.6.23 [INFO] [stderr] Compiling polling v2.0.2 [INFO] [stderr] Compiling mio-uds v0.6.8 [INFO] [stderr] Compiling thiserror v1.0.24 [INFO] [stderr] Compiling async-io v1.3.1 [INFO] [stderr] Compiling rustls v0.17.0 [INFO] [stderr] Compiling kv-log-macro v1.0.7 [INFO] [stderr] Compiling os_info v3.0.1 [INFO] [stderr] Compiling tokio v0.2.25 [INFO] [stderr] Compiling futures-util v0.3.12 [INFO] [stderr] Compiling async-global-executor v2.0.2 [INFO] [stderr] Compiling async-std v1.9.0 [INFO] [stderr] Compiling futures-executor v0.3.12 [INFO] [stderr] Compiling futures v0.3.12 [INFO] [stderr] Compiling tokio-rustls v0.13.1 [INFO] [stderr] Compiling tokio-util v0.3.1 [INFO] [stderr] Compiling trust-dns-proto v0.19.6 [INFO] [stderr] Compiling trust-dns-resolver v0.19.6 [INFO] [stderr] Compiling uuid v0.8.2 [INFO] [stderr] Compiling bstr v0.2.15 [INFO] [stderr] Compiling serde_with v1.6.4 [INFO] [stderr] Compiling serde_bytes v0.10.5 [INFO] [stderr] Compiling csv v1.1.5 [INFO] [stderr] Compiling bson v1.2.0 [INFO] [stderr] Compiling ndarray-csv v0.4.1 [INFO] [stderr] Compiling mongodb v1.2.0 [INFO] [stderr] Compiling qifi-rs v0.3.0 [INFO] [stderr] Compiling quantaxis-rs v0.3.4 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `std::f64::NAN` [INFO] [stdout] --> src/indicators/moving_average.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::f64::NAN; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/qaaccount.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qaaccount.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::format::ParseError` [INFO] [stdout] --> src/qaaccount.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use chrono::format::ParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stdout] --> src/qaaccount.rs:7:14 [INFO] [stdout] | [INFO] [stdout] 7 | use chrono::{DateTime, FixedOffset, Local, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/qaaccount.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `CodePreset` [INFO] [stdout] --> src/qaaccount.rs:15:28 [INFO] [stdout] | [INFO] [stdout] 15 | use crate::market_preset::{CodePreset, MarketPreset}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaposition` [INFO] [stdout] --> src/qaaccount.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | use crate::qaposition; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account_info` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:56:12 [INFO] [stdout] | [INFO] [stdout] 56 | pub struct account_info { [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `AccountInfo` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:63:12 [INFO] [stdout] | [INFO] [stdout] 63 | pub struct account { [INFO] [stdout] | ^^^^^^^ help: convert the identifier to upper camel case: `Account` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:105:12 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to upper camel case: `QaAccount` [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/qaaccount.rs:103:8 [INFO] [stdout] | [INFO] [stdout] 103 | #[warn(non_camel_case_types)] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:886:23 [INFO] [stdout] | [INFO] [stdout] 886 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 886 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 886 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:959:23 [INFO] [stdout] | [INFO] [stdout] 959 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 959 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 959 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ndarray::array` [INFO] [stdout] --> src/qadata.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use ndarray::array; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/qafetch.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qafetch.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::process` [INFO] [stdout] --> src/qafetch.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::process; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaorder::QAOrder` [INFO] [stdout] --> src/qaposition.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::qaorder::QAOrder; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Frozen` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct QA_Frozen { [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to upper camel case: `QaFrozen` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Postions` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:22:12 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct QA_Postions { [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaPostions` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:237:33 [INFO] [stdout] | [INFO] [stdout] 237 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 237 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 237 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:240:34 [INFO] [stdout] | [INFO] [stdout] 240 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 240 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 240 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:246:33 [INFO] [stdout] | [INFO] [stdout] 246 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 246 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 246 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:249:34 [INFO] [stdout] | [INFO] [stdout] 249 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 249 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 249 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `Offset` [INFO] [stdout] --> src/transaction.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Offset, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/transaction.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stdout] --> src/qaperformance.rs:3:14 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, FixedOffset, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::format::ParseError` [INFO] [stdout] --> src/qaperformance.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use chrono::format::ParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QAPerformance_Single` should have an upper camel case name [INFO] [stdout] --> src/qaperformance.rs:43:12 [INFO] [stdout] | [INFO] [stdout] 43 | pub struct QAPerformance_Single { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaperformanceSingle` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/trade_date.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Index` [INFO] [stdout] --> src/trade_date.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::ops::Index; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/trade_date.rs:941:19 [INFO] [stdout] | [INFO] [stdout] 941 | let day = (date - year * 10000 - month * 100); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 941 - let day = (date - year * 10000 - month * 100); [INFO] [stdout] 941 + let day = date - year * 10000 - month * 100; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:43:17 [INFO] [stdout] | [INFO] [stdout] 42 | prev => (input - prev).abs(), [INFO] [stdout] | ---- matches any value [INFO] [stdout] 43 | _ => 0.0 [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:65:17 [INFO] [stdout] | [INFO] [stdout] 64 | prev => (input - prev).abs(), [INFO] [stdout] | ---- matches any value [INFO] [stdout] 65 | _ => 0.0 [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:92:17 [INFO] [stdout] | [INFO] [stdout] 86 | prev_close => { [INFO] [stdout] | ---------- matches any value [INFO] [stdout] ... [INFO] [stdout] 92 | _ => bar.high() - bar.low(), [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:115:17 [INFO] [stdout] | [INFO] [stdout] 109 | prev_close => { [INFO] [stdout] | ---------- matches any value [INFO] [stdout] ... [INFO] [stdout] 115 | _ => bar.high() - bar.low(), [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `order_id` [INFO] [stdout] --> src/qaaccount.rs:723:9 [INFO] [stdout] | [INFO] [stdout] 723 | order_id: &str, [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_order_id` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `realorder_id` [INFO] [stdout] --> src/qaaccount.rs:856:9 [INFO] [stdout] | [INFO] [stdout] 856 | realorder_id: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_realorder_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:980:17 [INFO] [stdout] | [INFO] [stdout] 980 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:991:17 [INFO] [stdout] | [INFO] [stdout] 991 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:999:17 [INFO] [stdout] | [INFO] [stdout] 999 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:1014:17 [INFO] [stdout] | [INFO] [stdout] 1014 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaaccount.rs:269:13 [INFO] [stdout] | [INFO] [stdout] 269 | let mut acc = Self { [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:91:13 [INFO] [stdout] | [INFO] [stdout] 91 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:154:13 [INFO] [stdout] | [INFO] [stdout] 154 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `length` is never read [INFO] [stdout] --> src/indicators/average_true_range.rs:32:5 [INFO] [stdout] | [INFO] [stdout] 29 | pub struct AverageTrueRange { [INFO] [stdout] | ---------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 32 | length: usize, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AverageTrueRange` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/qaaccount.rs:107:5 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ---------- fields in this struct [INFO] [stdout] 106 | init_cash: f64, [INFO] [stdout] 107 | init_hold: HashMap, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 108 | [INFO] [stdout] 109 | allow_t0: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 110 | allow_sellopen: bool, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 111 | allow_margin: bool, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 112 | [INFO] [stdout] 113 | auto_reload: bool, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 114 | market_preset: MarketPreset, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 132 | commission_ratio: f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 133 | // 手续费率 [INFO] [stdout] 134 | tax_ratio: f64, // tax for qaaccount [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `QA_Account` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `main` is never used [INFO] [stdout] --> src/qadata.rs:73:4 [INFO] [stdout] | [INFO] [stdout] 73 | fn main() { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `message` is never used [INFO] [stdout] --> src/qaposition.rs:79:19 [INFO] [stdout] | [INFO] [stdout] 79 | pub(crate) fn message(&self) { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `WithdrawQuota` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:74:9 [INFO] [stdout] | [INFO] [stdout] 74 | pub WithdrawQuota: f64, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `withdraw_quota` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_codeSubscribed` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:518:12 [INFO] [stdout] | [INFO] [stdout] 518 | pub fn get_codeSubscribed(&mut self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_code_subscribed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `codeSub` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:524:17 [INFO] [stdout] | [INFO] [stdout] 524 | let mut codeSub = vec![]; [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `code_sub` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 52 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/main.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/main.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::process` [INFO] [stdout] --> src/main.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use std::process; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ReaderBuilder`, `WriterBuilder` [INFO] [stdout] --> src/main.rs:11:11 [INFO] [stdout] | [INFO] [stdout] 11 | use csv::{ReaderBuilder, WriterBuilder}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `array`, `stack` [INFO] [stdout] --> src/main.rs:12:15 [INFO] [stdout] | [INFO] [stdout] 12 | use ndarray::{array, stack}; [INFO] [stdout] | ^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ndarray::prelude::*` [INFO] [stdout] --> src/main.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | use ndarray::prelude::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json` [INFO] [stdout] --> src/main.rs:14:5 [INFO] [stdout] | [INFO] [stdout] 14 | use serde_json; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `stopwatch::Stopwatch` [INFO] [stdout] --> src/main.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use stopwatch::Stopwatch; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/qaaccount.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qaaccount.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::format::ParseError` [INFO] [stdout] --> src/qaaccount.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use chrono::format::ParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stdout] --> src/qaaccount.rs:7:14 [INFO] [stdout] | [INFO] [stdout] 7 | use chrono::{DateTime, FixedOffset, Local, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/qaaccount.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `CodePreset` [INFO] [stdout] --> src/qaaccount.rs:15:28 [INFO] [stdout] | [INFO] [stdout] 15 | use crate::market_preset::{CodePreset, MarketPreset}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaposition` [INFO] [stdout] --> src/qaaccount.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | use crate::qaposition; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account_info` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:56:12 [INFO] [stdout] | [INFO] [stdout] 56 | pub struct account_info { [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `AccountInfo` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:63:12 [INFO] [stdout] | [INFO] [stdout] 63 | pub struct account { [INFO] [stdout] | ^^^^^^^ help: convert the identifier to upper camel case: `Account` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:105:12 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to upper camel case: `QaAccount` [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/qaaccount.rs:103:8 [INFO] [stdout] | [INFO] [stdout] 103 | #[warn(non_camel_case_types)] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:886:23 [INFO] [stdout] | [INFO] [stdout] 886 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 886 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 886 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:959:23 [INFO] [stdout] | [INFO] [stdout] 959 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 959 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 959 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ndarray::array` [INFO] [stdout] --> src/qadata.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use ndarray::array; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/qafetch.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qafetch.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::process` [INFO] [stdout] --> src/qafetch.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::process; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaorder::QAOrder` [INFO] [stdout] --> src/qaposition.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::qaorder::QAOrder; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Frozen` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct QA_Frozen { [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to upper camel case: `QaFrozen` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Postions` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:22:12 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct QA_Postions { [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaPostions` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:237:33 [INFO] [stdout] | [INFO] [stdout] 237 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 237 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 237 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:240:34 [INFO] [stdout] | [INFO] [stdout] 240 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 240 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 240 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:246:33 [INFO] [stdout] | [INFO] [stdout] 246 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 246 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 246 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:249:34 [INFO] [stdout] | [INFO] [stdout] 249 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 249 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 249 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `Offset` [INFO] [stdout] --> src/transaction.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Offset, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/transaction.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/trade_date.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Index` [INFO] [stdout] --> src/trade_date.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::ops::Index; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/trade_date.rs:941:19 [INFO] [stdout] | [INFO] [stdout] 941 | let day = (date - year * 10000 - month * 100); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 941 - let day = (date - year * 10000 - month * 100); [INFO] [stdout] 941 + let day = date - year * 10000 - month * 100; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `order_id` [INFO] [stdout] --> src/qaaccount.rs:723:9 [INFO] [stdout] | [INFO] [stdout] 723 | order_id: &str, [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_order_id` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `realorder_id` [INFO] [stdout] --> src/qaaccount.rs:856:9 [INFO] [stdout] | [INFO] [stdout] 856 | realorder_id: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_realorder_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:980:17 [INFO] [stdout] | [INFO] [stdout] 980 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:991:17 [INFO] [stdout] | [INFO] [stdout] 991 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:999:17 [INFO] [stdout] | [INFO] [stdout] 999 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:1014:17 [INFO] [stdout] | [INFO] [stdout] 1014 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `bar` [INFO] [stdout] --> src/main.rs:37:26 [INFO] [stdout] | [INFO] [stdout] 37 | fn on_bar(&mut self, bar: qafetch::BAR) {} [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_bar` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaaccount.rs:269:13 [INFO] [stdout] | [INFO] [stdout] 269 | let mut acc = Self { [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:91:13 [INFO] [stdout] | [INFO] [stdout] 91 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:154:13 [INFO] [stdout] | [INFO] [stdout] 154 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `create` is never used [INFO] [stdout] --> src/main.rs:30:8 [INFO] [stdout] | [INFO] [stdout] 30 | fn create() -> Self { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `init` is never used [INFO] [stdout] --> src/main.rs:35:8 [INFO] [stdout] | [INFO] [stdout] 35 | fn init(&mut self) {} [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `on_bar` is never used [INFO] [stdout] --> src/main.rs:37:8 [INFO] [stdout] | [INFO] [stdout] 37 | fn on_bar(&mut self, bar: qafetch::BAR) {} [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `run` is never used [INFO] [stdout] --> src/main.rs:39:8 [INFO] [stdout] | [INFO] [stdout] 39 | fn run(&mut self) {} [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `day_open` is never used [INFO] [stdout] --> src/main.rs:41:8 [INFO] [stdout] | [INFO] [stdout] 41 | fn day_open(&mut self) {} [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `day_close` is never used [INFO] [stdout] --> src/main.rs:43:8 [INFO] [stdout] | [INFO] [stdout] 43 | fn day_close(&mut self) {} [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `on_backtest_close` is never used [INFO] [stdout] --> src/main.rs:45:8 [INFO] [stdout] | [INFO] [stdout] 45 | fn on_backtest_close(&mut self) {} [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/qaaccount.rs:107:5 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ---------- fields in this struct [INFO] [stdout] 106 | init_cash: f64, [INFO] [stdout] 107 | init_hold: HashMap, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 108 | [INFO] [stdout] 109 | allow_t0: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 110 | allow_sellopen: bool, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 111 | allow_margin: bool, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 112 | [INFO] [stdout] 113 | auto_reload: bool, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 114 | market_preset: MarketPreset, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 132 | commission_ratio: f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 133 | // 手续费率 [INFO] [stdout] 134 | tax_ratio: f64, // tax for qaaccount [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `QA_Account` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `main` is never used [INFO] [stdout] --> src/qadata.rs:73:4 [INFO] [stdout] | [INFO] [stdout] 73 | fn main() { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `message` is never used [INFO] [stdout] --> src/qaposition.rs:79:19 [INFO] [stdout] | [INFO] [stdout] 79 | pub(crate) fn message(&self) { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `WithdrawQuota` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:74:9 [INFO] [stdout] | [INFO] [stdout] 74 | pub WithdrawQuota: f64, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `withdraw_quota` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_codeSubscribed` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:518:12 [INFO] [stdout] | [INFO] [stdout] 518 | pub fn get_codeSubscribed(&mut self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_code_subscribed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `codeSub` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:524:17 [INFO] [stdout] | [INFO] [stdout] 524 | let mut codeSub = vec![]; [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `code_sub` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 59 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 6m 31s [INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: rustc-serialize v0.3.24 [INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1` [INFO] running `Command { std: "docker" "inspect" "27c78736a64af3f3f4ba9c83bfec836cd3ee10b2e58e590c2b7d109f8b1dbc4d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "27c78736a64af3f3f4ba9c83bfec836cd3ee10b2e58e590c2b7d109f8b1dbc4d", kill_on_drop: false }` [INFO] [stdout] 27c78736a64af3f3f4ba9c83bfec836cd3ee10b2e58e590c2b7d109f8b1dbc4d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-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:7c93e6f9a94679f34221d1005849d4c83862f85b14a264fa0883942f4d043a66" "/opt/rustwide/cargo-home/bin/cargo" "+613d1972a772987ed4ee06faccbab0e2fc839871" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 7b7a3adb807314dcf83603c57bb886522ca265021734087f6b8211a7117e41cc [INFO] running `Command { std: "docker" "start" "-a" "7b7a3adb807314dcf83603c57bb886522ca265021734087f6b8211a7117e41cc", kill_on_drop: false }` [INFO] [stdout] warning: unused import: `std::f64::NAN` [INFO] [stdout] --> src/indicators/moving_average.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::f64::NAN; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/qaaccount.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qaaccount.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::format::ParseError` [INFO] [stdout] --> src/qaaccount.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use chrono::format::ParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stdout] --> src/qaaccount.rs:7:14 [INFO] [stdout] | [INFO] [stdout] 7 | use chrono::{DateTime, FixedOffset, Local, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/qaaccount.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `CodePreset` [INFO] [stdout] --> src/qaaccount.rs:15:28 [INFO] [stdout] | [INFO] [stdout] 15 | use crate::market_preset::{CodePreset, MarketPreset}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaposition` [INFO] [stdout] --> src/qaaccount.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | use crate::qaposition; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account_info` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:56:12 [INFO] [stdout] | [INFO] [stdout] 56 | pub struct account_info { [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `AccountInfo` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:63:12 [INFO] [stdout] | [INFO] [stdout] 63 | pub struct account { [INFO] [stdout] | ^^^^^^^ help: convert the identifier to upper camel case: `Account` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:105:12 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to upper camel case: `QaAccount` [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/qaaccount.rs:103:8 [INFO] [stdout] | [INFO] [stdout] 103 | #[warn(non_camel_case_types)] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:886:23 [INFO] [stdout] | [INFO] [stdout] 886 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 886 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 886 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:959:23 [INFO] [stdout] | [INFO] [stdout] 959 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 959 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 959 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ndarray::array` [INFO] [stdout] --> src/qadata.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use ndarray::array; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/qafetch.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qafetch.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::process` [INFO] [stdout] --> src/qafetch.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::process; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaorder::QAOrder` [INFO] [stdout] --> src/qaposition.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::qaorder::QAOrder; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Frozen` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct QA_Frozen { [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to upper camel case: `QaFrozen` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Postions` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:22:12 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct QA_Postions { [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaPostions` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:237:33 [INFO] [stdout] | [INFO] [stdout] 237 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 237 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 237 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:240:34 [INFO] [stdout] | [INFO] [stdout] 240 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 240 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 240 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:246:33 [INFO] [stdout] | [INFO] [stdout] 246 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 246 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 246 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:249:34 [INFO] [stdout] | [INFO] [stdout] 249 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 249 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 249 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `Offset` [INFO] [stdout] --> src/transaction.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Offset, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/transaction.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stdout] --> src/qaperformance.rs:3:14 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, FixedOffset, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::format::ParseError` [INFO] [stdout] --> src/qaperformance.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use chrono::format::ParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QAPerformance_Single` should have an upper camel case name [INFO] [stdout] --> src/qaperformance.rs:43:12 [INFO] [stdout] | [INFO] [stdout] 43 | pub struct QAPerformance_Single { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaperformanceSingle` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/trade_date.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Index` [INFO] [stdout] --> src/trade_date.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::ops::Index; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/trade_date.rs:941:19 [INFO] [stdout] | [INFO] [stdout] 941 | let day = (date - year * 10000 - month * 100); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 941 - let day = (date - year * 10000 - month * 100); [INFO] [stdout] 941 + let day = date - year * 10000 - month * 100; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:43:17 [INFO] [stdout] | [INFO] [stdout] 42 | prev => (input - prev).abs(), [INFO] [stdout] | ---- matches any value [INFO] [stdout] 43 | _ => 0.0 [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:65:17 [INFO] [stdout] | [INFO] [stdout] 64 | prev => (input - prev).abs(), [INFO] [stdout] | ---- matches any value [INFO] [stdout] 65 | _ => 0.0 [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:92:17 [INFO] [stdout] | [INFO] [stdout] 86 | prev_close => { [INFO] [stdout] | ---------- matches any value [INFO] [stdout] ... [INFO] [stdout] 92 | _ => bar.high() - bar.low(), [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:115:17 [INFO] [stdout] | [INFO] [stdout] 109 | prev_close => { [INFO] [stdout] | ---------- matches any value [INFO] [stdout] ... [INFO] [stdout] 115 | _ => bar.high() - bar.low(), [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `order_id` [INFO] [stdout] --> src/qaaccount.rs:723:9 [INFO] [stdout] | [INFO] [stdout] 723 | order_id: &str, [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_order_id` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `realorder_id` [INFO] [stdout] --> src/qaaccount.rs:856:9 [INFO] [stdout] | [INFO] [stdout] 856 | realorder_id: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_realorder_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:980:17 [INFO] [stdout] | [INFO] [stdout] 980 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:991:17 [INFO] [stdout] | [INFO] [stdout] 991 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:999:17 [INFO] [stdout] | [INFO] [stdout] 999 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:1014:17 [INFO] [stdout] | [INFO] [stdout] 1014 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaaccount.rs:269:13 [INFO] [stdout] | [INFO] [stdout] 269 | let mut acc = Self { [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:91:13 [INFO] [stdout] | [INFO] [stdout] 91 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:154:13 [INFO] [stdout] | [INFO] [stdout] 154 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `length` is never read [INFO] [stdout] --> src/indicators/average_true_range.rs:32:5 [INFO] [stdout] | [INFO] [stdout] 29 | pub struct AverageTrueRange { [INFO] [stdout] | ---------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 32 | length: usize, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AverageTrueRange` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/qaaccount.rs:107:5 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ---------- fields in this struct [INFO] [stdout] 106 | init_cash: f64, [INFO] [stdout] 107 | init_hold: HashMap, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 108 | [INFO] [stdout] 109 | allow_t0: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 110 | allow_sellopen: bool, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 111 | allow_margin: bool, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 112 | [INFO] [stdout] 113 | auto_reload: bool, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 114 | market_preset: MarketPreset, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 132 | commission_ratio: f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 133 | // 手续费率 [INFO] [stdout] 134 | tax_ratio: f64, // tax for qaaccount [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `QA_Account` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `main` is never used [INFO] [stdout] --> src/qadata.rs:73:4 [INFO] [stdout] | [INFO] [stdout] 73 | fn main() { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `message` is never used [INFO] [stdout] --> src/qaposition.rs:79:19 [INFO] [stdout] | [INFO] [stdout] 79 | pub(crate) fn message(&self) { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `WithdrawQuota` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:74:9 [INFO] [stdout] | [INFO] [stdout] 74 | pub WithdrawQuota: f64, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `withdraw_quota` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_codeSubscribed` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:518:12 [INFO] [stdout] | [INFO] [stdout] 518 | pub fn get_codeSubscribed(&mut self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_code_subscribed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `codeSub` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:524:17 [INFO] [stdout] | [INFO] [stdout] 524 | let mut codeSub = vec![]; [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `code_sub` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 52 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling quantaxis-rs v0.3.4 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/main.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/main.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::process` [INFO] [stdout] --> src/main.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use std::process; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ReaderBuilder`, `WriterBuilder` [INFO] [stdout] --> src/main.rs:11:11 [INFO] [stdout] | [INFO] [stdout] 11 | use csv::{ReaderBuilder, WriterBuilder}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `array`, `stack` [INFO] [stdout] --> src/main.rs:12:15 [INFO] [stdout] | [INFO] [stdout] 12 | use ndarray::{array, stack}; [INFO] [stdout] | ^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ndarray::prelude::*` [INFO] [stdout] --> src/main.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | use ndarray::prelude::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json` [INFO] [stdout] --> src/main.rs:14:5 [INFO] [stdout] | [INFO] [stdout] 14 | use serde_json; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `stopwatch::Stopwatch` [INFO] [stdout] --> src/main.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use stopwatch::Stopwatch; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/qaaccount.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qaaccount.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::format::ParseError` [INFO] [stdout] --> src/qaaccount.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use chrono::format::ParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stdout] --> src/qaaccount.rs:7:14 [INFO] [stdout] | [INFO] [stdout] 7 | use chrono::{DateTime, FixedOffset, Local, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/qaaccount.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `CodePreset` [INFO] [stdout] --> src/qaaccount.rs:15:28 [INFO] [stdout] | [INFO] [stdout] 15 | use crate::market_preset::{CodePreset, MarketPreset}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaposition` [INFO] [stdout] --> src/qaaccount.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | use crate::qaposition; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account_info` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:56:12 [INFO] [stdout] | [INFO] [stdout] 56 | pub struct account_info { [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `AccountInfo` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:63:12 [INFO] [stdout] | [INFO] [stdout] 63 | pub struct account { [INFO] [stdout] | ^^^^^^^ help: convert the identifier to upper camel case: `Account` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:105:12 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to upper camel case: `QaAccount` [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/qaaccount.rs:103:8 [INFO] [stdout] | [INFO] [stdout] 103 | #[warn(non_camel_case_types)] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:886:23 [INFO] [stdout] | [INFO] [stdout] 886 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 886 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 886 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:959:23 [INFO] [stdout] | [INFO] [stdout] 959 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 959 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 959 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ndarray::array` [INFO] [stdout] --> src/qadata.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use ndarray::array; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/qafetch.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qafetch.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::process` [INFO] [stdout] --> src/qafetch.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::process; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaorder::QAOrder` [INFO] [stdout] --> src/qaposition.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::qaorder::QAOrder; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Frozen` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct QA_Frozen { [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to upper camel case: `QaFrozen` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Postions` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:22:12 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct QA_Postions { [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaPostions` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:237:33 [INFO] [stdout] | [INFO] [stdout] 237 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 237 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 237 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:240:34 [INFO] [stdout] | [INFO] [stdout] 240 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 240 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 240 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:246:33 [INFO] [stdout] | [INFO] [stdout] 246 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 246 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 246 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:249:34 [INFO] [stdout] | [INFO] [stdout] 249 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 249 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 249 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `Offset` [INFO] [stdout] --> src/transaction.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Offset, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/transaction.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/trade_date.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Index` [INFO] [stdout] --> src/trade_date.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::ops::Index; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/trade_date.rs:941:19 [INFO] [stdout] | [INFO] [stdout] 941 | let day = (date - year * 10000 - month * 100); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 941 - let day = (date - year * 10000 - month * 100); [INFO] [stdout] 941 + let day = date - year * 10000 - month * 100; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `order_id` [INFO] [stdout] --> src/qaaccount.rs:723:9 [INFO] [stdout] | [INFO] [stdout] 723 | order_id: &str, [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_order_id` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `realorder_id` [INFO] [stdout] --> src/qaaccount.rs:856:9 [INFO] [stdout] | [INFO] [stdout] 856 | realorder_id: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_realorder_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:980:17 [INFO] [stdout] | [INFO] [stdout] 980 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:991:17 [INFO] [stdout] | [INFO] [stdout] 991 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:999:17 [INFO] [stdout] | [INFO] [stdout] 999 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:1014:17 [INFO] [stdout] | [INFO] [stdout] 1014 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `bar` [INFO] [stdout] --> src/main.rs:37:26 [INFO] [stdout] | [INFO] [stdout] 37 | fn on_bar(&mut self, bar: qafetch::BAR) {} [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_bar` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaaccount.rs:269:13 [INFO] [stdout] | [INFO] [stdout] 269 | let mut acc = Self { [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:91:13 [INFO] [stdout] | [INFO] [stdout] 91 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:154:13 [INFO] [stdout] | [INFO] [stdout] 154 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `create` is never used [INFO] [stdout] --> src/main.rs:30:8 [INFO] [stdout] | [INFO] [stdout] 30 | fn create() -> Self { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `init` is never used [INFO] [stdout] --> src/main.rs:35:8 [INFO] [stdout] | [INFO] [stdout] 35 | fn init(&mut self) {} [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `on_bar` is never used [INFO] [stdout] --> src/main.rs:37:8 [INFO] [stdout] | [INFO] [stdout] 37 | fn on_bar(&mut self, bar: qafetch::BAR) {} [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `run` is never used [INFO] [stdout] --> src/main.rs:39:8 [INFO] [stdout] | [INFO] [stdout] 39 | fn run(&mut self) {} [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `day_open` is never used [INFO] [stdout] --> src/main.rs:41:8 [INFO] [stdout] | [INFO] [stdout] 41 | fn day_open(&mut self) {} [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `day_close` is never used [INFO] [stdout] --> src/main.rs:43:8 [INFO] [stdout] | [INFO] [stdout] 43 | fn day_close(&mut self) {} [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `on_backtest_close` is never used [INFO] [stdout] --> src/main.rs:45:8 [INFO] [stdout] | [INFO] [stdout] 45 | fn on_backtest_close(&mut self) {} [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/qaaccount.rs:107:5 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ---------- fields in this struct [INFO] [stdout] 106 | init_cash: f64, [INFO] [stdout] 107 | init_hold: HashMap, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 108 | [INFO] [stdout] 109 | allow_t0: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 110 | allow_sellopen: bool, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 111 | allow_margin: bool, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 112 | [INFO] [stdout] 113 | auto_reload: bool, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 114 | market_preset: MarketPreset, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 132 | commission_ratio: f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 133 | // 手续费率 [INFO] [stdout] 134 | tax_ratio: f64, // tax for qaaccount [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `QA_Account` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `main` is never used [INFO] [stdout] --> src/qadata.rs:73:4 [INFO] [stdout] | [INFO] [stdout] 73 | fn main() { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `message` is never used [INFO] [stdout] --> src/qaposition.rs:79:19 [INFO] [stdout] | [INFO] [stdout] 79 | pub(crate) fn message(&self) { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `WithdrawQuota` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:74:9 [INFO] [stdout] | [INFO] [stdout] 74 | pub WithdrawQuota: f64, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `withdraw_quota` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_codeSubscribed` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:518:12 [INFO] [stdout] | [INFO] [stdout] 518 | pub fn get_codeSubscribed(&mut self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_code_subscribed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `codeSub` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:524:17 [INFO] [stdout] | [INFO] [stdout] 524 | let mut codeSub = vec![]; [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `code_sub` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 59 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::BorrowMut` [INFO] [stdout] --> examples/t01b2D.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::borrow::BorrowMut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `max`, `min` [INFO] [stdout] --> examples/t01b2D.rs:9:16 [INFO] [stdout] | [INFO] [stdout] 9 | use std::cmp::{max, min}; [INFO] [stdout] | ^^^ ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `array`, `stack` [INFO] [stdout] --> examples/t01b2D.rs:13:15 [INFO] [stdout] | [INFO] [stdout] 13 | use ndarray::{array, stack}; [INFO] [stdout] | ^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `indicators`, `qadata`, `qaindicator`, `qaposition`, `transaction` [INFO] [stdout] --> examples/t01b2D.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | indicators, Next, qaaccount, qadata, qafetch, qaindicator, qaposition, transaction, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `BollingerBands`, `EfficiencyRatio`, `ExponentialMovingAverage`, `FastStochastic`, `Maximum`, `Minimum`, `MoneyFlowIndex`, `MovingAverageConvergenceDivergence`, `OnBalanceVolume`, `RateOfChange`, `RelativeStrengthIndex`, `SimpleMovingAverage`, `SlowStochastic`, `StandardDeviation`, `TrueRange` [INFO] [stdout] --> examples/t01b2D.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | BollingerBands, EfficiencyRatio, ExponentialMovingAverage, FastStochastic, HHV, LLV, [INFO] [stdout] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] 21 | Maximum, Minimum, MoneyFlowIndex, MovingAverage, [INFO] [stdout] | ^^^^^^^ ^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] 22 | MovingAverageConvergenceDivergence, OnBalanceVolume, RateOfChange, RelativeStrengthIndex, SimpleMovingAverage, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 23 | SlowStochastic, StandardDeviation, TrueRange, [INFO] [stdout] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `quantaxis_rs::qaposition::QA_Postions` [INFO] [stdout] --> examples/t01b2D.rs:26:5 [INFO] [stdout] | [INFO] [stdout] 26 | use quantaxis_rs::qaposition::QA_Postions; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> examples/t01b2D.rs:163:28 [INFO] [stdout] | [INFO] [stdout] 163 | stopLine = (HAE * (1.0 - TrailingStop1 / 1000.0)); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 163 - stopLine = (HAE * (1.0 - TrailingStop1 / 1000.0)); [INFO] [stdout] 163 + stopLine = HAE * (1.0 - TrailingStop1 / 1000.0); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> examples/t01b2D.rs:191:28 [INFO] [stdout] | [INFO] [stdout] 191 | stopLine = (LAE * (1.0 + TrailingStop1 / 1000.0)); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 191 - stopLine = (LAE * (1.0 + TrailingStop1 / 1000.0)); [INFO] [stdout] 191 + stopLine = LAE * (1.0 + TrailingStop1 / 1000.0); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::BorrowMut` [INFO] [stdout] --> examples/t01b2.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::borrow::BorrowMut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `max`, `min` [INFO] [stdout] --> examples/t01b2.rs:9:16 [INFO] [stdout] | [INFO] [stdout] 9 | use std::cmp::{max, min}; [INFO] [stdout] | ^^^ ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `array`, `stack` [INFO] [stdout] --> examples/t01b2.rs:13:15 [INFO] [stdout] | [INFO] [stdout] 13 | use ndarray::{array, stack}; [INFO] [stdout] | ^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `indicators`, `qadata`, `qaindicator`, `qaposition`, `transaction` [INFO] [stdout] --> examples/t01b2.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | indicators, Next, qaaccount, qadata, qafetch, qaindicator, qaposition, transaction, [INFO] [stdout] | ^^^^^^^^^^ ^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `BollingerBands`, `EfficiencyRatio`, `ExponentialMovingAverage`, `FastStochastic`, `Maximum`, `Minimum`, `MoneyFlowIndex`, `MovingAverageConvergenceDivergence`, `OnBalanceVolume`, `RateOfChange`, `RelativeStrengthIndex`, `SimpleMovingAverage`, `SlowStochastic`, `StandardDeviation`, `TrueRange` [INFO] [stdout] --> examples/t01b2.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | BollingerBands, EfficiencyRatio, ExponentialMovingAverage, FastStochastic, HHV, LLV, [INFO] [stdout] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] 21 | Maximum, Minimum, MoneyFlowIndex, MovingAverage, [INFO] [stdout] | ^^^^^^^ ^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stdout] 22 | MovingAverageConvergenceDivergence, OnBalanceVolume, RateOfChange, RelativeStrengthIndex, SimpleMovingAverage, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 23 | SlowStochastic, StandardDeviation, TrueRange, [INFO] [stdout] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `quantaxis_rs::qaposition::QA_Postions` [INFO] [stdout] --> examples/t01b2.rs:26:5 [INFO] [stdout] | [INFO] [stdout] 26 | use quantaxis_rs::qaposition::QA_Postions; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> examples/t01b2.rs:165:28 [INFO] [stdout] | [INFO] [stdout] 165 | stopLine = (HAE * (1.0 - TrailingStop1 / 1000.0)); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 165 - stopLine = (HAE * (1.0 - TrailingStop1 / 1000.0)); [INFO] [stdout] 165 + stopLine = HAE * (1.0 - TrailingStop1 / 1000.0); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> examples/t01b2.rs:168:16 [INFO] [stdout] | [INFO] [stdout] 168 | if (crossUnder && cond2) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 168 - if (crossUnder && cond2) { [INFO] [stdout] 168 + if crossUnder && cond2 { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> examples/t01b2.rs:177:23 [INFO] [stdout] | [INFO] [stdout] 177 | } else if (bar.low < stopLine) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 177 - } else if (bar.low < stopLine) { [INFO] [stdout] 177 + } else if bar.low < stopLine { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> examples/t01b2.rs:188:12 [INFO] [stdout] | [INFO] [stdout] 188 | if (short_pos > 0.0 && long_pos == 0.0) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 188 - if (short_pos > 0.0 && long_pos == 0.0) { [INFO] [stdout] 188 + if short_pos > 0.0 && long_pos == 0.0 { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> examples/t01b2.rs:192:16 [INFO] [stdout] | [INFO] [stdout] 192 | if (LAE >= (acc.get_open_price_short(code) * (1.0 - TrailingStart1 / 1000.0) as f64) [INFO] [stdout] | ^ [INFO] [stdout] 193 | && bar_id - count1 >= 1) [INFO] [stdout] | ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 192 ~ if LAE >= (acc.get_open_price_short(code) * (1.0 - TrailingStart1 / 1000.0) as f64) [INFO] [stdout] 193 ~ && bar_id - count1 >= 1 [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> examples/t01b2.rs:195:28 [INFO] [stdout] | [INFO] [stdout] 195 | stopLine = (LAE * (1.0 + TrailingStop1 / 1000.0)); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 195 - stopLine = (LAE * (1.0 + TrailingStop1 / 1000.0)); [INFO] [stdout] 195 + stopLine = LAE * (1.0 + TrailingStop1 / 1000.0); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> examples/t01b2.rs:205:23 [INFO] [stdout] | [INFO] [stdout] 205 | } else if (bar.high >= stopLine) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 205 - } else if (bar.high >= stopLine) { [INFO] [stdout] 205 + } else if bar.high >= stopLine { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> examples/t01b2.rs:215:12 [INFO] [stdout] | [INFO] [stdout] 215 | if (short_pos == 0.0 && long_pos == 0.0) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 215 - if (short_pos == 0.0 && long_pos == 0.0) { [INFO] [stdout] 215 + if short_pos == 0.0 && long_pos == 0.0 { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::runtime::Builder` [INFO] [stdout] --> examples/asynctest.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use tokio::runtime::Builder; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::oneshot` [INFO] [stdout] --> examples/asynctest.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use tokio::sync::oneshot; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::task` [INFO] [stdout] --> examples/asynctest.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use tokio::task; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::rc::Rc` [INFO] [stdout] --> examples/asynctest.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::rc::Rc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::cell::RefCell` [INFO] [stdout] --> examples/asynctest.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::cell::RefCell; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::BorrowMut` [INFO] [stdout] --> examples/asynctest.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::borrow::BorrowMut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Arc`, `Mutex` [INFO] [stdout] --> examples/asynctest.rs:8:17 [INFO] [stdout] | [INFO] [stdout] 8 | use std::sync::{Arc, Mutex}; [INFO] [stdout] | ^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::runtime` [INFO] [stdout] --> examples/asynctest.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use tokio::runtime; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `#[macro_use]` import [INFO] [stdout] --> examples/qadata.rs:2:1 [INFO] [stdout] | [INFO] [stdout] 2 | #[macro_use] [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::runtime::Builder` [INFO] [stdout] --> examples/x1.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use tokio::runtime::Builder; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::oneshot` [INFO] [stdout] --> examples/x1.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use tokio::sync::oneshot; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::rc::Rc` [INFO] [stdout] --> examples/x1.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::rc::Rc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::cell::RefCell` [INFO] [stdout] --> examples/x1.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use std::cell::RefCell; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::BorrowMut` [INFO] [stdout] --> examples/x1.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::borrow::BorrowMut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::runtime` [INFO] [stdout] --> examples/x1.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use tokio::runtime; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::DerefMut` [INFO] [stdout] --> examples/x1.rs:10:5 [INFO] [stdout] | [INFO] [stdout] 10 | use std::ops::DerefMut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `some_computation` is never used [INFO] [stdout] --> examples/asynctest.rs:12:10 [INFO] [stdout] | [INFO] [stdout] 12 | async fn some_computation() -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::BorrowMut` [INFO] [stdout] --> examples/x2.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::BorrowMut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::cell::RefCell` [INFO] [stdout] --> examples/x2.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::cell::RefCell; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::rc::Rc` [INFO] [stdout] --> examples/x2.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::rc::Rc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Arc`, `Mutex` [INFO] [stdout] --> examples/x2.rs:4:17 [INFO] [stdout] | [INFO] [stdout] 4 | use std::sync::{Arc, Mutex}; [INFO] [stdout] | ^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::runtime` [INFO] [stdout] --> examples/x2.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use tokio::runtime; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::runtime::Builder` [INFO] [stdout] --> examples/x2.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use tokio::runtime::Builder; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::sync::oneshot` [INFO] [stdout] --> examples/x2.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use tokio::sync::oneshot; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `priceoffset` [INFO] [stdout] --> examples/t01b2D.rs:63:9 [INFO] [stdout] | [INFO] [stdout] 63 | let priceoffset = 1; [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_priceoffset` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `count1` [INFO] [stdout] --> examples/t01b2D.rs:69:9 [INFO] [stdout] | [INFO] [stdout] 69 | let count1 = 0; [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_count1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `ind_llv` [INFO] [stdout] --> examples/t01b2D.rs:103:13 [INFO] [stdout] | [INFO] [stdout] 103 | let ind_llv = llv_i.next(bar.low); [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_llv` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `order` [INFO] [stdout] --> examples/x1.rs:26:13 [INFO] [stdout] | [INFO] [stdout] 26 | let order = acc_mut.send_order_async(&code, 10.0, "2020-01-20 22:10:00", 2, 3500.0, "BUY_OPEN"); [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_order` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `ind_hhv` [INFO] [stdout] --> examples/t01b2D.rs:104:13 [INFO] [stdout] | [INFO] [stdout] 104 | let ind_hhv = hhv_i.next(bar.high); [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_hhv` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `ind_ma` [INFO] [stdout] --> examples/t01b2D.rs:105:13 [INFO] [stdout] | [INFO] [stdout] 105 | let ind_ma = ma.next(bar.open); [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_ma` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> examples/x1.rs:23:9 [INFO] [stdout] | [INFO] [stdout] 23 | let mut ac1= ac.clone(); [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `acc` [INFO] [stdout] --> examples/x2.rs:41:10 [INFO] [stdout] | [INFO] [stdout] 41 | let (acc, code) = join.await.unwrap(); [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_acc` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `code` [INFO] [stdout] --> examples/x2.rs:41:15 [INFO] [stdout] | [INFO] [stdout] 41 | let (acc, code) = join.await.unwrap(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_code` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `acc2` [INFO] [stdout] --> examples/x2.rs:42:10 [INFO] [stdout] | [INFO] [stdout] 42 | let (acc2, code2) = join2.await.unwrap(); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_acc2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: crate `t01b2D` should have a snake case name [INFO] [stdout] | [INFO] [stdout] = help: convert the identifier to snake case: `t01b2_d` [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `some_computation` is never used [INFO] [stdout] --> examples/x1.rs:12:10 [INFO] [stdout] | [INFO] [stdout] 12 | async fn some_computation() -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `lossP` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:64:9 [INFO] [stdout] | [INFO] [stdout] 64 | let lossP = 1.3; [INFO] [stdout] | ^^^^^ help: convert the identifier to snake case: `loss_p` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K1` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:65:9 [INFO] [stdout] | [INFO] [stdout] 65 | let K1: usize = 20; [INFO] [stdout] | ^^ help: convert the identifier to snake case (notice the capitalization): `k1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K2` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:66:9 [INFO] [stdout] | [INFO] [stdout] 66 | let K2: usize = 20; [INFO] [stdout] | ^^ help: convert the identifier to snake case (notice the capitalization): `k2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `HAE` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:70:13 [INFO] [stdout] | [INFO] [stdout] 70 | let mut HAE: f64 = 0 as f64; [INFO] [stdout] | ^^^ help: convert the identifier to snake case: `hae` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `LAE` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:71:13 [INFO] [stdout] | [INFO] [stdout] 71 | let mut LAE: f64 = 0 as f64; [INFO] [stdout] | ^^^ help: convert the identifier to snake case: `lae` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `TrailingStart1` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:72:9 [INFO] [stdout] | [INFO] [stdout] 72 | let TrailingStart1 = 90.0; [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `trailing_start1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `TrailingStop1` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:73:9 [INFO] [stdout] | [INFO] [stdout] 73 | let TrailingStop1 = 10.0; [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `trailing_stop1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `crossOver` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:107:13 [INFO] [stdout] | [INFO] [stdout] 107 | let crossOver = bar.high > hhv_i.cached[K1 - 2] && lastbar.high < hhv_i.cached[K1 - 2]; [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `cross_over` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `crossUnder` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:110:13 [INFO] [stdout] | [INFO] [stdout] 110 | let crossUnder = bar.low < llv_i.cached[K2 - 2] && lastbar.low > llv_i.cached[K2 - 2]; [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `cross_under` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `code2` [INFO] [stdout] --> examples/x2.rs:42:16 [INFO] [stdout] | [INFO] [stdout] 42 | let (acc2, code2) = join2.await.unwrap(); [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_code2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `priceoffset` [INFO] [stdout] --> examples/t01b2.rs:63:9 [INFO] [stdout] | [INFO] [stdout] 63 | let priceoffset = 2; [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_priceoffset` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `ind_llv` [INFO] [stdout] --> examples/t01b2.rs:101:13 [INFO] [stdout] | [INFO] [stdout] 101 | let ind_llv = llv_i.next(bar.low); [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_llv` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `ind_hhv` [INFO] [stdout] --> examples/t01b2.rs:102:13 [INFO] [stdout] | [INFO] [stdout] 102 | let ind_hhv = hhv_i.next(bar.high); [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_hhv` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `ind_ma` [INFO] [stdout] --> examples/t01b2.rs:103:13 [INFO] [stdout] | [INFO] [stdout] 103 | let ind_ma = ma.next(bar.open); [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_ma` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2D.rs:139:17 [INFO] [stdout] | [INFO] [stdout] 139 | / acc.buy_open( [INFO] [stdout] 140 | | bar.code.as_ref(), [INFO] [stdout] 141 | | 10.0, [INFO] [stdout] 142 | | bar.datetime.as_ref(), [INFO] [stdout] 143 | | compare_max(bar.open, hhv_i.cached[K1 - 2]), [INFO] [stdout] 144 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2D.rs:146:17 [INFO] [stdout] | [INFO] [stdout] 146 | / acc.sell_open( [INFO] [stdout] 147 | | bar.code.as_ref(), [INFO] [stdout] 148 | | 10.0, [INFO] [stdout] 149 | | bar.datetime.as_ref(), [INFO] [stdout] 150 | | compare_min(bar.open, llv_i.cached[K2 - 2]), [INFO] [stdout] 151 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `stopLine` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:157:21 [INFO] [stdout] | [INFO] [stdout] 157 | let mut stopLine: f64 = acc.get_open_price_long(code) * (100.0 - lossP) / 100.0; [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `stop_line` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2D.rs:168:17 [INFO] [stdout] | [INFO] [stdout] 168 | / acc.sell_close( [INFO] [stdout] 169 | | code, [INFO] [stdout] 170 | | 10.0, [INFO] [stdout] 171 | | bar.datetime.as_ref(), [INFO] [stdout] 172 | | compare_min(bar.open, llv_i.cached[K2 - 2]), [INFO] [stdout] 173 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2D.rs:176:17 [INFO] [stdout] | [INFO] [stdout] 176 | / acc.sell_close( [INFO] [stdout] 177 | | code, [INFO] [stdout] 178 | | 10.0, [INFO] [stdout] 179 | | bar.datetime.as_ref(), [INFO] [stdout] 180 | | compare_min(bar.open, stopLine), [INFO] [stdout] 181 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `some_computation` is never used [INFO] [stdout] --> examples/x2.rs:13:10 [INFO] [stdout] | [INFO] [stdout] 13 | async fn some_computation() -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `stopLine` should have a snake case name [INFO] [stdout] --> examples/t01b2D.rs:186:21 [INFO] [stdout] | [INFO] [stdout] 186 | let mut stopLine: f64 = acc.get_open_price_short(code) * (100.0 + lossP) / 100.0; [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `stop_line` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2D.rs:195:17 [INFO] [stdout] | [INFO] [stdout] 195 | / acc.buy_close( [INFO] [stdout] 196 | | code, [INFO] [stdout] 197 | | 10.0, [INFO] [stdout] 198 | | bar.datetime.as_ref(), [INFO] [stdout] 199 | | compare_max(bar.open, hhv_i.cached[K1 - 2]), [INFO] [stdout] 200 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2D.rs:205:17 [INFO] [stdout] | [INFO] [stdout] 205 | / acc.buy_close( [INFO] [stdout] 206 | | code, [INFO] [stdout] 207 | | 10.0, [INFO] [stdout] 208 | | bar.datetime.as_ref(), [INFO] [stdout] 209 | | compare_max(bar.open, stopLine), [INFO] [stdout] 210 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2D.rs:229:5 [INFO] [stdout] | [INFO] [stdout] 229 | acc.to_csv(); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `num_traits::real::Real` [INFO] [stdout] --> examples/qadata.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use num_traits::real::Real; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `lossP` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:64:9 [INFO] [stdout] | [INFO] [stdout] 64 | let lossP = 1.3; [INFO] [stdout] | ^^^^^ help: convert the identifier to snake case: `loss_p` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K1` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:65:9 [INFO] [stdout] | [INFO] [stdout] 65 | let K1: usize = 20; [INFO] [stdout] | ^^ help: convert the identifier to snake case (notice the capitalization): `k1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `K2` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:66:9 [INFO] [stdout] | [INFO] [stdout] 66 | let K2: usize = 20; [INFO] [stdout] | ^^ help: convert the identifier to snake case (notice the capitalization): `k2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `HAE` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:70:13 [INFO] [stdout] | [INFO] [stdout] 70 | let mut HAE: f64 = 0 as f64; [INFO] [stdout] | ^^^ help: convert the identifier to snake case: `hae` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `LAE` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:71:13 [INFO] [stdout] | [INFO] [stdout] 71 | let mut LAE: f64 = 0 as f64; [INFO] [stdout] | ^^^ help: convert the identifier to snake case: `lae` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `TrailingStart1` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:72:9 [INFO] [stdout] | [INFO] [stdout] 72 | let TrailingStart1 = 90.0; [INFO] [stdout] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `trailing_start1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `TrailingStop1` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:73:9 [INFO] [stdout] | [INFO] [stdout] 73 | let TrailingStop1 = 10.0; [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `trailing_stop1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `crossOver` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:104:13 [INFO] [stdout] | [INFO] [stdout] 104 | let crossOver = bar.high > hhv_i.cached[K1 - 2] && lastbar.high < hhv_i.cached[K1 - 2]; [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `cross_over` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `crossUnder` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:106:13 [INFO] [stdout] | [INFO] [stdout] 106 | let crossUnder = bar.low < llv_i.cached[K2 - 2] && lastbar.low > llv_i.cached[K2 - 2]; [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `cross_under` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2.rs:135:17 [INFO] [stdout] | [INFO] [stdout] 135 | / acc.buy_open( [INFO] [stdout] 136 | | bar.code.as_ref(), [INFO] [stdout] 137 | | 90.0, [INFO] [stdout] 138 | | bar.datetime.as_ref(), [INFO] [stdout] 139 | | compare_max(bar.open, hhv_i.cached[K1 - 2]), [INFO] [stdout] 140 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2.rs:146:17 [INFO] [stdout] | [INFO] [stdout] 146 | / acc.sell_open( [INFO] [stdout] 147 | | bar.code.as_ref(), [INFO] [stdout] 148 | | 90.0, [INFO] [stdout] 149 | | bar.datetime.as_ref(), [INFO] [stdout] 150 | | compare_min(bar.open, llv_i.cached[K2 - 2]), [INFO] [stdout] 151 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `stopLine` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:160:21 [INFO] [stdout] | [INFO] [stdout] 160 | let mut stopLine: f64 = acc.get_open_price_long(code) * (100.0 - lossP) / 100.0; [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `stop_line` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2.rs:171:17 [INFO] [stdout] | [INFO] [stdout] 171 | / acc.sell_close( [INFO] [stdout] 172 | | code, [INFO] [stdout] 173 | | 90.0, [INFO] [stdout] 174 | | bar.datetime.as_ref(), [INFO] [stdout] 175 | | compare_min(bar.open, llv_i.cached[K2 - 2]), [INFO] [stdout] 176 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2.rs:180:17 [INFO] [stdout] | [INFO] [stdout] 180 | / acc.sell_close( [INFO] [stdout] 181 | | code, [INFO] [stdout] 182 | | 90.0, [INFO] [stdout] 183 | | bar.datetime.as_ref(), [INFO] [stdout] 184 | | compare_min(bar.open, stopLine), [INFO] [stdout] 185 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `stopLine` should have a snake case name [INFO] [stdout] --> examples/t01b2.rs:190:21 [INFO] [stdout] | [INFO] [stdout] 190 | let mut stopLine: f64 = acc.get_open_price_short(code) * (100.0 + lossP) / 100.0; [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `stop_line` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2.rs:199:17 [INFO] [stdout] | [INFO] [stdout] 199 | / acc.buy_close( [INFO] [stdout] 200 | | code, [INFO] [stdout] 201 | | 90.0, [INFO] [stdout] 202 | | bar.datetime.as_ref(), [INFO] [stdout] 203 | | compare_max(bar.open, hhv_i.cached[K1 - 2]), [INFO] [stdout] 204 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2.rs:207:17 [INFO] [stdout] | [INFO] [stdout] 207 | / acc.buy_close( [INFO] [stdout] 208 | | code, [INFO] [stdout] 209 | | 90.0, [INFO] [stdout] 210 | | bar.datetime.as_ref(), [INFO] [stdout] 211 | | compare_max(bar.open, stopLine), [INFO] [stdout] 212 | | ); [INFO] [stdout] | |_________________^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> examples/t01b2.rs:235:5 [INFO] [stdout] | [INFO] [stdout] 235 | acc.to_csv(); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/main.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/main.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::process` [INFO] [stdout] --> src/main.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use std::process; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ReaderBuilder`, `WriterBuilder` [INFO] [stdout] --> src/main.rs:11:11 [INFO] [stdout] | [INFO] [stdout] 11 | use csv::{ReaderBuilder, WriterBuilder}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `array`, `stack` [INFO] [stdout] --> src/main.rs:12:15 [INFO] [stdout] | [INFO] [stdout] 12 | use ndarray::{array, stack}; [INFO] [stdout] | ^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ndarray::prelude::*` [INFO] [stdout] --> src/main.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | use ndarray::prelude::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json` [INFO] [stdout] --> src/main.rs:14:5 [INFO] [stdout] | [INFO] [stdout] 14 | use serde_json; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `stopwatch::Stopwatch` [INFO] [stdout] --> src/main.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use stopwatch::Stopwatch; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/qaaccount.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qaaccount.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::format::ParseError` [INFO] [stdout] --> src/qaaccount.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use chrono::format::ParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stdout] --> src/qaaccount.rs:7:14 [INFO] [stdout] | [INFO] [stdout] 7 | use chrono::{DateTime, FixedOffset, Local, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/qaaccount.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `CodePreset` [INFO] [stdout] --> src/qaaccount.rs:15:28 [INFO] [stdout] | [INFO] [stdout] 15 | use crate::market_preset::{CodePreset, MarketPreset}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaposition` [INFO] [stdout] --> src/qaaccount.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | use crate::qaposition; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account_info` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:56:12 [INFO] [stdout] | [INFO] [stdout] 56 | pub struct account_info { [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `AccountInfo` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:63:12 [INFO] [stdout] | [INFO] [stdout] 63 | pub struct account { [INFO] [stdout] | ^^^^^^^ help: convert the identifier to upper camel case: `Account` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:105:12 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to upper camel case: `QaAccount` [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/qaaccount.rs:103:8 [INFO] [stdout] | [INFO] [stdout] 103 | #[warn(non_camel_case_types)] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:886:23 [INFO] [stdout] | [INFO] [stdout] 886 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 886 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 886 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:959:23 [INFO] [stdout] | [INFO] [stdout] 959 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 959 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 959 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ndarray::array` [INFO] [stdout] --> src/qadata.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use ndarray::array; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/qafetch.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qafetch.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::process` [INFO] [stdout] --> src/qafetch.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::process; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaorder::QAOrder` [INFO] [stdout] --> src/qaposition.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::qaorder::QAOrder; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Frozen` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct QA_Frozen { [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to upper camel case: `QaFrozen` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Postions` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:22:12 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct QA_Postions { [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaPostions` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:237:33 [INFO] [stdout] | [INFO] [stdout] 237 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 237 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 237 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:240:34 [INFO] [stdout] | [INFO] [stdout] 240 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 240 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 240 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:246:33 [INFO] [stdout] | [INFO] [stdout] 246 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 246 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 246 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:249:34 [INFO] [stdout] | [INFO] [stdout] 249 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 249 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 249 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `Offset` [INFO] [stdout] --> src/transaction.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Offset, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/transaction.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/trade_date.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Index` [INFO] [stdout] --> src/trade_date.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::ops::Index; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/trade_date.rs:941:19 [INFO] [stdout] | [INFO] [stdout] 941 | let day = (date - year * 10000 - month * 100); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 941 - let day = (date - year * 10000 - month * 100); [INFO] [stdout] 941 + let day = date - year * 10000 - month * 100; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaaccount::QA_Account` [INFO] [stdout] --> src/trade_date.rs:1044:9 [INFO] [stdout] | [INFO] [stdout] 1044 | use crate::qaaccount::QA_Account; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 2 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::f64::NAN` [INFO] [stdout] --> src/indicators/moving_average.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::f64::NAN; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused macro definition: `test_indicator` [INFO] [stdout] --> src/indicators/money_flow_index.rs:153:18 [INFO] [stdout] | [INFO] [stdout] 153 | macro_rules! test_indicator { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_macros)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/qaaccount.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qaaccount.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::format::ParseError` [INFO] [stdout] --> src/qaaccount.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use chrono::format::ParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stdout] --> src/qaaccount.rs:7:14 [INFO] [stdout] | [INFO] [stdout] 7 | use chrono::{DateTime, FixedOffset, Local, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/qaaccount.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `CodePreset` [INFO] [stdout] --> src/qaaccount.rs:15:28 [INFO] [stdout] | [INFO] [stdout] 15 | use crate::market_preset::{CodePreset, MarketPreset}; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaposition` [INFO] [stdout] --> src/qaaccount.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | use crate::qaposition; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account_info` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:56:12 [INFO] [stdout] | [INFO] [stdout] 56 | pub struct account_info { [INFO] [stdout] | ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `AccountInfo` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:63:12 [INFO] [stdout] | [INFO] [stdout] 63 | pub struct account { [INFO] [stdout] | ^^^^^^^ help: convert the identifier to upper camel case: `Account` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Account` should have an upper camel case name [INFO] [stdout] --> src/qaaccount.rs:105:12 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to upper camel case: `QaAccount` [INFO] [stdout] | [INFO] [stdout] note: the lint level is defined here [INFO] [stdout] --> src/qaaccount.rs:103:8 [INFO] [stdout] | [INFO] [stdout] 103 | #[warn(non_camel_case_types)] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:886:23 [INFO] [stdout] | [INFO] [stdout] 886 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 886 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 886 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaaccount.rs:959:23 [INFO] [stdout] | [INFO] [stdout] 959 | self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 959 - self.money -= (margin - close_profit + commission + tax); [INFO] [stdout] 959 + self.money -= margin - close_profit + commission + tax; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ndarray::array` [INFO] [stdout] --> src/qadata.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use ndarray::array; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/qafetch.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io` [INFO] [stdout] --> src/qafetch.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::io; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::process` [INFO] [stdout] --> src/qafetch.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::process; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaorder::QAOrder` [INFO] [stdout] --> src/qaposition.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::qaorder::QAOrder; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Frozen` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct QA_Frozen { [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to upper camel case: `QaFrozen` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QA_Postions` should have an upper camel case name [INFO] [stdout] --> src/qaposition.rs:22:12 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct QA_Postions { [INFO] [stdout] | ^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaPostions` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:237:33 [INFO] [stdout] | [INFO] [stdout] 237 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 237 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 237 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:240:34 [INFO] [stdout] | [INFO] [stdout] 240 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 240 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 240 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:246:33 [INFO] [stdout] | [INFO] [stdout] 246 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 246 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stdout] 246 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/qaposition.rs:249:34 [INFO] [stdout] | [INFO] [stdout] 249 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 249 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stdout] 249 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `Offset` [INFO] [stdout] --> src/transaction.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | use chrono::{DateTime, Offset, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::to_string` [INFO] [stdout] --> src/transaction.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use serde_json::to_string; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stdout] --> src/qaperformance.rs:3:14 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, FixedOffset, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::format::ParseError` [INFO] [stdout] --> src/qaperformance.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use chrono::format::ParseError; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `QAPerformance_Single` should have an upper camel case name [INFO] [stdout] --> src/qaperformance.rs:43:12 [INFO] [stdout] | [INFO] [stdout] 43 | pub struct QAPerformance_Single { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaperformanceSingle` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::Borrow` [INFO] [stdout] --> src/trade_date.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::Borrow; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Index` [INFO] [stdout] --> src/trade_date.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::ops::Index; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/trade_date.rs:941:19 [INFO] [stdout] | [INFO] [stdout] 941 | let day = (date - year * 10000 - month * 100); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 941 - let day = (date - year * 10000 - month * 100); [INFO] [stdout] 941 + let day = date - year * 10000 - month * 100; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::qaaccount::QA_Account` [INFO] [stdout] --> src/trade_date.rs:1044:9 [INFO] [stdout] | [INFO] [stdout] 1044 | use crate::qaaccount::QA_Account; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `order_id` [INFO] [stdout] --> src/qaaccount.rs:723:9 [INFO] [stdout] | [INFO] [stdout] 723 | order_id: &str, [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_order_id` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `realorder_id` [INFO] [stdout] --> src/qaaccount.rs:856:9 [INFO] [stdout] | [INFO] [stdout] 856 | realorder_id: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_realorder_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `acc` [INFO] [stdout] --> src/qaaccount.rs:1001:17 [INFO] [stdout] | [INFO] [stdout] 1001 | let mut acc = QA_Account::new("RustT01B2_RBL8", "test", "admin", 100000.0, false, "real"); [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_acc` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `slice` [INFO] [stdout] --> src/qaaccount.rs:1276:13 [INFO] [stdout] | [INFO] [stdout] 1276 | let slice = acc.get_qifi_slice(); [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_slice` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `slice` [INFO] [stdout] --> src/qaaccount.rs:1295:13 [INFO] [stdout] | [INFO] [stdout] 1295 | let slice = acc.get_qifi_slice(); [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_slice` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:980:17 [INFO] [stdout] | [INFO] [stdout] 980 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:991:17 [INFO] [stdout] | [INFO] [stdout] 991 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:999:17 [INFO] [stdout] | [INFO] [stdout] 999 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:1014:17 [INFO] [stdout] | [INFO] [stdout] 1014 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `bar` [INFO] [stdout] --> src/main.rs:37:26 [INFO] [stdout] | [INFO] [stdout] 37 | fn on_bar(&mut self, bar: qafetch::BAR) {} [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_bar` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaaccount.rs:269:13 [INFO] [stdout] | [INFO] [stdout] 269 | let mut acc = Self { [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaaccount.rs:991:13 [INFO] [stdout] | [INFO] [stdout] 991 | let mut acc = QA_Account::new( [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaaccount.rs:1001:13 [INFO] [stdout] | [INFO] [stdout] 1001 | let mut acc = QA_Account::new("RustT01B2_RBL8", "test", "admin", 100000.0, false, "real"); [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:91:13 [INFO] [stdout] | [INFO] [stdout] 91 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:154:13 [INFO] [stdout] | [INFO] [stdout] 154 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:466:13 [INFO] [stdout] | [INFO] [stdout] 466 | let mut pos = QA_Postions::new( [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:481:13 [INFO] [stdout] | [INFO] [stdout] 481 | let mut pos = QA_Postions::new( [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `create` is never used [INFO] [stdout] --> src/main.rs:30:8 [INFO] [stdout] | [INFO] [stdout] 30 | fn create() -> Self { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `init` is never used [INFO] [stdout] --> src/main.rs:35:8 [INFO] [stdout] | [INFO] [stdout] 35 | fn init(&mut self) {} [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `on_bar` is never used [INFO] [stdout] --> src/main.rs:37:8 [INFO] [stdout] | [INFO] [stdout] 37 | fn on_bar(&mut self, bar: qafetch::BAR) {} [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `run` is never used [INFO] [stdout] --> src/main.rs:39:8 [INFO] [stdout] | [INFO] [stdout] 39 | fn run(&mut self) {} [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `day_open` is never used [INFO] [stdout] --> src/main.rs:41:8 [INFO] [stdout] | [INFO] [stdout] 41 | fn day_open(&mut self) {} [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `day_close` is never used [INFO] [stdout] --> src/main.rs:43:8 [INFO] [stdout] | [INFO] [stdout] 43 | fn day_close(&mut self) {} [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `on_backtest_close` is never used [INFO] [stdout] --> src/main.rs:45:8 [INFO] [stdout] | [INFO] [stdout] 45 | fn on_backtest_close(&mut self) {} [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/qaaccount.rs:107:5 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ---------- fields in this struct [INFO] [stdout] 106 | init_cash: f64, [INFO] [stdout] 107 | init_hold: HashMap, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 108 | [INFO] [stdout] 109 | allow_t0: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 110 | allow_sellopen: bool, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 111 | allow_margin: bool, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 112 | [INFO] [stdout] 113 | auto_reload: bool, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 114 | market_preset: MarketPreset, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 132 | commission_ratio: f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 133 | // 手续费率 [INFO] [stdout] 134 | tax_ratio: f64, // tax for qaaccount [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `QA_Account` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `main` is never used [INFO] [stdout] --> src/qadata.rs:73:4 [INFO] [stdout] | [INFO] [stdout] 73 | fn main() { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `WithdrawQuota` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:74:9 [INFO] [stdout] | [INFO] [stdout] 74 | pub WithdrawQuota: f64, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `withdraw_quota` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_codeSubscribed` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:518:12 [INFO] [stdout] | [INFO] [stdout] 518 | pub fn get_codeSubscribed(&mut self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_code_subscribed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `codeSub` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:524:17 [INFO] [stdout] | [INFO] [stdout] 524 | let mut codeSub = vec![]; [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `code_sub` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1052:9 [INFO] [stdout] | [INFO] [stdout] 1052 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1071:9 [INFO] [stdout] | [INFO] [stdout] 1071 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1090:9 [INFO] [stdout] | [INFO] [stdout] 1090 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1109:9 [INFO] [stdout] | [INFO] [stdout] 1109 | acc.sell_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1127:9 [INFO] [stdout] | [INFO] [stdout] 1127 | acc.sell_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1129:9 [INFO] [stdout] | [INFO] [stdout] 1129 | acc.buy_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1149:9 [INFO] [stdout] | [INFO] [stdout] 1149 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1151:9 [INFO] [stdout] | [INFO] [stdout] 1151 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1171:9 [INFO] [stdout] | [INFO] [stdout] 1171 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1175:9 [INFO] [stdout] | [INFO] [stdout] 1175 | acc.sell_close(code, 1000.0, "2020-01-20", 36.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1192:9 [INFO] [stdout] | [INFO] [stdout] 1192 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1203:9 [INFO] [stdout] | [INFO] [stdout] 1203 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1207:9 [INFO] [stdout] | [INFO] [stdout] 1207 | acc.sell(code, 10.0, "2020-01-22 22:10:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1217:9 [INFO] [stdout] | [INFO] [stdout] 1217 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1220:9 [INFO] [stdout] | [INFO] [stdout] 1220 | acc.sell(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `test_accountSlice` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:1225:8 [INFO] [stdout] | [INFO] [stdout] 1225 | fn test_accountSlice() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_account_slice` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1238:9 [INFO] [stdout] | [INFO] [stdout] 1238 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1242:9 [INFO] [stdout] | [INFO] [stdout] 1242 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `test_accountSlice_for_qifi` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:1252:8 [INFO] [stdout] | [INFO] [stdout] 1252 | fn test_accountSlice_for_qifi() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_account_slice_for_qifi` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1257:9 [INFO] [stdout] | [INFO] [stdout] 1257 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1261:9 [INFO] [stdout] | [INFO] [stdout] 1261 | acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1275:9 [INFO] [stdout] | [INFO] [stdout] 1275 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1281:9 [INFO] [stdout] | [INFO] [stdout] 1281 | new_acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1294:9 [INFO] [stdout] | [INFO] [stdout] 1294 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1300:9 [INFO] [stdout] | [INFO] [stdout] 1300 | new_acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1318:9 [INFO] [stdout] | [INFO] [stdout] 1318 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1322:9 [INFO] [stdout] | [INFO] [stdout] 1322 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1345:9 [INFO] [stdout] | [INFO] [stdout] 1345 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1352:9 [INFO] [stdout] | [INFO] [stdout] 1352 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1369:9 [INFO] [stdout] | [INFO] [stdout] 1369 | acc.buy_open(code, 10.0, "2020-01-22", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1398:9 [INFO] [stdout] | [INFO] [stdout] 1398 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1404:9 [INFO] [stdout] | [INFO] [stdout] 1404 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1428:9 [INFO] [stdout] | [INFO] [stdout] 1428 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1430:9 [INFO] [stdout] | [INFO] [stdout] 1430 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1435:9 [INFO] [stdout] | [INFO] [stdout] 1435 | acc.to_csv(); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1449:9 [INFO] [stdout] | [INFO] [stdout] 1449 | acc.buy_open("rb2005", 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:43:17 [INFO] [stdout] | [INFO] [stdout] 42 | prev => (input - prev).abs(), [INFO] [stdout] | ---- matches any value [INFO] [stdout] 43 | _ => 0.0 [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:65:17 [INFO] [stdout] | [INFO] [stdout] 64 | prev => (input - prev).abs(), [INFO] [stdout] | ---- matches any value [INFO] [stdout] 65 | _ => 0.0 [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:92:17 [INFO] [stdout] | [INFO] [stdout] 86 | prev_close => { [INFO] [stdout] | ---------- matches any value [INFO] [stdout] ... [INFO] [stdout] 92 | _ => bar.high() - bar.low(), [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/indicators/true_range.rs:115:17 [INFO] [stdout] | [INFO] [stdout] 109 | prev_close => { [INFO] [stdout] | ---------- matches any value [INFO] [stdout] ... [INFO] [stdout] 115 | _ => bar.high() - bar.low(), [INFO] [stdout] | ^ unreachable pattern [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `order_id` [INFO] [stdout] --> src/qaaccount.rs:723:9 [INFO] [stdout] | [INFO] [stdout] 723 | order_id: &str, [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_order_id` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `realorder_id` [INFO] [stdout] --> src/qaaccount.rs:856:9 [INFO] [stdout] | [INFO] [stdout] 856 | realorder_id: String, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_realorder_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `acc` [INFO] [stdout] --> src/qaaccount.rs:1001:17 [INFO] [stdout] | [INFO] [stdout] 1001 | let mut acc = QA_Account::new("RustT01B2_RBL8", "test", "admin", 100000.0, false, "real"); [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_acc` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `slice` [INFO] [stdout] --> src/qaaccount.rs:1276:13 [INFO] [stdout] | [INFO] [stdout] 1276 | let slice = acc.get_qifi_slice(); [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_slice` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `slice` [INFO] [stdout] --> src/qaaccount.rs:1295:13 [INFO] [stdout] | [INFO] [stdout] 1295 | let slice = acc.get_qifi_slice(); [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_slice` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:980:17 [INFO] [stdout] | [INFO] [stdout] 980 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:991:17 [INFO] [stdout] | [INFO] [stdout] 991 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:999:17 [INFO] [stdout] | [INFO] [stdout] 999 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `res` is never read [INFO] [stdout] --> src/trade_date.rs:1014:17 [INFO] [stdout] | [INFO] [stdout] 1014 | let mut res = 0; [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaaccount.rs:269:13 [INFO] [stdout] | [INFO] [stdout] 269 | let mut acc = Self { [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaaccount.rs:991:13 [INFO] [stdout] | [INFO] [stdout] 991 | let mut acc = QA_Account::new( [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaaccount.rs:1001:13 [INFO] [stdout] | [INFO] [stdout] 1001 | let mut acc = QA_Account::new("RustT01B2_RBL8", "test", "admin", 100000.0, false, "real"); [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:91:13 [INFO] [stdout] | [INFO] [stdout] 91 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:154:13 [INFO] [stdout] | [INFO] [stdout] 154 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:466:13 [INFO] [stdout] | [INFO] [stdout] 466 | let mut pos = QA_Postions::new( [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/qaposition.rs:481:13 [INFO] [stdout] | [INFO] [stdout] 481 | let mut pos = QA_Postions::new( [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 36 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 9 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 32 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `length` is never read [INFO] [stdout] --> src/indicators/average_true_range.rs:32:5 [INFO] [stdout] | [INFO] [stdout] 29 | pub struct AverageTrueRange { [INFO] [stdout] | ---------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 32 | length: usize, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AverageTrueRange` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/qaaccount.rs:107:5 [INFO] [stdout] | [INFO] [stdout] 105 | pub struct QA_Account { [INFO] [stdout] | ---------- fields in this struct [INFO] [stdout] 106 | init_cash: f64, [INFO] [stdout] 107 | init_hold: HashMap, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 108 | [INFO] [stdout] 109 | allow_t0: bool, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 110 | allow_sellopen: bool, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 111 | allow_margin: bool, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 112 | [INFO] [stdout] 113 | auto_reload: bool, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 114 | market_preset: MarketPreset, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 132 | commission_ratio: f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 133 | // 手续费率 [INFO] [stdout] 134 | tax_ratio: f64, // tax for qaaccount [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `QA_Account` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `main` is never used [INFO] [stdout] --> src/qadata.rs:73:4 [INFO] [stdout] | [INFO] [stdout] 73 | fn main() { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `LLV_Indicator` should have a snake case name [INFO] [stdout] --> src/indicators/llv.rs:227:17 [INFO] [stdout] | [INFO] [stdout] 227 | let mut LLV_Indicator = LLV::new(3).unwrap(); [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `llv_indicator` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `LLV_Indicator` should have a snake case name [INFO] [stdout] --> src/indicators/llv.rs:250:17 [INFO] [stdout] | [INFO] [stdout] 250 | let mut LLV_Indicator = LLV::new_init(2, vec![3.0,4.0,3.0]).unwrap(); [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `llv_indicator` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `LLV_Indicator` should have a snake case name [INFO] [stdout] --> src/indicators/llv.rs:262:17 [INFO] [stdout] | [INFO] [stdout] 262 | let mut LLV_Indicator = LLV::new_init(4, vec![4.0,6.0,3.0]).unwrap(); [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `llv_indicator` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: structure field `WithdrawQuota` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:74:9 [INFO] [stdout] | [INFO] [stdout] 74 | pub WithdrawQuota: f64, [INFO] [stdout] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `withdraw_quota` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_codeSubscribed` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:518:12 [INFO] [stdout] | [INFO] [stdout] 518 | pub fn get_codeSubscribed(&mut self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_code_subscribed` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `codeSub` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:524:17 [INFO] [stdout] | [INFO] [stdout] 524 | let mut codeSub = vec![]; [INFO] [stdout] | ^^^^^^^ help: convert the identifier to snake case: `code_sub` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1052:9 [INFO] [stdout] | [INFO] [stdout] 1052 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1071:9 [INFO] [stdout] | [INFO] [stdout] 1071 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1090:9 [INFO] [stdout] | [INFO] [stdout] 1090 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1109:9 [INFO] [stdout] | [INFO] [stdout] 1109 | acc.sell_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1127:9 [INFO] [stdout] | [INFO] [stdout] 1127 | acc.sell_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1129:9 [INFO] [stdout] | [INFO] [stdout] 1129 | acc.buy_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1149:9 [INFO] [stdout] | [INFO] [stdout] 1149 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1151:9 [INFO] [stdout] | [INFO] [stdout] 1151 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1171:9 [INFO] [stdout] | [INFO] [stdout] 1171 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1175:9 [INFO] [stdout] | [INFO] [stdout] 1175 | acc.sell_close(code, 1000.0, "2020-01-20", 36.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1192:9 [INFO] [stdout] | [INFO] [stdout] 1192 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1203:9 [INFO] [stdout] | [INFO] [stdout] 1203 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1207:9 [INFO] [stdout] | [INFO] [stdout] 1207 | acc.sell(code, 10.0, "2020-01-22 22:10:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1217:9 [INFO] [stdout] | [INFO] [stdout] 1217 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1220:9 [INFO] [stdout] | [INFO] [stdout] 1220 | acc.sell(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `test_accountSlice` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:1225:8 [INFO] [stdout] | [INFO] [stdout] 1225 | fn test_accountSlice() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_account_slice` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1238:9 [INFO] [stdout] | [INFO] [stdout] 1238 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1242:9 [INFO] [stdout] | [INFO] [stdout] 1242 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `test_accountSlice_for_qifi` should have a snake case name [INFO] [stdout] --> src/qaaccount.rs:1252:8 [INFO] [stdout] | [INFO] [stdout] 1252 | fn test_accountSlice_for_qifi() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_account_slice_for_qifi` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1257:9 [INFO] [stdout] | [INFO] [stdout] 1257 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1261:9 [INFO] [stdout] | [INFO] [stdout] 1261 | acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1275:9 [INFO] [stdout] | [INFO] [stdout] 1275 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1281:9 [INFO] [stdout] | [INFO] [stdout] 1281 | new_acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1294:9 [INFO] [stdout] | [INFO] [stdout] 1294 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1300:9 [INFO] [stdout] | [INFO] [stdout] 1300 | new_acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1318:9 [INFO] [stdout] | [INFO] [stdout] 1318 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1322:9 [INFO] [stdout] | [INFO] [stdout] 1322 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1345:9 [INFO] [stdout] | [INFO] [stdout] 1345 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1352:9 [INFO] [stdout] | [INFO] [stdout] 1352 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1369:9 [INFO] [stdout] | [INFO] [stdout] 1369 | acc.buy_open(code, 10.0, "2020-01-22", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1398:9 [INFO] [stdout] | [INFO] [stdout] 1398 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1404:9 [INFO] [stdout] | [INFO] [stdout] 1404 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1428:9 [INFO] [stdout] | [INFO] [stdout] 1428 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1430:9 [INFO] [stdout] | [INFO] [stdout] 1430 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1435:9 [INFO] [stdout] | [INFO] [stdout] 1435 | acc.to_csv(); [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaaccount.rs:1449:9 [INFO] [stdout] | [INFO] [stdout] 1449 | acc.buy_open("rb2005", 10.0, "2020-01-20", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:298:9 [INFO] [stdout] | [INFO] [stdout] 298 | acc.sell_open(code, 10.0, "2020-01-20 09:30:22", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:299:9 [INFO] [stdout] | [INFO] [stdout] 299 | acc.buy_open(code, 10.0, "2020-01-20 09:52:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:302:9 [INFO] [stdout] | [INFO] [stdout] 302 | acc.buy_close(code, 10.0, "2020-01-20 10:22:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:303:9 [INFO] [stdout] | [INFO] [stdout] 303 | acc.buy_open(code, 10.0, "2020-01-20 13:54:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:304:9 [INFO] [stdout] | [INFO] [stdout] 304 | acc.buy_open(code, 10.0, "2020-01-20 13:55:00", 3510.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:306:9 [INFO] [stdout] | [INFO] [stdout] 306 | acc.sell_close(code, 20.0, "2020-01-20 14:52:00", 3620.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:307:9 [INFO] [stdout] | [INFO] [stdout] 307 | acc.buy_open(code, 20.0, "2020-01-21 13:54:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:308:9 [INFO] [stdout] | [INFO] [stdout] 308 | acc.sell_close(code, 15.0, "2020-01-21 13:55:00", 3510.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:310:9 [INFO] [stdout] | [INFO] [stdout] 310 | acc.sell_close(code, 5.0, "2020-01-21 14:52:00", 3420.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:333:9 [INFO] [stdout] | [INFO] [stdout] 333 | acc.sell_open(code, 10.0, "2020-01-20 09:30:22", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:334:9 [INFO] [stdout] | [INFO] [stdout] 334 | acc.buy_open(code, 10.0, "2020-01-20 09:52:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:337:9 [INFO] [stdout] | [INFO] [stdout] 337 | acc.buy_close(code, 10.0, "2020-01-20 10:22:00", 3600.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:338:9 [INFO] [stdout] | [INFO] [stdout] 338 | acc.buy_open(code, 10.0, "2020-01-20 13:54:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:339:9 [INFO] [stdout] | [INFO] [stdout] 339 | acc.buy_open(code, 10.0, "2020-01-20 13:55:00", 3510.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:341:9 [INFO] [stdout] | [INFO] [stdout] 341 | acc.sell_close(code, 20.0, "2020-01-20 14:52:00", 3620.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:342:9 [INFO] [stdout] | [INFO] [stdout] 342 | acc.buy_open(code, 20.0, "2020-01-21 13:54:00", 3500.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:343:9 [INFO] [stdout] | [INFO] [stdout] 343 | acc.sell_close(code, 15.0, "2020-01-21 13:55:00", 3510.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:345:9 [INFO] [stdout] | [INFO] [stdout] 345 | acc.sell_close(code, 5.0, "2020-01-21 14:52:00", 3420.0); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:359:9 [INFO] [stdout] | [INFO] [stdout] 359 | acc.sell_open(code, 1000.0, "2020-04-03 09:30:22", 46.33); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:360:9 [INFO] [stdout] | [INFO] [stdout] 360 | acc.sell_open("RB2005", 10.0, "2020-04-03 09:30:22", 3346.33); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:361:9 [INFO] [stdout] | [INFO] [stdout] 361 | acc.buy_open(code, 1000.0, "2020-04-03 09:52:00", 46.86); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:363:9 [INFO] [stdout] | [INFO] [stdout] 363 | acc.buy_close(code, 1000.0, "2020-04-03 10:22:00", 47.34); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:364:9 [INFO] [stdout] | [INFO] [stdout] 364 | acc.sell_close(code, 1000.0, "2020-04-03 10:22:00", 47.34); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:365:9 [INFO] [stdout] | [INFO] [stdout] 365 | acc.buy_close("RB2005", 10.0, "2020-04-03 10:30:22", 3246.33); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:366:9 [INFO] [stdout] | [INFO] [stdout] 366 | acc.buy_open(code, 1000.0, "2020-04-03 13:54:00", 47.1); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:367:9 [INFO] [stdout] | [INFO] [stdout] 367 | acc.buy_open(code, 1000.0, "2020-04-03 13:55:00", 47.11); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:369:9 [INFO] [stdout] | [INFO] [stdout] 369 | acc.sell_close(code, 2000.0, "2020-04-03 14:52:00", 47.17); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:398:9 [INFO] [stdout] | [INFO] [stdout] 398 | acc.sell_open(code, 1000.0, "2020-04-03 09:30:22", 46.33); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:399:9 [INFO] [stdout] | [INFO] [stdout] 399 | acc.sell_open("RB2005", 10.0, "2020-04-03 09:30:22", 3346.33); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:400:9 [INFO] [stdout] | [INFO] [stdout] 400 | acc.buy_open(code, 1000.0, "2020-04-03 09:52:00", 46.86); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:402:9 [INFO] [stdout] | [INFO] [stdout] 402 | acc.buy_closetoday(code, 1000.0, "2020-04-03 10:22:00", 47.34); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:403:9 [INFO] [stdout] | [INFO] [stdout] 403 | acc.sell_closetoday(code, 1000.0, "2020-04-03 10:22:00", 47.34); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:404:9 [INFO] [stdout] | [INFO] [stdout] 404 | acc.buy_closetoday("RB2005", 10.0, "2020-04-03 10:30:22", 3246.33); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:405:9 [INFO] [stdout] | [INFO] [stdout] 405 | acc.buy_open(code, 1000.0, "2020-04-03 13:54:00", 47.1); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:406:9 [INFO] [stdout] | [INFO] [stdout] 406 | acc.buy_open(code, 1000.0, "2020-04-03 13:55:00", 47.11); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/qaperformance.rs:408:9 [INFO] [stdout] | [INFO] [stdout] 408 | acc.sell_closetoday(code, 2000.0, "2020-04-03 14:52:00", 47.17); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 12 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 10 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 102 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 135 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 34.20s [INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: rustc-serialize v0.3.24 [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" "7b7a3adb807314dcf83603c57bb886522ca265021734087f6b8211a7117e41cc", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7b7a3adb807314dcf83603c57bb886522ca265021734087f6b8211a7117e41cc", kill_on_drop: false }` [INFO] [stdout] 7b7a3adb807314dcf83603c57bb886522ca265021734087f6b8211a7117e41cc [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-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:7c93e6f9a94679f34221d1005849d4c83862f85b14a264fa0883942f4d043a66" "/opt/rustwide/cargo-home/bin/cargo" "+613d1972a772987ed4ee06faccbab0e2fc839871" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] f3391a87288436f33b182d223a4edc5d8aaaab01d2158c3d879d2def3d0c84a3 [INFO] running `Command { std: "docker" "start" "-a" "f3391a87288436f33b182d223a4edc5d8aaaab01d2158c3d879d2def3d0c84a3", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `std::f64::NAN` [INFO] [stderr] --> src/indicators/moving_average.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::f64::NAN; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::borrow::Borrow` [INFO] [stderr] --> src/qaaccount.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::borrow::Borrow; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::io` [INFO] [stderr] --> src/qaaccount.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::io; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `chrono::format::ParseError` [INFO] [stderr] --> src/qaaccount.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use chrono::format::ParseError; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stderr] --> src/qaaccount.rs:7:14 [INFO] [stderr] | [INFO] [stderr] 7 | use chrono::{DateTime, FixedOffset, Local, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `serde_json::to_string` [INFO] [stderr] --> src/qaaccount.rs:11:5 [INFO] [stderr] | [INFO] [stderr] 11 | use serde_json::to_string; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `CodePreset` [INFO] [stderr] --> src/qaaccount.rs:15:28 [INFO] [stderr] | [INFO] [stderr] 15 | use crate::market_preset::{CodePreset, MarketPreset}; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `crate::qaposition` [INFO] [stderr] --> src/qaaccount.rs:17:5 [INFO] [stderr] | [INFO] [stderr] 17 | use crate::qaposition; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: type `account_info` should have an upper camel case name [INFO] [stderr] --> src/qaaccount.rs:56:12 [INFO] [stderr] | [INFO] [stderr] 56 | pub struct account_info { [INFO] [stderr] | ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `AccountInfo` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stderr] [INFO] [stderr] warning: type `account` should have an upper camel case name [INFO] [stderr] --> src/qaaccount.rs:63:12 [INFO] [stderr] | [INFO] [stderr] 63 | pub struct account { [INFO] [stderr] | ^^^^^^^ help: convert the identifier to upper camel case: `Account` [INFO] [stderr] [INFO] [stderr] warning: type `QA_Account` should have an upper camel case name [INFO] [stderr] --> src/qaaccount.rs:105:12 [INFO] [stderr] | [INFO] [stderr] 105 | pub struct QA_Account { [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to upper camel case: `QaAccount` [INFO] [stderr] | [INFO] [stderr] note: the lint level is defined here [INFO] [stderr] --> src/qaaccount.rs:103:8 [INFO] [stderr] | [INFO] [stderr] 103 | #[warn(non_camel_case_types)] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> src/qaaccount.rs:886:23 [INFO] [stderr] | [INFO] [stderr] 886 | self.money -= (margin - close_profit + commission + tax); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 886 - self.money -= (margin - close_profit + commission + tax); [INFO] [stderr] 886 + self.money -= margin - close_profit + commission + tax; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> src/qaaccount.rs:959:23 [INFO] [stderr] | [INFO] [stderr] 959 | self.money -= (margin - close_profit + commission + tax); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 959 - self.money -= (margin - close_profit + commission + tax); [INFO] [stderr] 959 + self.money -= margin - close_profit + commission + tax; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused import: `ndarray::array` [INFO] [stderr] --> src/qadata.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use ndarray::array; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> src/qafetch.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::io` [INFO] [stderr] --> src/qafetch.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::io; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::process` [INFO] [stderr] --> src/qafetch.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::process; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `crate::qaorder::QAOrder` [INFO] [stderr] --> src/qaposition.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use crate::qaorder::QAOrder; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: type `QA_Frozen` should have an upper camel case name [INFO] [stderr] --> src/qaposition.rs:9:12 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct QA_Frozen { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to upper camel case: `QaFrozen` [INFO] [stderr] [INFO] [stderr] warning: type `QA_Postions` should have an upper camel case name [INFO] [stderr] --> src/qaposition.rs:22:12 [INFO] [stderr] | [INFO] [stderr] 22 | pub struct QA_Postions { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaPostions` [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> src/qaposition.rs:237:33 [INFO] [stderr] | [INFO] [stderr] 237 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 237 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stderr] 237 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> src/qaposition.rs:240:34 [INFO] [stderr] | [INFO] [stderr] 240 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 240 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stderr] 240 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> src/qaposition.rs:246:33 [INFO] [stderr] | [INFO] [stderr] 246 | self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 246 - self.volume_long_his += (self.volume_long_today + self.volume_long_frozen_today); [INFO] [stderr] 246 + self.volume_long_his += self.volume_long_today + self.volume_long_frozen_today; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> src/qaposition.rs:249:34 [INFO] [stderr] | [INFO] [stderr] 249 | self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 249 - self.volume_short_his += (self.volume_short_today + self.volume_short_frozen_today); [INFO] [stderr] 249 + self.volume_short_his += self.volume_short_today + self.volume_short_frozen_today; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DateTime`, `Offset` [INFO] [stderr] --> src/transaction.rs:1:14 [INFO] [stderr] | [INFO] [stderr] 1 | use chrono::{DateTime, Offset, TimeZone, Utc}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `serde_json::to_string` [INFO] [stderr] --> src/transaction.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use serde_json::to_string; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DateTime`, `FixedOffset`, `NaiveDateTime`, `NaiveDate`, `NaiveTime` [INFO] [stderr] --> src/qaperformance.rs:3:14 [INFO] [stderr] | [INFO] [stderr] 3 | use chrono::{DateTime, FixedOffset, NaiveDate, NaiveDateTime, NaiveTime, TimeZone, Utc}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `chrono::format::ParseError` [INFO] [stderr] --> src/qaperformance.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use chrono::format::ParseError; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: type `QAPerformance_Single` should have an upper camel case name [INFO] [stderr] --> src/qaperformance.rs:43:12 [INFO] [stderr] | [INFO] [stderr] 43 | pub struct QAPerformance_Single { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `QaperformanceSingle` [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::borrow::Borrow` [INFO] [stderr] --> src/trade_date.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::borrow::Borrow; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::ops::Index` [INFO] [stderr] --> src/trade_date.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::ops::Index; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> src/trade_date.rs:941:19 [INFO] [stderr] | [INFO] [stderr] 941 | let day = (date - year * 10000 - month * 100); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 941 - let day = (date - year * 10000 - month * 100); [INFO] [stderr] 941 + let day = date - year * 10000 - month * 100; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/indicators/true_range.rs:43:17 [INFO] [stderr] | [INFO] [stderr] 42 | prev => (input - prev).abs(), [INFO] [stderr] | ---- matches any value [INFO] [stderr] 43 | _ => 0.0 [INFO] [stderr] | ^ unreachable pattern [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/indicators/true_range.rs:65:17 [INFO] [stderr] | [INFO] [stderr] 64 | prev => (input - prev).abs(), [INFO] [stderr] | ---- matches any value [INFO] [stderr] 65 | _ => 0.0 [INFO] [stderr] | ^ unreachable pattern [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/indicators/true_range.rs:92:17 [INFO] [stderr] | [INFO] [stderr] 86 | prev_close => { [INFO] [stderr] | ---------- matches any value [INFO] [stderr] ... [INFO] [stderr] 92 | _ => bar.high() - bar.low(), [INFO] [stderr] | ^ unreachable pattern [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/indicators/true_range.rs:115:17 [INFO] [stderr] | [INFO] [stderr] 109 | prev_close => { [INFO] [stderr] | ---------- matches any value [INFO] [stderr] ... [INFO] [stderr] 115 | _ => bar.high() - bar.low(), [INFO] [stderr] | ^ unreachable pattern [INFO] [stderr] [INFO] [stderr] warning: unused variable: `order_id` [INFO] [stderr] --> src/qaaccount.rs:723:9 [INFO] [stderr] | [INFO] [stderr] 723 | order_id: &str, [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_order_id` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `realorder_id` [INFO] [stderr] --> src/qaaccount.rs:856:9 [INFO] [stderr] | [INFO] [stderr] 856 | realorder_id: String, [INFO] [stderr] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_realorder_id` [INFO] [stderr] [INFO] [stderr] warning: value assigned to `res` is never read [INFO] [stderr] --> src/trade_date.rs:980:17 [INFO] [stderr] | [INFO] [stderr] 980 | let mut res = 0; [INFO] [stderr] | ^^^ [INFO] [stderr] | [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] = note: `#[warn(unused_assignments)]` on by default [INFO] [stderr] [INFO] [stderr] warning: value assigned to `res` is never read [INFO] [stderr] --> src/trade_date.rs:991:17 [INFO] [stderr] | [INFO] [stderr] 991 | let mut res = 0; [INFO] [stderr] | ^^^ [INFO] [stderr] | [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] [INFO] [stderr] warning: value assigned to `res` is never read [INFO] [stderr] --> src/trade_date.rs:999:17 [INFO] [stderr] | [INFO] [stderr] 999 | let mut res = 0; [INFO] [stderr] | ^^^ [INFO] [stderr] | [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] [INFO] [stderr] warning: value assigned to `res` is never read [INFO] [stderr] --> src/trade_date.rs:1014:17 [INFO] [stderr] | [INFO] [stderr] 1014 | let mut res = 0; [INFO] [stderr] | ^^^ [INFO] [stderr] | [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/qaaccount.rs:269:13 [INFO] [stderr] | [INFO] [stderr] 269 | let mut acc = Self { [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/qaposition.rs:91:13 [INFO] [stderr] | [INFO] [stderr] 91 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stderr] | ----^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/qaposition.rs:154:13 [INFO] [stderr] | [INFO] [stderr] 154 | let mut preset: CodePreset = MarketPreset::new().get(code.as_ref()); [INFO] [stderr] | ----^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: field `length` is never read [INFO] [stderr] --> src/indicators/average_true_range.rs:32:5 [INFO] [stderr] | [INFO] [stderr] 29 | pub struct AverageTrueRange { [INFO] [stderr] | ---------------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 32 | length: usize, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `AverageTrueRange` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: multiple fields are never read [INFO] [stderr] --> src/qaaccount.rs:107:5 [INFO] [stderr] | [INFO] [stderr] 105 | pub struct QA_Account { [INFO] [stderr] | ---------- fields in this struct [INFO] [stderr] 106 | init_cash: f64, [INFO] [stderr] 107 | init_hold: HashMap, [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] 108 | [INFO] [stderr] 109 | allow_t0: bool, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] 110 | allow_sellopen: bool, [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] 111 | allow_margin: bool, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] 112 | [INFO] [stderr] 113 | auto_reload: bool, [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] 114 | market_preset: MarketPreset, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 132 | commission_ratio: f64, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] 133 | // 手续费率 [INFO] [stderr] 134 | tax_ratio: f64, // tax for qaaccount [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `QA_Account` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: function `main` is never used [INFO] [stderr] --> src/qadata.rs:73:4 [INFO] [stderr] | [INFO] [stderr] 73 | fn main() { [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `message` is never used [INFO] [stderr] --> src/qaposition.rs:79:19 [INFO] [stderr] | [INFO] [stderr] 79 | pub(crate) fn message(&self) { [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `WithdrawQuota` should have a snake case name [INFO] [stderr] --> src/qaaccount.rs:74:9 [INFO] [stderr] | [INFO] [stderr] 74 | pub WithdrawQuota: f64, [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `withdraw_quota` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: method `get_codeSubscribed` should have a snake case name [INFO] [stderr] --> src/qaaccount.rs:518:12 [INFO] [stderr] | [INFO] [stderr] 518 | pub fn get_codeSubscribed(&mut self) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_code_subscribed` [INFO] [stderr] [INFO] [stderr] warning: variable `codeSub` should have a snake case name [INFO] [stderr] --> src/qaaccount.rs:524:17 [INFO] [stderr] | [INFO] [stderr] 524 | let mut codeSub = vec![]; [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `code_sub` [INFO] [stderr] [INFO] [stderr] warning: unused macro definition: `test_indicator` [INFO] [stderr] --> src/indicators/money_flow_index.rs:153:18 [INFO] [stderr] | [INFO] [stderr] 153 | macro_rules! test_indicator { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_macros)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `crate::qaaccount::QA_Account` [INFO] [stderr] --> src/trade_date.rs:1044:9 [INFO] [stderr] | [INFO] [stderr] 1044 | use crate::qaaccount::QA_Account; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `acc` [INFO] [stderr] --> src/qaaccount.rs:1001:17 [INFO] [stderr] | [INFO] [stderr] 1001 | let mut acc = QA_Account::new("RustT01B2_RBL8", "test", "admin", 100000.0, false, "real"); [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_acc` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `slice` [INFO] [stderr] --> src/qaaccount.rs:1276:13 [INFO] [stderr] | [INFO] [stderr] 1276 | let slice = acc.get_qifi_slice(); [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_slice` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `slice` [INFO] [stderr] --> src/qaaccount.rs:1295:13 [INFO] [stderr] | [INFO] [stderr] 1295 | let slice = acc.get_qifi_slice(); [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_slice` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/qaaccount.rs:991:13 [INFO] [stderr] | [INFO] [stderr] 991 | let mut acc = QA_Account::new( [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/qaaccount.rs:1001:13 [INFO] [stderr] | [INFO] [stderr] 1001 | let mut acc = QA_Account::new("RustT01B2_RBL8", "test", "admin", 100000.0, false, "real"); [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/qaposition.rs:466:13 [INFO] [stderr] | [INFO] [stderr] 466 | let mut pos = QA_Postions::new( [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/qaposition.rs:481:13 [INFO] [stderr] | [INFO] [stderr] 481 | let mut pos = QA_Postions::new( [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable `LLV_Indicator` should have a snake case name [INFO] [stderr] --> src/indicators/llv.rs:227:17 [INFO] [stderr] | [INFO] [stderr] 227 | let mut LLV_Indicator = LLV::new(3).unwrap(); [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `llv_indicator` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `LLV_Indicator` should have a snake case name [INFO] [stderr] --> src/indicators/llv.rs:250:17 [INFO] [stderr] | [INFO] [stderr] 250 | let mut LLV_Indicator = LLV::new_init(2, vec![3.0,4.0,3.0]).unwrap(); [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `llv_indicator` [INFO] [stderr] [INFO] [stderr] warning: variable `LLV_Indicator` should have a snake case name [INFO] [stderr] --> src/indicators/llv.rs:262:17 [INFO] [stderr] | [INFO] [stderr] 262 | let mut LLV_Indicator = LLV::new_init(4, vec![4.0,6.0,3.0]).unwrap(); [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `llv_indicator` [INFO] [stderr] [INFO] [stderr] warning: structure field `WithdrawQuota` should have a snake case name [INFO] [stderr] --> src/qaaccount.rs:74:9 [INFO] [stderr] | [INFO] [stderr] 74 | pub WithdrawQuota: f64, [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `withdraw_quota` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1052:9 [INFO] [stderr] | [INFO] [stderr] 1052 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1071:9 [INFO] [stderr] | [INFO] [stderr] 1071 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1090:9 [INFO] [stderr] | [INFO] [stderr] 1090 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1109:9 [INFO] [stderr] | [INFO] [stderr] 1109 | acc.sell_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1127:9 [INFO] [stderr] | [INFO] [stderr] 1127 | acc.sell_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1129:9 [INFO] [stderr] | [INFO] [stderr] 1129 | acc.buy_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1149:9 [INFO] [stderr] | [INFO] [stderr] 1149 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1151:9 [INFO] [stderr] | [INFO] [stderr] 1151 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1171:9 [INFO] [stderr] | [INFO] [stderr] 1171 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1175:9 [INFO] [stderr] | [INFO] [stderr] 1175 | acc.sell_close(code, 1000.0, "2020-01-20", 36.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1192:9 [INFO] [stderr] | [INFO] [stderr] 1192 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1203:9 [INFO] [stderr] | [INFO] [stderr] 1203 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1207:9 [INFO] [stderr] | [INFO] [stderr] 1207 | acc.sell(code, 10.0, "2020-01-22 22:10:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1217:9 [INFO] [stderr] | [INFO] [stderr] 1217 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1220:9 [INFO] [stderr] | [INFO] [stderr] 1220 | acc.sell(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: function `test_accountSlice` should have a snake case name [INFO] [stderr] --> src/qaaccount.rs:1225:8 [INFO] [stderr] | [INFO] [stderr] 1225 | fn test_accountSlice() { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_account_slice` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1238:9 [INFO] [stderr] | [INFO] [stderr] 1238 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1242:9 [INFO] [stderr] | [INFO] [stderr] 1242 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: function `test_accountSlice_for_qifi` should have a snake case name [INFO] [stderr] --> src/qaaccount.rs:1252:8 [INFO] [stderr] | [INFO] [stderr] 1252 | fn test_accountSlice_for_qifi() { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_account_slice_for_qifi` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1257:9 [INFO] [stderr] | [INFO] [stderr] 1257 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1261:9 [INFO] [stderr] | [INFO] [stderr] 1261 | acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1275:9 [INFO] [stderr] | [INFO] [stderr] 1275 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1281:9 [INFO] [stderr] | [INFO] [stderr] 1281 | new_acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1294:9 [INFO] [stderr] | [INFO] [stderr] 1294 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1300:9 [INFO] [stderr] | [INFO] [stderr] 1300 | new_acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1318:9 [INFO] [stderr] | [INFO] [stderr] 1318 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1322:9 [INFO] [stderr] | [INFO] [stderr] 1322 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1345:9 [INFO] [stderr] | [INFO] [stderr] 1345 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1352:9 [INFO] [stderr] | [INFO] [stderr] 1352 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1369:9 [INFO] [stderr] | [INFO] [stderr] 1369 | acc.buy_open(code, 10.0, "2020-01-22", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1398:9 [INFO] [stderr] | [INFO] [stderr] 1398 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1404:9 [INFO] [stderr] | [INFO] [stderr] 1404 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1428:9 [INFO] [stderr] | [INFO] [stderr] 1428 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1430:9 [INFO] [stderr] | [INFO] [stderr] 1430 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1435:9 [INFO] [stderr] | [INFO] [stderr] 1435 | acc.to_csv(); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1449:9 [INFO] [stderr] | [INFO] [stderr] 1449 | acc.buy_open("rb2005", 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:298:9 [INFO] [stderr] | [INFO] [stderr] 298 | acc.sell_open(code, 10.0, "2020-01-20 09:30:22", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:299:9 [INFO] [stderr] | [INFO] [stderr] 299 | acc.buy_open(code, 10.0, "2020-01-20 09:52:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:302:9 [INFO] [stderr] | [INFO] [stderr] 302 | acc.buy_close(code, 10.0, "2020-01-20 10:22:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:303:9 [INFO] [stderr] | [INFO] [stderr] 303 | acc.buy_open(code, 10.0, "2020-01-20 13:54:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:304:9 [INFO] [stderr] | [INFO] [stderr] 304 | acc.buy_open(code, 10.0, "2020-01-20 13:55:00", 3510.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:306:9 [INFO] [stderr] | [INFO] [stderr] 306 | acc.sell_close(code, 20.0, "2020-01-20 14:52:00", 3620.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:307:9 [INFO] [stderr] | [INFO] [stderr] 307 | acc.buy_open(code, 20.0, "2020-01-21 13:54:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:308:9 [INFO] [stderr] | [INFO] [stderr] 308 | acc.sell_close(code, 15.0, "2020-01-21 13:55:00", 3510.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:310:9 [INFO] [stderr] | [INFO] [stderr] 310 | acc.sell_close(code, 5.0, "2020-01-21 14:52:00", 3420.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:333:9 [INFO] [stderr] | [INFO] [stderr] 333 | acc.sell_open(code, 10.0, "2020-01-20 09:30:22", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:334:9 [INFO] [stderr] | [INFO] [stderr] 334 | acc.buy_open(code, 10.0, "2020-01-20 09:52:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:337:9 [INFO] [stderr] | [INFO] [stderr] 337 | acc.buy_close(code, 10.0, "2020-01-20 10:22:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:338:9 [INFO] [stderr] | [INFO] [stderr] 338 | acc.buy_open(code, 10.0, "2020-01-20 13:54:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:339:9 [INFO] [stderr] | [INFO] [stderr] 339 | acc.buy_open(code, 10.0, "2020-01-20 13:55:00", 3510.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:341:9 [INFO] [stderr] | [INFO] [stderr] 341 | acc.sell_close(code, 20.0, "2020-01-20 14:52:00", 3620.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:342:9 [INFO] [stderr] | [INFO] [stderr] 342 | acc.buy_open(code, 20.0, "2020-01-21 13:54:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:343:9 [INFO] [stderr] | [INFO] [stderr] 343 | acc.sell_close(code, 15.0, "2020-01-21 13:55:00", 3510.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:345:9 [INFO] [stderr] | [INFO] [stderr] 345 | acc.sell_close(code, 5.0, "2020-01-21 14:52:00", 3420.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:359:9 [INFO] [stderr] | [INFO] [stderr] 359 | acc.sell_open(code, 1000.0, "2020-04-03 09:30:22", 46.33); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:360:9 [INFO] [stderr] | [INFO] [stderr] 360 | acc.sell_open("RB2005", 10.0, "2020-04-03 09:30:22", 3346.33); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:361:9 [INFO] [stderr] | [INFO] [stderr] 361 | acc.buy_open(code, 1000.0, "2020-04-03 09:52:00", 46.86); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:363:9 [INFO] [stderr] | [INFO] [stderr] 363 | acc.buy_close(code, 1000.0, "2020-04-03 10:22:00", 47.34); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:364:9 [INFO] [stderr] | [INFO] [stderr] 364 | acc.sell_close(code, 1000.0, "2020-04-03 10:22:00", 47.34); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:365:9 [INFO] [stderr] | [INFO] [stderr] 365 | acc.buy_close("RB2005", 10.0, "2020-04-03 10:30:22", 3246.33); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:366:9 [INFO] [stderr] | [INFO] [stderr] 366 | acc.buy_open(code, 1000.0, "2020-04-03 13:54:00", 47.1); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:367:9 [INFO] [stderr] | [INFO] [stderr] 367 | acc.buy_open(code, 1000.0, "2020-04-03 13:55:00", 47.11); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:369:9 [INFO] [stderr] | [INFO] [stderr] 369 | acc.sell_close(code, 2000.0, "2020-04-03 14:52:00", 47.17); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:398:9 [INFO] [stderr] | [INFO] [stderr] 398 | acc.sell_open(code, 1000.0, "2020-04-03 09:30:22", 46.33); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:399:9 [INFO] [stderr] | [INFO] [stderr] 399 | acc.sell_open("RB2005", 10.0, "2020-04-03 09:30:22", 3346.33); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:400:9 [INFO] [stderr] | [INFO] [stderr] 400 | acc.buy_open(code, 1000.0, "2020-04-03 09:52:00", 46.86); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:402:9 [INFO] [stderr] | [INFO] [stderr] 402 | acc.buy_closetoday(code, 1000.0, "2020-04-03 10:22:00", 47.34); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:403:9 [INFO] [stderr] | [INFO] [stderr] 403 | acc.sell_closetoday(code, 1000.0, "2020-04-03 10:22:00", 47.34); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:404:9 [INFO] [stderr] | [INFO] [stderr] 404 | acc.buy_closetoday("RB2005", 10.0, "2020-04-03 10:30:22", 3246.33); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:405:9 [INFO] [stderr] | [INFO] [stderr] 405 | acc.buy_open(code, 1000.0, "2020-04-03 13:54:00", 47.1); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:406:9 [INFO] [stderr] | [INFO] [stderr] 406 | acc.buy_open(code, 1000.0, "2020-04-03 13:55:00", 47.11); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/qaperformance.rs:408:9 [INFO] [stderr] | [INFO] [stderr] 408 | acc.sell_closetoday(code, 2000.0, "2020-04-03 14:52:00", 47.17); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: `quantaxis-rs` (lib) generated 52 warnings (run `cargo fix --lib -p quantaxis-rs` to apply 31 suggestions) [INFO] [stderr] warning: `quantaxis-rs` (lib test) generated 135 warnings (50 duplicates) (run `cargo fix --lib -p quantaxis-rs --tests` to apply 8 suggestions) [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> src/main.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::io` [INFO] [stderr] --> src/main.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | use std::io; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::process` [INFO] [stderr] --> src/main.rs:9:5 [INFO] [stderr] | [INFO] [stderr] 9 | use std::process; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `ReaderBuilder`, `WriterBuilder` [INFO] [stderr] --> src/main.rs:11:11 [INFO] [stderr] | [INFO] [stderr] 11 | use csv::{ReaderBuilder, WriterBuilder}; [INFO] [stderr] | ^^^^^^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `array`, `stack` [INFO] [stderr] --> src/main.rs:12:15 [INFO] [stderr] | [INFO] [stderr] 12 | use ndarray::{array, stack}; [INFO] [stderr] | ^^^^^ ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `ndarray::prelude::*` [INFO] [stderr] --> src/main.rs:13:5 [INFO] [stderr] | [INFO] [stderr] 13 | use ndarray::prelude::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `serde_json` [INFO] [stderr] --> src/main.rs:14:5 [INFO] [stderr] | [INFO] [stderr] 14 | use serde_json; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `stopwatch::Stopwatch` [INFO] [stderr] --> src/main.rs:15:5 [INFO] [stderr] | [INFO] [stderr] 15 | use stopwatch::Stopwatch; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `bar` [INFO] [stderr] --> src/main.rs:37:26 [INFO] [stderr] | [INFO] [stderr] 37 | fn on_bar(&mut self, bar: qafetch::BAR) {} [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_bar` [INFO] [stderr] [INFO] [stderr] warning: associated function `create` is never used [INFO] [stderr] --> src/main.rs:30:8 [INFO] [stderr] | [INFO] [stderr] 30 | fn create() -> Self { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: associated function `init` is never used [INFO] [stderr] --> src/main.rs:35:8 [INFO] [stderr] | [INFO] [stderr] 35 | fn init(&mut self) {} [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `on_bar` is never used [INFO] [stderr] --> src/main.rs:37:8 [INFO] [stderr] | [INFO] [stderr] 37 | fn on_bar(&mut self, bar: qafetch::BAR) {} [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `run` is never used [INFO] [stderr] --> src/main.rs:39:8 [INFO] [stderr] | [INFO] [stderr] 39 | fn run(&mut self) {} [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `day_open` is never used [INFO] [stderr] --> src/main.rs:41:8 [INFO] [stderr] | [INFO] [stderr] 41 | fn day_open(&mut self) {} [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `day_close` is never used [INFO] [stderr] --> src/main.rs:43:8 [INFO] [stderr] | [INFO] [stderr] 43 | fn day_close(&mut self) {} [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `on_backtest_close` is never used [INFO] [stderr] --> src/main.rs:45:8 [INFO] [stderr] | [INFO] [stderr] 45 | fn on_backtest_close(&mut self) {} [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1052:9 [INFO] [stderr] | [INFO] [stderr] 1052 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1071:9 [INFO] [stderr] | [INFO] [stderr] 1071 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1090:9 [INFO] [stderr] | [INFO] [stderr] 1090 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1109:9 [INFO] [stderr] | [INFO] [stderr] 1109 | acc.sell_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1127:9 [INFO] [stderr] | [INFO] [stderr] 1127 | acc.sell_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1129:9 [INFO] [stderr] | [INFO] [stderr] 1129 | acc.buy_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1149:9 [INFO] [stderr] | [INFO] [stderr] 1149 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1151:9 [INFO] [stderr] | [INFO] [stderr] 1151 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1171:9 [INFO] [stderr] | [INFO] [stderr] 1171 | acc.buy_open(code, 1000.0, "2020-01-20", 35.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1175:9 [INFO] [stderr] | [INFO] [stderr] 1175 | acc.sell_close(code, 1000.0, "2020-01-20", 36.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1192:9 [INFO] [stderr] | [INFO] [stderr] 1192 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1203:9 [INFO] [stderr] | [INFO] [stderr] 1203 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1207:9 [INFO] [stderr] | [INFO] [stderr] 1207 | acc.sell(code, 10.0, "2020-01-22 22:10:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1217:9 [INFO] [stderr] | [INFO] [stderr] 1217 | acc.buy(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1220:9 [INFO] [stderr] | [INFO] [stderr] 1220 | acc.sell(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1238:9 [INFO] [stderr] | [INFO] [stderr] 1238 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1242:9 [INFO] [stderr] | [INFO] [stderr] 1242 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1257:9 [INFO] [stderr] | [INFO] [stderr] 1257 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1261:9 [INFO] [stderr] | [INFO] [stderr] 1261 | acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1275:9 [INFO] [stderr] | [INFO] [stderr] 1275 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1281:9 [INFO] [stderr] | [INFO] [stderr] 1281 | new_acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1294:9 [INFO] [stderr] | [INFO] [stderr] 1294 | acc.buy_open(code, 10.0, "2020-01-20 22:10:00", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1300:9 [INFO] [stderr] | [INFO] [stderr] 1300 | new_acc.sell_close(code, 10.0, "2020-01-20 22:10:00", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1318:9 [INFO] [stderr] | [INFO] [stderr] 1318 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1322:9 [INFO] [stderr] | [INFO] [stderr] 1322 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1345:9 [INFO] [stderr] | [INFO] [stderr] 1345 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1352:9 [INFO] [stderr] | [INFO] [stderr] 1352 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1369:9 [INFO] [stderr] | [INFO] [stderr] 1369 | acc.buy_open(code, 10.0, "2020-01-22", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1398:9 [INFO] [stderr] | [INFO] [stderr] 1398 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1404:9 [INFO] [stderr] | [INFO] [stderr] 1404 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1428:9 [INFO] [stderr] | [INFO] [stderr] 1428 | acc.buy_open(code, 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1430:9 [INFO] [stderr] | [INFO] [stderr] 1430 | acc.sell_close(code, 10.0, "2020-01-20", 3600.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1435:9 [INFO] [stderr] | [INFO] [stderr] 1435 | acc.to_csv(); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/qaaccount.rs:1449:9 [INFO] [stderr] | [INFO] [stderr] 1449 | acc.buy_open("rb2005", 10.0, "2020-01-20", 3500.0); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::borrow::BorrowMut` [INFO] [stderr] --> examples/t01b2D.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | use std::borrow::BorrowMut; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `max`, `min` [INFO] [stderr] --> examples/t01b2D.rs:9:16 [INFO] [stderr] | [INFO] [stderr] 9 | use std::cmp::{max, min}; [INFO] [stderr] | ^^^ ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `array`, `stack` [INFO] [stderr] --> examples/t01b2D.rs:13:15 [INFO] [stderr] | [INFO] [stderr] 13 | use ndarray::{array, stack}; [INFO] [stderr] | ^^^^^ ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `indicators`, `qadata`, `qaindicator`, `qaposition`, `transaction` [INFO] [stderr] --> examples/t01b2D.rs:17:5 [INFO] [stderr] | [INFO] [stderr] 17 | indicators, Next, qaaccount, qadata, qafetch, qaindicator, qaposition, transaction, [INFO] [stderr] | ^^^^^^^^^^ ^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `BollingerBands`, `EfficiencyRatio`, `ExponentialMovingAverage`, `FastStochastic`, `Maximum`, `Minimum`, `MoneyFlowIndex`, `MovingAverageConvergenceDivergence`, `OnBalanceVolume`, `RateOfChange`, `RelativeStrengthIndex`, `SimpleMovingAverage`, `SlowStochastic`, `StandardDeviation`, `TrueRange` [INFO] [stderr] --> examples/t01b2D.rs:20:5 [INFO] [stderr] | [INFO] [stderr] 20 | BollingerBands, EfficiencyRatio, ExponentialMovingAverage, FastStochastic, HHV, LLV, [INFO] [stderr] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stderr] 21 | Maximum, Minimum, MoneyFlowIndex, MovingAverage, [INFO] [stderr] | ^^^^^^^ ^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stderr] 22 | MovingAverageConvergenceDivergence, OnBalanceVolume, RateOfChange, RelativeStrengthIndex, SimpleMovingAverage, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 23 | SlowStochastic, StandardDeviation, TrueRange, [INFO] [stderr] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `quantaxis_rs::qaposition::QA_Postions` [INFO] [stderr] --> examples/t01b2D.rs:26:5 [INFO] [stderr] | [INFO] [stderr] 26 | use quantaxis_rs::qaposition::QA_Postions; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> examples/t01b2D.rs:163:28 [INFO] [stderr] | [INFO] [stderr] 163 | stopLine = (HAE * (1.0 - TrailingStop1 / 1000.0)); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 163 - stopLine = (HAE * (1.0 - TrailingStop1 / 1000.0)); [INFO] [stderr] 163 + stopLine = HAE * (1.0 - TrailingStop1 / 1000.0); [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> examples/t01b2D.rs:191:28 [INFO] [stderr] | [INFO] [stderr] 191 | stopLine = (LAE * (1.0 + TrailingStop1 / 1000.0)); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 191 - stopLine = (LAE * (1.0 + TrailingStop1 / 1000.0)); [INFO] [stderr] 191 + stopLine = LAE * (1.0 + TrailingStop1 / 1000.0); [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused variable: `priceoffset` [INFO] [stderr] --> examples/t01b2D.rs:63:9 [INFO] [stderr] | [INFO] [stderr] 63 | let priceoffset = 1; [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_priceoffset` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `count1` [INFO] [stderr] --> examples/t01b2D.rs:69:9 [INFO] [stderr] | [INFO] [stderr] 69 | let count1 = 0; [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_count1` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ind_llv` [INFO] [stderr] --> examples/t01b2D.rs:103:13 [INFO] [stderr] | [INFO] [stderr] 103 | let ind_llv = llv_i.next(bar.low); [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_llv` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ind_hhv` [INFO] [stderr] --> examples/t01b2D.rs:104:13 [INFO] [stderr] | [INFO] [stderr] 104 | let ind_hhv = hhv_i.next(bar.high); [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_hhv` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ind_ma` [INFO] [stderr] --> examples/t01b2D.rs:105:13 [INFO] [stderr] | [INFO] [stderr] 105 | let ind_ma = ma.next(bar.open); [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_ma` [INFO] [stderr] [INFO] [stderr] warning: crate `t01b2D` should have a snake case name [INFO] [stderr] | [INFO] [stderr] = help: convert the identifier to snake case: `t01b2_d` [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `lossP` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:64:9 [INFO] [stderr] | [INFO] [stderr] 64 | let lossP = 1.3; [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `loss_p` [INFO] [stderr] [INFO] [stderr] warning: variable `K1` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:65:9 [INFO] [stderr] | [INFO] [stderr] 65 | let K1: usize = 20; [INFO] [stderr] | ^^ help: convert the identifier to snake case (notice the capitalization): `k1` [INFO] [stderr] [INFO] [stderr] warning: variable `K2` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:66:9 [INFO] [stderr] | [INFO] [stderr] 66 | let K2: usize = 20; [INFO] [stderr] | ^^ help: convert the identifier to snake case (notice the capitalization): `k2` [INFO] [stderr] [INFO] [stderr] warning: variable `HAE` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:70:13 [INFO] [stderr] | [INFO] [stderr] 70 | let mut HAE: f64 = 0 as f64; [INFO] [stderr] | ^^^ help: convert the identifier to snake case: `hae` [INFO] [stderr] [INFO] [stderr] warning: variable `LAE` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:71:13 [INFO] [stderr] | [INFO] [stderr] 71 | let mut LAE: f64 = 0 as f64; [INFO] [stderr] | ^^^ help: convert the identifier to snake case: `lae` [INFO] [stderr] [INFO] [stderr] warning: variable `TrailingStart1` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:72:9 [INFO] [stderr] | [INFO] [stderr] 72 | let TrailingStart1 = 90.0; [INFO] [stderr] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `trailing_start1` [INFO] [stderr] [INFO] [stderr] warning: variable `TrailingStop1` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:73:9 [INFO] [stderr] | [INFO] [stderr] 73 | let TrailingStop1 = 10.0; [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `trailing_stop1` [INFO] [stderr] [INFO] [stderr] warning: variable `crossOver` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:107:13 [INFO] [stderr] | [INFO] [stderr] 107 | let crossOver = bar.high > hhv_i.cached[K1 - 2] && lastbar.high < hhv_i.cached[K1 - 2]; [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `cross_over` [INFO] [stderr] [INFO] [stderr] warning: variable `crossUnder` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:110:13 [INFO] [stderr] | [INFO] [stderr] 110 | let crossUnder = bar.low < llv_i.cached[K2 - 2] && lastbar.low > llv_i.cached[K2 - 2]; [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `cross_under` [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2D.rs:139:17 [INFO] [stderr] | [INFO] [stderr] 139 | / acc.buy_open( [INFO] [stderr] 140 | | bar.code.as_ref(), [INFO] [stderr] 141 | | 10.0, [INFO] [stderr] 142 | | bar.datetime.as_ref(), [INFO] [stderr] 143 | | compare_max(bar.open, hhv_i.cached[K1 - 2]), [INFO] [stderr] 144 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2D.rs:146:17 [INFO] [stderr] | [INFO] [stderr] 146 | / acc.sell_open( [INFO] [stderr] 147 | | bar.code.as_ref(), [INFO] [stderr] 148 | | 10.0, [INFO] [stderr] 149 | | bar.datetime.as_ref(), [INFO] [stderr] 150 | | compare_min(bar.open, llv_i.cached[K2 - 2]), [INFO] [stderr] 151 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: variable `stopLine` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:157:21 [INFO] [stderr] | [INFO] [stderr] 157 | let mut stopLine: f64 = acc.get_open_price_long(code) * (100.0 - lossP) / 100.0; [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `stop_line` [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2D.rs:168:17 [INFO] [stderr] | [INFO] [stderr] 168 | / acc.sell_close( [INFO] [stderr] 169 | | code, [INFO] [stderr] 170 | | 10.0, [INFO] [stderr] 171 | | bar.datetime.as_ref(), [INFO] [stderr] 172 | | compare_min(bar.open, llv_i.cached[K2 - 2]), [INFO] [stderr] 173 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2D.rs:176:17 [INFO] [stderr] | [INFO] [stderr] 176 | / acc.sell_close( [INFO] [stderr] 177 | | code, [INFO] [stderr] 178 | | 10.0, [INFO] [stderr] 179 | | bar.datetime.as_ref(), [INFO] [stderr] 180 | | compare_min(bar.open, stopLine), [INFO] [stderr] 181 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: variable `stopLine` should have a snake case name [INFO] [stderr] --> examples/t01b2D.rs:186:21 [INFO] [stderr] | [INFO] [stderr] 186 | let mut stopLine: f64 = acc.get_open_price_short(code) * (100.0 + lossP) / 100.0; [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `stop_line` [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2D.rs:195:17 [INFO] [stderr] | [INFO] [stderr] 195 | / acc.buy_close( [INFO] [stderr] 196 | | code, [INFO] [stderr] 197 | | 10.0, [INFO] [stderr] 198 | | bar.datetime.as_ref(), [INFO] [stderr] 199 | | compare_max(bar.open, hhv_i.cached[K1 - 2]), [INFO] [stderr] 200 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2D.rs:205:17 [INFO] [stderr] | [INFO] [stderr] 205 | / acc.buy_close( [INFO] [stderr] 206 | | code, [INFO] [stderr] 207 | | 10.0, [INFO] [stderr] 208 | | bar.datetime.as_ref(), [INFO] [stderr] 209 | | compare_max(bar.open, stopLine), [INFO] [stderr] 210 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2D.rs:229:5 [INFO] [stderr] | [INFO] [stderr] 229 | acc.to_csv(); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::borrow::BorrowMut` [INFO] [stderr] --> examples/t01b2.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | use std::borrow::BorrowMut; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `max`, `min` [INFO] [stderr] --> examples/t01b2.rs:9:16 [INFO] [stderr] | [INFO] [stderr] 9 | use std::cmp::{max, min}; [INFO] [stderr] | ^^^ ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `array`, `stack` [INFO] [stderr] --> examples/t01b2.rs:13:15 [INFO] [stderr] | [INFO] [stderr] 13 | use ndarray::{array, stack}; [INFO] [stderr] | ^^^^^ ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `indicators`, `qadata`, `qaindicator`, `qaposition`, `transaction` [INFO] [stderr] --> examples/t01b2.rs:17:5 [INFO] [stderr] | [INFO] [stderr] 17 | indicators, Next, qaaccount, qadata, qafetch, qaindicator, qaposition, transaction, [INFO] [stderr] | ^^^^^^^^^^ ^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `BollingerBands`, `EfficiencyRatio`, `ExponentialMovingAverage`, `FastStochastic`, `Maximum`, `Minimum`, `MoneyFlowIndex`, `MovingAverageConvergenceDivergence`, `OnBalanceVolume`, `RateOfChange`, `RelativeStrengthIndex`, `SimpleMovingAverage`, `SlowStochastic`, `StandardDeviation`, `TrueRange` [INFO] [stderr] --> examples/t01b2.rs:20:5 [INFO] [stderr] | [INFO] [stderr] 20 | BollingerBands, EfficiencyRatio, ExponentialMovingAverage, FastStochastic, HHV, LLV, [INFO] [stderr] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stderr] 21 | Maximum, Minimum, MoneyFlowIndex, MovingAverage, [INFO] [stderr] | ^^^^^^^ ^^^^^^^ ^^^^^^^^^^^^^^ [INFO] [stderr] 22 | MovingAverageConvergenceDivergence, OnBalanceVolume, RateOfChange, RelativeStrengthIndex, SimpleMovingAverage, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^ ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] 23 | SlowStochastic, StandardDeviation, TrueRange, [INFO] [stderr] | ^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `quantaxis_rs::qaposition::QA_Postions` [INFO] [stderr] --> examples/t01b2.rs:26:5 [INFO] [stderr] | [INFO] [stderr] 26 | use quantaxis_rs::qaposition::QA_Postions; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> examples/t01b2.rs:165:28 [INFO] [stderr] | [INFO] [stderr] 165 | stopLine = (HAE * (1.0 - TrailingStop1 / 1000.0)); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 165 - stopLine = (HAE * (1.0 - TrailingStop1 / 1000.0)); [INFO] [stderr] 165 + stopLine = HAE * (1.0 - TrailingStop1 / 1000.0); [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> examples/t01b2.rs:168:16 [INFO] [stderr] | [INFO] [stderr] 168 | if (crossUnder && cond2) { [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 168 - if (crossUnder && cond2) { [INFO] [stderr] 168 + if crossUnder && cond2 { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> examples/t01b2.rs:177:23 [INFO] [stderr] | [INFO] [stderr] 177 | } else if (bar.low < stopLine) { [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 177 - } else if (bar.low < stopLine) { [INFO] [stderr] 177 + } else if bar.low < stopLine { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> examples/t01b2.rs:188:12 [INFO] [stderr] | [INFO] [stderr] 188 | if (short_pos > 0.0 && long_pos == 0.0) { [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 188 - if (short_pos > 0.0 && long_pos == 0.0) { [INFO] [stderr] 188 + if short_pos > 0.0 && long_pos == 0.0 { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> examples/t01b2.rs:192:16 [INFO] [stderr] | [INFO] [stderr] 192 | if (LAE >= (acc.get_open_price_short(code) * (1.0 - TrailingStart1 / 1000.0) as f64) [INFO] [stderr] | ^ [INFO] [stderr] 193 | && bar_id - count1 >= 1) [INFO] [stderr] | ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 192 ~ if LAE >= (acc.get_open_price_short(code) * (1.0 - TrailingStart1 / 1000.0) as f64) [INFO] [stderr] 193 ~ && bar_id - count1 >= 1 [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> examples/t01b2.rs:195:28 [INFO] [stderr] | [INFO] [stderr] 195 | stopLine = (LAE * (1.0 + TrailingStop1 / 1000.0)); [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 195 - stopLine = (LAE * (1.0 + TrailingStop1 / 1000.0)); [INFO] [stderr] 195 + stopLine = LAE * (1.0 + TrailingStop1 / 1000.0); [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> examples/t01b2.rs:205:23 [INFO] [stderr] | [INFO] [stderr] 205 | } else if (bar.high >= stopLine) { [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 205 - } else if (bar.high >= stopLine) { [INFO] [stderr] 205 + } else if bar.high >= stopLine { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> examples/t01b2.rs:215:12 [INFO] [stderr] | [INFO] [stderr] 215 | if (short_pos == 0.0 && long_pos == 0.0) { [INFO] [stderr] | ^ ^ [INFO] [stderr] | [INFO] [stderr] help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] 215 - if (short_pos == 0.0 && long_pos == 0.0) { [INFO] [stderr] 215 + if short_pos == 0.0 && long_pos == 0.0 { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused variable: `priceoffset` [INFO] [stderr] --> examples/t01b2.rs:63:9 [INFO] [stderr] | [INFO] [stderr] 63 | let priceoffset = 2; [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_priceoffset` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ind_llv` [INFO] [stderr] --> examples/t01b2.rs:101:13 [INFO] [stderr] | [INFO] [stderr] 101 | let ind_llv = llv_i.next(bar.low); [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_llv` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ind_hhv` [INFO] [stderr] --> examples/t01b2.rs:102:13 [INFO] [stderr] | [INFO] [stderr] 102 | let ind_hhv = hhv_i.next(bar.high); [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_hhv` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ind_ma` [INFO] [stderr] --> examples/t01b2.rs:103:13 [INFO] [stderr] | [INFO] [stderr] 103 | let ind_ma = ma.next(bar.open); [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_ind_ma` [INFO] [stderr] [INFO] [stderr] warning: variable `lossP` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:64:9 [INFO] [stderr] | [INFO] [stderr] 64 | let lossP = 1.3; [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `loss_p` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `K1` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:65:9 [INFO] [stderr] | [INFO] [stderr] 65 | let K1: usize = 20; [INFO] [stderr] | ^^ help: convert the identifier to snake case (notice the capitalization): `k1` [INFO] [stderr] [INFO] [stderr] warning: variable `K2` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:66:9 [INFO] [stderr] | [INFO] [stderr] 66 | let K2: usize = 20; [INFO] [stderr] | ^^ help: convert the identifier to snake case (notice the capitalization): `k2` [INFO] [stderr] [INFO] [stderr] warning: variable `HAE` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:70:13 [INFO] [stderr] | [INFO] [stderr] 70 | let mut HAE: f64 = 0 as f64; [INFO] [stderr] | ^^^ help: convert the identifier to snake case: `hae` [INFO] [stderr] [INFO] [stderr] warning: variable `LAE` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:71:13 [INFO] [stderr] | [INFO] [stderr] 71 | let mut LAE: f64 = 0 as f64; [INFO] [stderr] | ^^^ help: convert the identifier to snake case: `lae` [INFO] [stderr] [INFO] [stderr] warning: variable `TrailingStart1` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:72:9 [INFO] [stderr] | [INFO] [stderr] 72 | let TrailingStart1 = 90.0; [INFO] [stderr] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `trailing_start1` [INFO] [stderr] [INFO] [stderr] warning: variable `TrailingStop1` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:73:9 [INFO] [stderr] | [INFO] [stderr] 73 | let TrailingStop1 = 10.0; [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `trailing_stop1` [INFO] [stderr] [INFO] [stderr] warning: variable `crossOver` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:104:13 [INFO] [stderr] | [INFO] [stderr] 104 | let crossOver = bar.high > hhv_i.cached[K1 - 2] && lastbar.high < hhv_i.cached[K1 - 2]; [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `cross_over` [INFO] [stderr] [INFO] [stderr] warning: variable `crossUnder` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:106:13 [INFO] [stderr] | [INFO] [stderr] 106 | let crossUnder = bar.low < llv_i.cached[K2 - 2] && lastbar.low > llv_i.cached[K2 - 2]; [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `cross_under` [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2.rs:135:17 [INFO] [stderr] | [INFO] [stderr] 135 | / acc.buy_open( [INFO] [stderr] 136 | | bar.code.as_ref(), [INFO] [stderr] 137 | | 90.0, [INFO] [stderr] 138 | | bar.datetime.as_ref(), [INFO] [stderr] 139 | | compare_max(bar.open, hhv_i.cached[K1 - 2]), [INFO] [stderr] 140 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2.rs:146:17 [INFO] [stderr] | [INFO] [stderr] 146 | / acc.sell_open( [INFO] [stderr] 147 | | bar.code.as_ref(), [INFO] [stderr] 148 | | 90.0, [INFO] [stderr] 149 | | bar.datetime.as_ref(), [INFO] [stderr] 150 | | compare_min(bar.open, llv_i.cached[K2 - 2]), [INFO] [stderr] 151 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: variable `stopLine` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:160:21 [INFO] [stderr] | [INFO] [stderr] 160 | let mut stopLine: f64 = acc.get_open_price_long(code) * (100.0 - lossP) / 100.0; [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `stop_line` [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2.rs:171:17 [INFO] [stderr] | [INFO] [stderr] 171 | / acc.sell_close( [INFO] [stderr] 172 | | code, [INFO] [stderr] 173 | | 90.0, [INFO] [stderr] 174 | | bar.datetime.as_ref(), [INFO] [stderr] 175 | | compare_min(bar.open, llv_i.cached[K2 - 2]), [INFO] [stderr] 176 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2.rs:180:17 [INFO] [stderr] | [INFO] [stderr] 180 | / acc.sell_close( [INFO] [stderr] 181 | | code, [INFO] [stderr] 182 | | 90.0, [INFO] [stderr] 183 | | bar.datetime.as_ref(), [INFO] [stderr] 184 | | compare_min(bar.open, stopLine), [INFO] [stderr] 185 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: variable `stopLine` should have a snake case name [INFO] [stderr] --> examples/t01b2.rs:190:21 [INFO] [stderr] | [INFO] [stderr] 190 | let mut stopLine: f64 = acc.get_open_price_short(code) * (100.0 + lossP) / 100.0; [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `stop_line` [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2.rs:199:17 [INFO] [stderr] | [INFO] [stderr] 199 | / acc.buy_close( [INFO] [stderr] 200 | | code, [INFO] [stderr] 201 | | 90.0, [INFO] [stderr] 202 | | bar.datetime.as_ref(), [INFO] [stderr] 203 | | compare_max(bar.open, hhv_i.cached[K1 - 2]), [INFO] [stderr] 204 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2.rs:207:17 [INFO] [stderr] | [INFO] [stderr] 207 | / acc.buy_close( [INFO] [stderr] 208 | | code, [INFO] [stderr] 209 | | 90.0, [INFO] [stderr] 210 | | bar.datetime.as_ref(), [INFO] [stderr] 211 | | compare_max(bar.open, stopLine), [INFO] [stderr] 212 | | ); [INFO] [stderr] | |_________________^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> examples/t01b2.rs:235:5 [INFO] [stderr] | [INFO] [stderr] 235 | acc.to_csv(); [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::runtime::Builder` [INFO] [stderr] --> examples/x1.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use tokio::runtime::Builder; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::sync::oneshot` [INFO] [stderr] --> examples/x1.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use tokio::sync::oneshot; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::rc::Rc` [INFO] [stderr] --> examples/x1.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::rc::Rc; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::cell::RefCell` [INFO] [stderr] --> examples/x1.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use std::cell::RefCell; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::borrow::BorrowMut` [INFO] [stderr] --> examples/x1.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use std::borrow::BorrowMut; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::runtime` [INFO] [stderr] --> examples/x1.rs:9:5 [INFO] [stderr] | [INFO] [stderr] 9 | use tokio::runtime; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::ops::DerefMut` [INFO] [stderr] --> examples/x1.rs:10:5 [INFO] [stderr] | [INFO] [stderr] 10 | use std::ops::DerefMut; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `order` [INFO] [stderr] --> examples/x1.rs:26:13 [INFO] [stderr] | [INFO] [stderr] 26 | let order = acc_mut.send_order_async(&code, 10.0, "2020-01-20 22:10:00", 2, 3500.0, "BUY_OPEN"); [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_order` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> examples/x1.rs:23:9 [INFO] [stderr] | [INFO] [stderr] 23 | let mut ac1= ac.clone(); [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: function `some_computation` is never used [INFO] [stderr] --> examples/x1.rs:12:10 [INFO] [stderr] | [INFO] [stderr] 12 | async fn some_computation() -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `#[macro_use]` import [INFO] [stderr] --> examples/qadata.rs:2:1 [INFO] [stderr] | [INFO] [stderr] 2 | #[macro_use] [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `num_traits::real::Real` [INFO] [stderr] --> examples/qadata.rs:9:5 [INFO] [stderr] | [INFO] [stderr] 9 | use num_traits::real::Real; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::runtime::Builder` [INFO] [stderr] --> examples/asynctest.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use tokio::runtime::Builder; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::sync::oneshot` [INFO] [stderr] --> examples/asynctest.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use tokio::sync::oneshot; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::task` [INFO] [stderr] --> examples/asynctest.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use tokio::task; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::rc::Rc` [INFO] [stderr] --> examples/asynctest.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::rc::Rc; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::cell::RefCell` [INFO] [stderr] --> examples/asynctest.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use std::cell::RefCell; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::borrow::BorrowMut` [INFO] [stderr] --> examples/asynctest.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use std::borrow::BorrowMut; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Arc`, `Mutex` [INFO] [stderr] --> examples/asynctest.rs:8:17 [INFO] [stderr] | [INFO] [stderr] 8 | use std::sync::{Arc, Mutex}; [INFO] [stderr] | ^^^ ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::runtime` [INFO] [stderr] --> examples/asynctest.rs:9:5 [INFO] [stderr] | [INFO] [stderr] 9 | use tokio::runtime; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `some_computation` is never used [INFO] [stderr] --> examples/asynctest.rs:12:10 [INFO] [stderr] | [INFO] [stderr] 12 | async fn some_computation() -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::borrow::BorrowMut` [INFO] [stderr] --> examples/x2.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::borrow::BorrowMut; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::cell::RefCell` [INFO] [stderr] --> examples/x2.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::cell::RefCell; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::rc::Rc` [INFO] [stderr] --> examples/x2.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::rc::Rc; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Arc`, `Mutex` [INFO] [stderr] --> examples/x2.rs:4:17 [INFO] [stderr] | [INFO] [stderr] 4 | use std::sync::{Arc, Mutex}; [INFO] [stderr] | ^^^ ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::runtime` [INFO] [stderr] --> examples/x2.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use tokio::runtime; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::runtime::Builder` [INFO] [stderr] --> examples/x2.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use tokio::runtime::Builder; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::sync::oneshot` [INFO] [stderr] --> examples/x2.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | use tokio::sync::oneshot; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `acc` [INFO] [stderr] --> examples/x2.rs:41:10 [INFO] [stderr] | [INFO] [stderr] 41 | let (acc, code) = join.await.unwrap(); [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_acc` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `code` [INFO] [stderr] --> examples/x2.rs:41:15 [INFO] [stderr] | [INFO] [stderr] 41 | let (acc, code) = join.await.unwrap(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_code` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `acc2` [INFO] [stderr] --> examples/x2.rs:42:10 [INFO] [stderr] | [INFO] [stderr] 42 | let (acc2, code2) = join2.await.unwrap(); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_acc2` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `code2` [INFO] [stderr] --> examples/x2.rs:42:16 [INFO] [stderr] | [INFO] [stderr] 42 | let (acc2, code2) = join2.await.unwrap(); [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_code2` [INFO] [stderr] [INFO] [stderr] warning: function `some_computation` is never used [INFO] [stderr] --> examples/x2.rs:13:10 [INFO] [stderr] | [INFO] [stderr] 13 | async fn some_computation() -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: `quantaxis-rs` (bin "quantaxis-rs" test) generated 102 warnings (52 duplicates) (run `cargo fix --bin "quantaxis-rs" --tests` to apply 9 suggestions) [INFO] [stderr] warning: `quantaxis-rs` (example "t01b2D") generated 32 warnings (run `cargo fix --example "t01b2D"` to apply 13 suggestions) [INFO] [stderr] warning: `quantaxis-rs` (example "t01b2") generated 36 warnings (run `cargo fix --example "t01b2"` to apply 18 suggestions) [INFO] [stderr] warning: `quantaxis-rs` (example "x1") generated 10 warnings (run `cargo fix --example "x1"` to apply 9 suggestions) [INFO] [stderr] warning: `quantaxis-rs` (example "qadata") generated 2 warnings [INFO] [stderr] warning: `quantaxis-rs` (example "asynctest") generated 9 warnings (run `cargo fix --example "asynctest"` to apply 8 suggestions) [INFO] [stderr] warning: `quantaxis-rs` (bin "quantaxis-rs") generated 59 warnings (59 duplicates) [INFO] [stderr] warning: `quantaxis-rs` (example "x2") generated 12 warnings (run `cargo fix --example "x2"` to apply 11 suggestions) [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.31s [INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: rustc-serialize v0.3.24 [INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 3` [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/quantaxis_rs-6d6f30a04b8b49e2) [INFO] [stdout] [INFO] [stdout] running 172 tests [INFO] [stdout] test indicators::bollinger_bands::tests::test_display ... ok [INFO] [stdout] test indicators::bollinger_bands::tests::test_indicator ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_default ... ok [INFO] [stdout] test helpers::tests::test_max3 ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_display ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_reset ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_indicator ... ok [INFO] [stdout] test indicators::bollinger_bands::tests::test_default ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_next ... ok [INFO] [stdout] test indicators::bollinger_bands::tests::test_reset ... ok [INFO] [stdout] test indicators::efficiency_ratio::tests::test_display ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_default ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_display ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_indicator ... ok [INFO] [stdout] test indicators::efficiency_ratio::tests::test_next_f64 ... ok [INFO] [stdout] test indicators::efficiency_ratio::tests::test_indicator ... ok [INFO] [stdout] test indicators::bollinger_bands::tests::test_next ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_new ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_reset ... ok [INFO] [stdout] test indicators::bollinger_bands::tests::test_new ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_update ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_new ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_next ... ok [INFO] [stdout] test indicators::hhv::tests::test_indicator ... ok [INFO] [stdout] test indicators::hhv::tests::test_new ... ok [INFO] [stdout] test indicators::hhv::tests::test_next ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_indicator ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::hhv::tests::test_update ... ok [INFO] [stdout] test indicators::llv::tests::test_display ... ok [INFO] [stdout] test indicators::llv::tests::test_default ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_default ... ok [INFO] [stdout] test indicators::llv::tests::test_indicator ... ok [INFO] [stdout] test indicators::llv::tests::test_newx ... ok [INFO] [stdout] test indicators::llv::tests::test_next ... ok [INFO] [stdout] test indicators::llv::tests::test_reset ... ok [INFO] [stdout] test indicators::llv::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::llv::tests::test_new_notenough ... ok [INFO] [stdout] test indicators::llv::tests::test_update ... ok [INFO] [stdout] test indicators::maximum::tests::test_default ... ok [INFO] [stdout] test indicators::efficiency_ratio::tests::test_new ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_display ... ok [INFO] [stdout] test indicators::maximum::tests::test_display ... ok [INFO] [stdout] test indicators::maximum::tests::test_indicator ... ok [INFO] [stdout] test indicators::maximum::tests::test_new ... ok [INFO] [stdout] test indicators::maximum::tests::test_next ... ok [INFO] [stdout] test indicators::maximum::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_reset ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_next_with_f64 ... ok [INFO] [stdout] test indicators::hhv::tests::test_default ... ok [INFO] [stdout] test indicators::hhv::tests::test_display ... ok [INFO] [stdout] test indicators::hhv::tests::test_reset ... ok [INFO] [stdout] test indicators::hhv::tests::test_next_with_bars ... ok [INFO] [stdout] test data_item::tests::test_builder ... ok [INFO] [stdout] test indicators::maximum::tests::test_reset ... ok [INFO] [stdout] test indicators::minimum::tests::test_indicator ... ok [INFO] [stdout] test indicators::minimum::tests::test_next ... ok [INFO] [stdout] test indicators::money_flow_index::tests::test_default ... ok [INFO] [stdout] test indicators::minimum::tests::test_reset ... ok [INFO] [stdout] test indicators::minimum::tests::test_default ... ok [INFO] [stdout] test indicators::minimum::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::llv::tests::test_new ... ok [INFO] [stdout] test indicators::minimum::tests::test_new ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_new ... ok [INFO] [stdout] test indicators::minimum::tests::test_display ... ok [INFO] [stdout] test indicators::money_flow_index::tests::test_new ... ok [INFO] [stdout] test indicators::money_flow_index::tests::test_display ... ok [INFO] [stdout] test indicators::money_flow_index::tests::test_next_bar ... ok [INFO] [stdout] test indicators::moving_average::tests::test_cached ... ok [INFO] [stdout] test indicators::moving_average::tests::test_new ... ok [INFO] [stdout] test indicators::moving_average::tests::test_default ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_reset ... ok [INFO] [stdout] test indicators::moving_average::tests::test_display ... ok [INFO] [stdout] test indicators::moving_average::tests::test_real ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_display ... ok [INFO] [stdout] test indicators::moving_average::tests::test_update ... ok [INFO] [stdout] test indicators::moving_average::tests::test_next ... ok [INFO] [stdout] test indicators::on_balance_volume::tests::test_default ... ok [INFO] [stdout] test indicators::moving_average::tests::test_indicator ... ok [INFO] [stdout] test indicators::money_flow_index::tests::test_reset ... ok [INFO] [stdout] test indicators::moving_average::tests::test_reset ... ok [INFO] [stdout] test indicators::on_balance_volume::tests::test_reset ... ok [INFO] [stdout] test indicators::on_balance_volume::tests::test_next_bar ... ok [INFO] [stdout] test indicators::on_balance_volume::tests::test_display ... ok [INFO] [stdout] test indicators::rate_of_change::tests::test_indicator ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_indicator ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_default ... ok [INFO] [stdout] test indicators::moving_average::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_macd ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_new ... ok [INFO] [stdout] test indicators::rate_of_change::tests::test_next_bar ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_default ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_display ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_display ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_new ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_display ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_indicator ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_new ... ok [INFO] [stdout] test indicators::rate_of_change::tests::test_new ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_reset ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_next_with_f64 ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_display ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_reset ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_indicator ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_new ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_next ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_next_same_values ... ok [INFO] [stdout] test indicators::true_range::tests::test_default ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::true_range::tests::test_indicator ... ok [INFO] [stdout] test indicators::true_range::tests::test_next_f64 ... ok [INFO] [stdout] test indicators::true_range::tests::test_display ... ok [INFO] [stdout] test indicators::true_range::tests::test_next_bar ... ok [INFO] [stdout] test indicators::true_range::tests::test_update_f64 ... ok [INFO] [stdout] test indicators::true_range::tests::test_reset ... ok [INFO] [stdout] test qaaccount::tests::test_buy_close ... ok [INFO] [stdout] test qaaccount::tests::test_accountSlice ... ok [INFO] [stdout] test indicators::rate_of_change::tests::test_reset ... ok [INFO] [stdout] test qaaccount::tests::test_get_info ... ok [INFO] [stdout] test qaaccount::tests::test_buy_open_for_stock ... ok [INFO] [stdout] test qaaccount::tests::test_accountSlice_for_qifi ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_new ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_indicator ... ok [INFO] [stdout] test indicators::rate_of_change::tests::test_next_f64 ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_default ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_reset ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_reset ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_default ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_next ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_indicator ... ok [INFO] [stdout] test qaaccount::tests::test_getaccountmessage ... ok [INFO] [stdout] test qaaccount::tests::test_on_pricechange ... ok [INFO] [stdout] test qaaccount::tests::test_buy_open ... ok [INFO] [stdout] test qaaccount::tests::test_realaccountmodel_for_stock ... ok [INFO] [stdout] test qaaccount::tests::test_pos ... ok [INFO] [stdout] test qaaccount::tests::test_sell_close ... ok [INFO] [stdout] test qaaccount::tests::test_qifi_reload ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_next ... ok [INFO] [stdout] test qaaccount::tests::test_sell_open ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_default ... ok [INFO] [stdout] test qaposition::tests::test_new_future ... ok [INFO] [stdout] test qaaccount::tests::test_sellclose_for_stock_rzrq ... ok [INFO] [stdout] test qaperformance::tests::test_pairtoday ... ok [INFO] [stdout] test qaperformance::tests::test_to_qifi ... ok [INFO] [stdout] test qaaccount::tests::test_stock_buy ... ok [INFO] [stdout] test qaaccount::tests::test_stock_qifi_reload ... ok [INFO] [stdout] test qaposition::tests::test_new_stock ... ok [INFO] [stdout] test qaposition::tests::test_onpricechange ... ok [INFO] [stdout] test qaposition::tests::test_pricetick ... ok [INFO] [stdout] test qaperformance::tests::test_backtest ... ok [INFO] [stdout] test qaposition::tests::test_new_with_inithold ... ok [INFO] [stdout] test qaaccount::tests::test_stocksell ... ok [INFO] [stdout] test trade_date::tests::test_get_next_n_day ... ok [INFO] [stdout] test trade_date::tests::test_get_next_day ... ok [INFO] [stdout] test trade_date::tests::test_get_last_day ... ok [INFO] [stdout] test qaposition::tests::test_settle ... ok [INFO] [stdout] test qaposition::tests::test_receivedeal ... ok [INFO] [stdout] test qaposition::tests::test_stock_receivedeal ... ok [INFO] [stdout] test trade_date::tests::test_to_string ... ok [INFO] [stdout] test transaction::tests::test_to_qifi ... ok [INFO] [stdout] test qaposition::tests::test_re ... ok [INFO] [stdout] test qaaccount::tests::test_stocksell_with_settle ... ok [INFO] [stdout] test trade_date::tests::test_get_real_date ... ok [INFO] [stdout] test trade_date::tests::test_get_last_n_day ... ok [INFO] [stdout] test qaaccount::tests::test_new ... ok [INFO] [stdout] test qaaccount::tests::test_init_h ... ok [INFO] [stdout] test qaaccount::tests::test_settle ... ok [INFO] [stdout] test trade_date::tests::test_get_real_tradeday ... ok [INFO] [stdout] test qaperformance::tests::test_pair ... ok [INFO] [stdout] test qaaccount::tests::test_to_csv ... FAILED [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- qaaccount::tests::test_to_csv stdout ---- [INFO] [stdout] test sell close [INFO] [stdout] 109929.0 [INFO] [stdout] thread 'qaaccount::tests::test_to_csv' panicked at 'called `Result::unwrap()` on an `Err` value: Error(Io(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }))', src/qaaccount.rs:566:86 [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x557076a9f1ba - std::backtrace_rs::backtrace::libunwind::trace::he494f4174c7b193d [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/../../backtrace/src/backtrace/libunwind.rs:93:5 [INFO] [stdout] 1: 0x557076a9f1ba - std::backtrace_rs::backtrace::trace_unsynchronized::h576ffc8be8cf606d [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/../../backtrace/src/backtrace/mod.rs:66:5 [INFO] [stdout] 2: 0x557076a9f1ba - std::sys_common::backtrace::_print_fmt::h785643da434656fb [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys_common/backtrace.rs:65:5 [INFO] [stdout] 3: 0x557076a9f1ba - ::fmt::h9b4bec46148aa515 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys_common/backtrace.rs:44:22 [INFO] [stdout] 4: 0x557076ac5c8e - core::fmt::write::h9b2447b2a0bad8cd [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/fmt/mod.rs:1213:17 [INFO] [stdout] 5: 0x557076a9c555 - std::io::Write::write_fmt::h01b310af65ec4db4 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/io/mod.rs:1682:15 [INFO] [stdout] 6: 0x557076a9ef85 - std::sys_common::backtrace::_print::hb761e44df96032bf [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys_common/backtrace.rs:47:5 [INFO] [stdout] 7: 0x557076a9ef85 - std::sys_common::backtrace::print::h38eae7c422ff66f6 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys_common/backtrace.rs:34:9 [INFO] [stdout] 8: 0x557076aa0d7f - std::panicking::default_hook::{{closure}}::h54755764573e4b37 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:267:22 [INFO] [stdout] 9: 0x557076aa0a3f - std::panicking::default_hook::h978c28978503d61b [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:283:9 [INFO] [stdout] 10: 0x5570769be5c7 - as core::ops::function::Fn>::call::hc75c380c644eb7dc [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/alloc/src/boxed.rs:2002:9 [INFO] [stdout] 11: 0x5570769be5c7 - test::test_main::{{closure}}::hf8df6ffaec03f459 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:135:21 [INFO] [stdout] 12: 0x557076aa14aa - as core::ops::function::Fn>::call::hf7b5b3aa2a34e491 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/alloc/src/boxed.rs:2002:9 [INFO] [stdout] 13: 0x557076aa14aa - std::panicking::rust_panic_with_hook::h334ed9b3cc817783 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:692:13 [INFO] [stdout] 14: 0x557076aa1229 - std::panicking::begin_panic_handler::{{closure}}::h2ab7fcc83540cf23 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:579:13 [INFO] [stdout] 15: 0x557076a9f66c - std::sys_common::backtrace::__rust_end_short_backtrace::h65758a09a74021a8 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys_common/backtrace.rs:137:18 [INFO] [stdout] 16: 0x557076aa0f32 - rust_begin_unwind [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:575:5 [INFO] [stdout] 17: 0x5570769310e3 - core::panicking::panic_fmt::h157cca2ea8c38d2f [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/panicking.rs:64:14 [INFO] [stdout] 18: 0x557076931593 - core::result::unwrap_failed::ha26876a373d397d9 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/result.rs:1790:5 [INFO] [stdout] 19: 0x55707698ac3f - core::result::Result::unwrap::he947cfe0dc8712b0 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/result.rs:1112:23 [INFO] [stdout] 20: 0x55707698ac3f - quantaxis_rs::qaaccount::QA_Account::to_csv::hef9d6f4d06265e81 [INFO] [stdout] at /opt/rustwide/workdir/src/qaaccount.rs:566:23 [INFO] [stdout] 21: 0x55707693c01d - quantaxis_rs::qaaccount::tests::test_to_csv::h5dcce9d466ab10ab [INFO] [stdout] at /opt/rustwide/workdir/src/qaaccount.rs:1435:9 [INFO] [stdout] 22: 0x557076946d59 - quantaxis_rs::qaaccount::tests::test_to_csv::{{closure}}::h09729cc52dc4d404 [INFO] [stdout] at /opt/rustwide/workdir/src/qaaccount.rs:1415:22 [INFO] [stdout] 23: 0x557076946d59 - core::ops::function::FnOnce::call_once::h8779c09aa40836ec [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x5570769c3a5f - core::ops::function::FnOnce::call_once::h01f8fec7cfa52c10 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x5570769c3a5f - test::__rust_begin_short_backtrace::hd9df3824e14a263a [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:656:18 [INFO] [stdout] 26: 0x55707699537c - test::run_test::{{closure}}::h14eccc3df692cf45 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:647:30 [INFO] [stdout] 27: 0x55707699537c - core::ops::function::FnOnce::call_once{{vtable.shim}}::h22daa4200e93d413 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 28: 0x5570769c29ea - as core::ops::function::FnOnce>::call_once::hf53e6a300c60e24c [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/alloc/src/boxed.rs:1988:9 [INFO] [stdout] 29: 0x5570769c29ea - as core::ops::function::FnOnce<()>>::call_once::h6791832c0d80daf4 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/panic/unwind_safe.rs:271:9 [INFO] [stdout] 30: 0x5570769c29ea - std::panicking::try::do_call::h8cc8eae26cdc3fd4 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:483:40 [INFO] [stdout] 31: 0x5570769c29ea - std::panicking::try::hda02a22cf2e8baa4 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:447:19 [INFO] [stdout] 32: 0x5570769c29ea - std::panic::catch_unwind::h3eae6cdd2df69f71 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panic.rs:140:14 [INFO] [stdout] 33: 0x5570769c29ea - test::run_test_in_process::h16fa719e43e0b71b [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:679:27 [INFO] [stdout] 34: 0x5570769c29ea - test::run_test::run_test_inner::{{closure}}::h17c8526637871e5a [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:573:39 [INFO] [stdout] 35: 0x55707698faf1 - test::run_test::run_test_inner::{{closure}}::h2af69c9d277fc069 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:600:37 [INFO] [stdout] 36: 0x55707698faf1 - std::sys_common::backtrace::__rust_begin_short_backtrace::h399ac55f3162af04 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys_common/backtrace.rs:121:18 [INFO] [stdout] 37: 0x5570769954bb - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h5a9b49c4b29a004f [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/thread/mod.rs:558:17 [INFO] [stdout] 38: 0x5570769954bb - as core::ops::function::FnOnce<()>>::call_once::h204fece3743b973e [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/panic/unwind_safe.rs:271:9 [INFO] [stdout] 39: 0x5570769954bb - std::panicking::try::do_call::he9e3e4b585f918a2 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:483:40 [INFO] [stdout] 40: 0x5570769954bb - std::panicking::try::h4de93a5845ac1690 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:447:19 [INFO] [stdout] 41: 0x5570769954bb - std::panic::catch_unwind::ha9ec01218adeb4c0 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panic.rs:140:14 [INFO] [stdout] 42: 0x5570769954bb - std::thread::Builder::spawn_unchecked_::{{closure}}::h5c8e32d46eb0d8ba [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 43: 0x5570769954bb - core::ops::function::FnOnce::call_once{{vtable.shim}}::hbddd861cd79853bf [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 44: 0x557076aa5b83 - as core::ops::function::FnOnce>::call_once::hb2ad3b54544c79ff [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/alloc/src/boxed.rs:1988:9 [INFO] [stdout] 45: 0x557076aa5b83 - as core::ops::function::FnOnce>::call_once::hb64cd5ea55c83f79 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/alloc/src/boxed.rs:1988:9 [INFO] [stdout] 46: 0x557076aa5b83 - std::sys::unix::thread::Thread::new::thread_start::ha585169903024f8f [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys/unix/thread.rs:108:17 [INFO] [stdout] 47: 0x7fe8aa220b43 - [INFO] [stdout] 48: 0x7fe8aa2b1bb4 - __clone [INFO] [stdout] 49: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] qaaccount::tests::test_to_csv [INFO] [stdout] [INFO] [stdout] test result: FAILED. 171 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.32s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] running `Command { std: "docker" "inspect" "f3391a87288436f33b182d223a4edc5d8aaaab01d2158c3d879d2def3d0c84a3", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f3391a87288436f33b182d223a4edc5d8aaaab01d2158c3d879d2def3d0c84a3", kill_on_drop: false }` [INFO] [stdout] f3391a87288436f33b182d223a4edc5d8aaaab01d2158c3d879d2def3d0c84a3