[INFO] fetching crate quantaxis-rs 0.3.4... [INFO] testing quantaxis-rs-0.3.4 against try#613d1972a772987ed4ee06faccbab0e2fc839871+rustflags=-Copt-level=3 for pr-107051 [INFO] extracting crate quantaxis-rs 0.3.4 into /workspace/builds/worker-7-tc2/source [INFO] validating manifest of crates.io crate quantaxis-rs 0.3.4 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 crates.io crate quantaxis-rs 0.3.4 [INFO] finished tweaking crates.io crate quantaxis-rs 0.3.4 [INFO] tweaked toml for crates.io crate quantaxis-rs 0.3.4 written to /workspace/builds/worker-7-tc2/source/Cargo.toml [INFO] crate crates.io crate quantaxis-rs 0.3.4 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-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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] a3c4d516f7c89140cbebefe3959774f310832b1ad8f85705cbaf29124e9b2f29 [INFO] running `Command { std: "docker" "start" "-a" "a3c4d516f7c89140cbebefe3959774f310832b1ad8f85705cbaf29124e9b2f29", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "a3c4d516f7c89140cbebefe3959774f310832b1ad8f85705cbaf29124e9b2f29", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "a3c4d516f7c89140cbebefe3959774f310832b1ad8f85705cbaf29124e9b2f29", kill_on_drop: false }` [INFO] [stdout] a3c4d516f7c89140cbebefe3959774f310832b1ad8f85705cbaf29124e9b2f29 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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] 22788640cc3689d68f092fd5c501839cb4b52e07fbcd62fb83824c1d6b407499 [INFO] running `Command { std: "docker" "start" "-a" "22788640cc3689d68f092fd5c501839cb4b52e07fbcd62fb83824c1d6b407499", kill_on_drop: false }` [INFO] [stderr] Compiling autocfg v1.0.1 [INFO] [stderr] Compiling proc-macro2 v1.0.24 [INFO] [stderr] Compiling unicode-xid v0.2.1 [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 value-bag v1.0.0-alpha.6 [INFO] [stderr] Compiling futures-core v0.3.12 [INFO] [stderr] Compiling log v0.4.14 [INFO] [stderr] Compiling futures-io v0.3.12 [INFO] [stderr] Compiling slab v0.4.2 [INFO] [stderr] Compiling typenum v1.12.0 [INFO] [stderr] Compiling serde_derive v1.0.123 [INFO] [stderr] Compiling pin-project-lite v0.2.4 [INFO] [stderr] Compiling serde v1.0.123 [INFO] [stderr] Compiling version_check v0.9.2 [INFO] [stderr] Compiling getrandom v0.1.16 [INFO] [stderr] Compiling byteorder v1.4.2 [INFO] [stderr] Compiling cc v1.0.67 [INFO] [stderr] Compiling proc-macro-hack v0.5.19 [INFO] [stderr] Compiling rand_core v0.4.2 [INFO] [stderr] Compiling autocfg v0.1.7 [INFO] [stderr] Compiling proc-macro-nested v0.1.7 [INFO] [stderr] Compiling futures-sink v0.3.12 [INFO] [stderr] Compiling cache-padded v1.1.1 [INFO] [stderr] Compiling matches v0.1.8 [INFO] [stderr] Compiling concurrent-queue v1.2.2 [INFO] [stderr] Compiling tinyvec v1.1.1 [INFO] [stderr] Compiling waker-fn v1.1.0 [INFO] [stderr] Compiling event-listener v2.5.1 [INFO] [stderr] Compiling ryu v1.0.5 [INFO] [stderr] Compiling parking v2.0.0 [INFO] [stderr] Compiling fastrand v1.4.0 [INFO] [stderr] Compiling unicode-bidi v0.3.4 [INFO] [stderr] Compiling futures-channel v0.3.12 [INFO] [stderr] Compiling futures-lite v1.11.3 [INFO] [stderr] Compiling futures-task v0.3.12 [INFO] [stderr] Compiling adler v0.2.3 [INFO] [stderr] Compiling bytes v0.5.6 [INFO] [stderr] Compiling byte-tools v0.3.1 [INFO] [stderr] Compiling gimli v0.23.0 [INFO] [stderr] Compiling ident_case v1.0.1 [INFO] [stderr] Compiling ppv-lite86 v0.2.10 [INFO] [stderr] Compiling strsim v0.10.0 [INFO] [stderr] Compiling pin-project-lite v0.1.11 [INFO] [stderr] Compiling quote v1.0.9 [INFO] [stderr] Compiling rustversion v1.0.4 [INFO] [stderr] Compiling num-traits v0.2.14 [INFO] [stderr] Compiling num-integer v0.1.44 [INFO] [stderr] Compiling num_cpus v1.13.0 [INFO] [stderr] Compiling crossbeam-utils v0.8.2 [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 miniz_oxide v0.4.3 [INFO] [stderr] Compiling unicode-normalization v0.1.17 [INFO] [stderr] Compiling signal-hook-registry v1.3.0 [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 memoffset v0.6.1 [INFO] [stderr] Compiling generic-array v0.12.3 [INFO] [stderr] Compiling indexmap v1.6.1 [INFO] [stderr] Compiling proc-macro-error-attr v1.0.4 [INFO] [stderr] Compiling block-padding v0.1.5 [INFO] [stderr] Compiling async-task v4.0.3 [INFO] [stderr] Compiling digest v0.8.1 [INFO] [stderr] Compiling getrandom v0.2.2 [INFO] [stderr] Compiling rustc-demangle v0.1.18 [INFO] [stderr] Compiling vec-arena v1.0.0 [INFO] [stderr] Compiling object v0.23.0 [INFO] [stderr] Compiling unicode-segmentation v1.7.1 [INFO] [stderr] Compiling itoa v0.4.7 [INFO] [stderr] Compiling idna v0.2.2 [INFO] [stderr] Compiling block-buffer v0.7.3 [INFO] [stderr] Compiling heck v0.3.2 [INFO] [stderr] Compiling form_urlencoded v1.0.1 [INFO] [stderr] Compiling nb-connect v1.0.3 [INFO] [stderr] Compiling rand v0.7.3 [INFO] [stderr] Compiling num-iter v0.1.42 [INFO] [stderr] Compiling num-complex v0.2.4 [INFO] [stderr] Compiling proc-macro-error v1.0.4 [INFO] [stderr] Compiling async-channel v1.6.1 [INFO] [stderr] Compiling rand_core v0.3.1 [INFO] [stderr] Compiling linked-hash-map v0.5.4 [INFO] [stderr] Compiling match_cfg v0.1.0 [INFO] [stderr] Compiling hashbrown v0.9.1 [INFO] [stderr] Compiling rustc-serialize v0.3.24 [INFO] [stderr] Compiling opaque-debug v0.2.3 [INFO] [stderr] Compiling atomic-waker v1.0.0 [INFO] [stderr] Compiling serde_json v1.0.62 [INFO] [stderr] Compiling subtle v1.0.0 [INFO] [stderr] Compiling blocking v1.0.2 [INFO] [stderr] Compiling crypto-mac v0.7.0 [INFO] [stderr] Compiling addr2line v0.14.1 [INFO] [stderr] Compiling hostname v0.3.1 [INFO] [stderr] Compiling url v2.2.1 [INFO] [stderr] Compiling async-executor v1.4.0 [INFO] [stderr] Compiling rand v0.4.6 [INFO] [stderr] Compiling time v0.1.44 [INFO] [stderr] Compiling num-bigint v0.2.6 [INFO] [stderr] Compiling async-mutex v1.4.0 [INFO] [stderr] Compiling smallvec v1.6.1 [INFO] [stderr] Compiling fake-simd v0.1.2 [INFO] [stderr] Compiling rayon-core v1.9.0 [INFO] [stderr] Compiling chrono v0.4.19 [INFO] [stderr] Compiling crossbeam-epoch v0.9.2 [INFO] [stderr] Compiling resolv-conf v0.7.0 [INFO] [stderr] Compiling lru-cache v0.1.2 [INFO] [stderr] Compiling rand_pcg v0.1.2 [INFO] [stderr] Compiling rand_chacha v0.1.1 [INFO] [stderr] Compiling num-rational v0.2.4 [INFO] [stderr] Compiling async-lock v2.3.0 [INFO] [stderr] Compiling regex-automata v0.1.9 [INFO] [stderr] Compiling ndarray v0.13.1 [INFO] [stderr] Compiling rawpointer v0.2.1 [INFO] [stderr] Compiling hex v0.4.2 [INFO] [stderr] Compiling base64 v0.12.3 [INFO] [stderr] Compiling matrixmultiply v0.2.4 [INFO] [stderr] Compiling backtrace v0.3.56 [INFO] [stderr] Compiling crossbeam-deque v0.8.0 [INFO] [stderr] Compiling sha2 v0.8.2 [INFO] [stderr] Compiling sha-1 v0.8.2 [INFO] [stderr] Compiling err-derive v0.2.4 [INFO] [stderr] Compiling hmac v0.7.1 [INFO] [stderr] Compiling pbkdf2 v0.3.0 [INFO] [stderr] Compiling md-5 v0.8.0 [INFO] [stderr] Compiling stringprep v0.1.2 [INFO] [stderr] Compiling crossbeam-channel v0.5.0 [INFO] [stderr] Compiling darling_core v0.12.1 [INFO] [stderr] Compiling num-bigint v0.1.44 [INFO] [stderr] Compiling synstructure v0.12.4 [INFO] [stderr] Compiling ring v0.16.20 [INFO] [stderr] Compiling num-complex v0.1.43 [INFO] [stderr] Compiling num-rational v0.1.42 [INFO] [stderr] Compiling rand v0.6.5 [INFO] [stderr] Compiling rayon v1.5.0 [INFO] [stderr] Compiling error-chain v0.12.4 [INFO] [stderr] Compiling csv-core v0.1.10 [INFO] [stderr] Compiling either v1.6.1 [INFO] [stderr] Compiling take_mut v0.2.2 [INFO] [stderr] Compiling num v0.1.42 [INFO] [stderr] Compiling rand_hc v0.1.0 [INFO] [stderr] Compiling rand_xorshift v0.1.1 [INFO] [stderr] Compiling rand_isaac v0.1.1 [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 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 webpki v0.21.4 [INFO] [stderr] Compiling sct v0.6.0 [INFO] [stderr] Compiling regex v1.4.3 [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 async-trait v0.1.42 [INFO] [stderr] Compiling enum-as-inner v0.3.3 [INFO] [stderr] Compiling async-attributes v1.1.2 [INFO] [stderr] Compiling typed-builder v0.4.1 [INFO] [stderr] Compiling derivative v2.2.0 [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 async-io v1.3.1 [INFO] [stderr] Compiling mio-uds v0.6.8 [INFO] [stderr] Compiling tokio v0.2.25 [INFO] [stderr] Compiling async-global-executor v2.0.2 [INFO] [stderr] Compiling rustls v0.17.0 [INFO] [stderr] Compiling thiserror v1.0.24 [INFO] [stderr] Compiling kv-log-macro v1.0.7 [INFO] [stderr] Compiling async-std v1.9.0 [INFO] [stderr] Compiling futures-util v0.3.12 [INFO] [stderr] Compiling os_info v3.0.1 [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 ndarray-csv v0.4.1 [INFO] [stderr] Compiling bson v1.2.0 [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 8m 41s [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" "22788640cc3689d68f092fd5c501839cb4b52e07fbcd62fb83824c1d6b407499", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "22788640cc3689d68f092fd5c501839cb4b52e07fbcd62fb83824c1d6b407499", kill_on_drop: false }` [INFO] [stdout] 22788640cc3689d68f092fd5c501839cb4b52e07fbcd62fb83824c1d6b407499 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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] 7a4d7c9ea8fef17e5a7141ca1724096d85823479fc1f67edc205c829deec0b39 [INFO] running `Command { std: "docker" "start" "-a" "7a4d7c9ea8fef17e5a7141ca1724096d85823479fc1f67edc205c829deec0b39", 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 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 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: 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: 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: 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 `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: 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: 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: 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 26.36s [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" "7a4d7c9ea8fef17e5a7141ca1724096d85823479fc1f67edc205c829deec0b39", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7a4d7c9ea8fef17e5a7141ca1724096d85823479fc1f67edc205c829deec0b39", kill_on_drop: false }` [INFO] [stdout] 7a4d7c9ea8fef17e5a7141ca1724096d85823479fc1f67edc205c829deec0b39 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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] 15335cb2438cf2e4094ea31a2dec5733ebde3076693bd900876fc4adcd9bf3eb [INFO] running `Command { std: "docker" "start" "-a" "15335cb2438cf2e4094ea31a2dec5733ebde3076693bd900876fc4adcd9bf3eb", 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: `quantaxis-rs` (bin "quantaxis-rs" test) generated 102 warnings (52 duplicates) (run `cargo fix --bin "quantaxis-rs" --tests` to apply 9 suggestions) [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.29s [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 helpers::tests::test_max3 ... ok [INFO] [stdout] test data_item::tests::test_builder ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_default ... 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::efficiency_ratio::tests::test_indicator ... ok [INFO] [stdout] test indicators::bollinger_bands::tests::test_new ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_new ... ok [INFO] [stdout] test indicators::bollinger_bands::tests::test_default ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_indicator ... ok [INFO] [stdout] test indicators::bollinger_bands::tests::test_next ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_reset ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_display ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_reset ... 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::fast_stochastic::tests::test_indicator ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_default ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_new ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_next_with_f64 ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_reset ... ok [INFO] [stdout] test indicators::hhv::tests::test_indicator ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_new ... ok [INFO] [stdout] test indicators::fast_stochastic::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_update ... ok [INFO] [stdout] test indicators::hhv::tests::test_display ... ok [INFO] [stdout] test indicators::hhv::tests::test_default ... ok [INFO] [stdout] test indicators::hhv::tests::test_next ... ok [INFO] [stdout] test indicators::average_true_range::tests::test_next ... ok [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_display ... ok [INFO] [stdout] test indicators::exponential_moving_average::tests::test_next ... ok [INFO] [stdout] test indicators::bollinger_bands::tests::test_reset ... ok [INFO] [stdout] test indicators::hhv::tests::test_new ... ok [INFO] [stdout] test indicators::hhv::tests::test_reset ... ok [INFO] [stdout] test indicators::hhv::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::llv::tests::test_default ... ok [INFO] [stdout] test indicators::hhv::tests::test_update ... ok [INFO] [stdout] test indicators::efficiency_ratio::tests::test_next_f64 ... ok [INFO] [stdout] test indicators::efficiency_ratio::tests::test_new ... ok [INFO] [stdout] test indicators::llv::tests::test_new ... ok [INFO] [stdout] test indicators::llv::tests::test_indicator ... ok [INFO] [stdout] test indicators::llv::tests::test_display ... ok [INFO] [stdout] test indicators::llv::tests::test_newx ... ok [INFO] [stdout] test indicators::llv::tests::test_new_notenough ... ok [INFO] [stdout] test indicators::llv::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::maximum::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::llv::tests::test_reset ... ok [INFO] [stdout] test indicators::maximum::tests::test_display ... ok [INFO] [stdout] test indicators::maximum::tests::test_new ... ok [INFO] [stdout] test indicators::llv::tests::test_update ... ok [INFO] [stdout] test indicators::llv::tests::test_next ... ok [INFO] [stdout] test indicators::maximum::tests::test_default ... ok [INFO] [stdout] test indicators::maximum::tests::test_indicator ... ok [INFO] [stdout] test indicators::minimum::tests::test_default ... ok [INFO] [stdout] test indicators::minimum::tests::test_next ... ok [INFO] [stdout] test indicators::maximum::tests::test_next ... ok [INFO] [stdout] test indicators::moving_average::tests::test_default ... 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::minimum::tests::test_reset ... 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_display ... ok [INFO] [stdout] test indicators::maximum::tests::test_reset ... ok [INFO] [stdout] test indicators::minimum::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::minimum::tests::test_display ... ok [INFO] [stdout] test indicators::money_flow_index::tests::test_default ... ok [INFO] [stdout] test indicators::money_flow_index::tests::test_new ... ok [INFO] [stdout] test indicators::minimum::tests::test_new ... ok [INFO] [stdout] test indicators::moving_average::tests::test_new ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_display ... ok [INFO] [stdout] test indicators::moving_average::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_reset ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_default ... ok [INFO] [stdout] test indicators::moving_average::tests::test_next ... ok [INFO] [stdout] test indicators::moving_average::tests::test_reset ... ok [INFO] [stdout] test indicators::moving_average::tests::test_real ... ok [INFO] [stdout] test indicators::moving_average::tests::test_update ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_macd ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_indicator ... ok [INFO] [stdout] test indicators::moving_average_convergence_divergence::tests::test_new ... ok [INFO] [stdout] test indicators::minimum::tests::test_indicator ... ok [INFO] [stdout] test indicators::moving_average::tests::test_cached ... ok [INFO] [stdout] test indicators::rate_of_change::tests::test_next_f64 ... ok [INFO] [stdout] test indicators::on_balance_volume::tests::test_default ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_display ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_indicator ... ok [INFO] [stdout] test indicators::on_balance_volume::tests::test_next_bar ... ok [INFO] [stdout] test indicators::rate_of_change::tests::test_indicator ... ok [INFO] [stdout] test indicators::rate_of_change::tests::test_reset ... ok [INFO] [stdout] test indicators::on_balance_volume::tests::test_display ... ok [INFO] [stdout] test indicators::rate_of_change::tests::test_new ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_default ... ok [INFO] [stdout] test indicators::on_balance_volume::tests::test_reset ... ok [INFO] [stdout] test indicators::rate_of_change::tests::test_next_bar ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_new ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_next ... ok [INFO] [stdout] test indicators::relative_strength_index::tests::test_reset ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_default ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_next ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_reset ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_display ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_indicator ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_next_with_f64 ... ok [INFO] [stdout] test indicators::simple_moving_average::tests::test_indicator ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_display ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_default ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_new ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_reset ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_display ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_next ... ok [INFO] [stdout] test indicators::true_range::tests::test_default ... ok [INFO] [stdout] test indicators::true_range::tests::test_display ... 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_reset ... ok [INFO] [stdout] test indicators::true_range::tests::test_update_f64 ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_indicator ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_reset ... ok [INFO] [stdout] test indicators::true_range::tests::test_next_bar ... ok [INFO] [stdout] test indicators::standard_deviation::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_new ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_default ... ok [INFO] [stdout] test indicators::slow_stochastic::tests::test_next_with_bars ... ok [INFO] [stdout] test indicators::standard_deviation::tests::test_next_same_values ... ok [INFO] [stdout] test qaaccount::tests::test_new ... ok [INFO] [stdout] test qaaccount::tests::test_init_h ... ok [INFO] [stdout] test qaaccount::tests::test_pos ... ok [INFO] [stdout] test qaaccount::tests::test_on_pricechange ... ok [INFO] [stdout] test qaaccount::tests::test_getaccountmessage ... ok [INFO] [stdout] test qaaccount::tests::test_stock_buy ... ok [INFO] [stdout] test qaaccount::tests::test_stocksell ... ok [INFO] [stdout] test qaaccount::tests::test_get_info ... ok [INFO] [stdout] test qaaccount::tests::test_sellclose_for_stock_rzrq ... ok [INFO] [stdout] test qaaccount::tests::test_settle ... ok [INFO] [stdout] test qaperformance::tests::test_backtest ... ok [INFO] [stdout] test qaposition::tests::test_new_future ... ok [INFO] [stdout] test qaposition::tests::test_new_stock ... ok [INFO] [stdout] test qaposition::tests::test_new_with_inithold ... ok [INFO] [stdout] test qaaccount::tests::test_stock_qifi_reload ... ok [INFO] [stdout] test qaperformance::tests::test_to_qifi ... ok [INFO] [stdout] test qaposition::tests::test_onpricechange ... ok [INFO] [stdout] test qaaccount::tests::test_qifi_reload ... ok [INFO] [stdout] test qaaccount::tests::test_stocksell_with_settle ... ok [INFO] [stdout] test qaaccount::tests::test_buy_close ... ok [INFO] [stdout] test qaaccount::tests::test_sell_open ... ok [INFO] [stdout] test qaaccount::tests::test_sell_close ... ok [INFO] [stdout] test qaperformance::tests::test_pairtoday ... ok [INFO] [stdout] test qaperformance::tests::test_pair ... ok [INFO] [stdout] test qaposition::tests::test_pricetick ... ok [INFO] [stdout] test qaposition::tests::test_settle ... ok [INFO] [stdout] test qaposition::tests::test_re ... 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_get_last_day ... ok [INFO] [stdout] test qaaccount::tests::test_buy_open_for_stock ... ok [INFO] [stdout] test qaaccount::tests::test_realaccountmodel_for_stock ... ok [INFO] [stdout] test qaaccount::tests::test_buy_open ... ok [INFO] [stdout] test trade_date::tests::test_get_next_day ... ok [INFO] [stdout] test qaaccount::tests::test_accountSlice ... ok [INFO] [stdout] test qaaccount::tests::test_accountSlice_for_qifi ... ok [INFO] [stdout] test trade_date::tests::test_get_last_n_day ... ok [INFO] [stdout] test trade_date::tests::test_get_next_n_day ... ok [INFO] [stdout] test trade_date::tests::test_get_real_date ... ok [INFO] [stdout] test trade_date::tests::test_get_real_tradeday ... ok [INFO] [stdout] test trade_date::tests::test_to_string ... ok [INFO] [stdout] test transaction::tests::test_to_qifi ... 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: 0x56057a5a71ba - 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: 0x56057a5a71ba - 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: 0x56057a5a71ba - std::sys_common::backtrace::_print_fmt::h785643da434656fb [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys_common/backtrace.rs:65:5 [INFO] [stdout] 3: 0x56057a5a71ba - ::fmt::h9b4bec46148aa515 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys_common/backtrace.rs:44:22 [INFO] [stdout] 4: 0x56057a5cdc8e - core::fmt::write::h9b2447b2a0bad8cd [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/fmt/mod.rs:1213:17 [INFO] [stdout] 5: 0x56057a5a4555 - std::io::Write::write_fmt::h01b310af65ec4db4 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/io/mod.rs:1682:15 [INFO] [stdout] 6: 0x56057a5a6f85 - std::sys_common::backtrace::_print::hb761e44df96032bf [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys_common/backtrace.rs:47:5 [INFO] [stdout] 7: 0x56057a5a6f85 - std::sys_common::backtrace::print::h38eae7c422ff66f6 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/sys_common/backtrace.rs:34:9 [INFO] [stdout] 8: 0x56057a5a8d7f - std::panicking::default_hook::{{closure}}::h54755764573e4b37 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:267:22 [INFO] [stdout] 9: 0x56057a5a8a3f - std::panicking::default_hook::h978c28978503d61b [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:283:9 [INFO] [stdout] 10: 0x56057a4c65c7 - as core::ops::function::Fn>::call::hc75c380c644eb7dc [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/alloc/src/boxed.rs:2002:9 [INFO] [stdout] 11: 0x56057a4c65c7 - test::test_main::{{closure}}::hf8df6ffaec03f459 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:135:21 [INFO] [stdout] 12: 0x56057a5a94aa - as core::ops::function::Fn>::call::hf7b5b3aa2a34e491 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/alloc/src/boxed.rs:2002:9 [INFO] [stdout] 13: 0x56057a5a94aa - std::panicking::rust_panic_with_hook::h334ed9b3cc817783 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:692:13 [INFO] [stdout] 14: 0x56057a5a9229 - std::panicking::begin_panic_handler::{{closure}}::h2ab7fcc83540cf23 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:579:13 [INFO] [stdout] 15: 0x56057a5a766c - 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: 0x56057a5a8f32 - rust_begin_unwind [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:575:5 [INFO] [stdout] 17: 0x56057a4390e3 - core::panicking::panic_fmt::h157cca2ea8c38d2f [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/panicking.rs:64:14 [INFO] [stdout] 18: 0x56057a439593 - core::result::unwrap_failed::ha26876a373d397d9 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/result.rs:1790:5 [INFO] [stdout] 19: 0x56057a492c3f - core::result::Result::unwrap::he947cfe0dc8712b0 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/result.rs:1112:23 [INFO] [stdout] 20: 0x56057a492c3f - quantaxis_rs::qaaccount::QA_Account::to_csv::hef9d6f4d06265e81 [INFO] [stdout] at /opt/rustwide/workdir/src/qaaccount.rs:566:23 [INFO] [stdout] 21: 0x56057a44401d - quantaxis_rs::qaaccount::tests::test_to_csv::h5dcce9d466ab10ab [INFO] [stdout] at /opt/rustwide/workdir/src/qaaccount.rs:1435:9 [INFO] [stdout] 22: 0x56057a44ed59 - quantaxis_rs::qaaccount::tests::test_to_csv::{{closure}}::h09729cc52dc4d404 [INFO] [stdout] at /opt/rustwide/workdir/src/qaaccount.rs:1415:22 [INFO] [stdout] 23: 0x56057a44ed59 - core::ops::function::FnOnce::call_once::h8779c09aa40836ec [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x56057a4cba5f - core::ops::function::FnOnce::call_once::h01f8fec7cfa52c10 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x56057a4cba5f - test::__rust_begin_short_backtrace::hd9df3824e14a263a [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:656:18 [INFO] [stdout] 26: 0x56057a49d37c - test::run_test::{{closure}}::h14eccc3df692cf45 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:647:30 [INFO] [stdout] 27: 0x56057a49d37c - 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: 0x56057a4ca9ea - as core::ops::function::FnOnce>::call_once::hf53e6a300c60e24c [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/alloc/src/boxed.rs:1988:9 [INFO] [stdout] 29: 0x56057a4ca9ea - 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: 0x56057a4ca9ea - std::panicking::try::do_call::h8cc8eae26cdc3fd4 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:483:40 [INFO] [stdout] 31: 0x56057a4ca9ea - std::panicking::try::hda02a22cf2e8baa4 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:447:19 [INFO] [stdout] 32: 0x56057a4ca9ea - std::panic::catch_unwind::h3eae6cdd2df69f71 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panic.rs:140:14 [INFO] [stdout] 33: 0x56057a4ca9ea - test::run_test_in_process::h16fa719e43e0b71b [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:679:27 [INFO] [stdout] 34: 0x56057a4ca9ea - test::run_test::run_test_inner::{{closure}}::h17c8526637871e5a [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:573:39 [INFO] [stdout] 35: 0x56057a497af1 - test::run_test::run_test_inner::{{closure}}::h2af69c9d277fc069 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/test/src/lib.rs:600:37 [INFO] [stdout] 36: 0x56057a497af1 - 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: 0x56057a49d4bb - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h5a9b49c4b29a004f [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/thread/mod.rs:558:17 [INFO] [stdout] 38: 0x56057a49d4bb - 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: 0x56057a49d4bb - std::panicking::try::do_call::he9e3e4b585f918a2 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:483:40 [INFO] [stdout] 40: 0x56057a49d4bb - std::panicking::try::h4de93a5845ac1690 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panicking.rs:447:19 [INFO] [stdout] 41: 0x56057a49d4bb - std::panic::catch_unwind::ha9ec01218adeb4c0 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/panic.rs:140:14 [INFO] [stdout] 42: 0x56057a49d4bb - std::thread::Builder::spawn_unchecked_::{{closure}}::h5c8e32d46eb0d8ba [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 43: 0x56057a49d4bb - 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: 0x56057a5adb83 - as core::ops::function::FnOnce>::call_once::hb2ad3b54544c79ff [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/alloc/src/boxed.rs:1988:9 [INFO] [stdout] 45: 0x56057a5adb83 - as core::ops::function::FnOnce>::call_once::hb64cd5ea55c83f79 [INFO] [stdout] at /rustc/613d1972a772987ed4ee06faccbab0e2fc839871/library/alloc/src/boxed.rs:1988:9 [INFO] [stdout] 46: 0x56057a5adb83 - 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: 0x7fda5e17eb43 - [INFO] [stdout] 48: 0x7fda5e20fbb4 - __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.39s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] running `Command { std: "docker" "inspect" "15335cb2438cf2e4094ea31a2dec5733ebde3076693bd900876fc4adcd9bf3eb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "15335cb2438cf2e4094ea31a2dec5733ebde3076693bd900876fc4adcd9bf3eb", kill_on_drop: false }` [INFO] [stdout] 15335cb2438cf2e4094ea31a2dec5733ebde3076693bd900876fc4adcd9bf3eb