[INFO] cloning repository https://github.com/CeciliaZ030/nearAMM-demo
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/CeciliaZ030/nearAMM-demo" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FCeciliaZ030%2FnearAMM-demo", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FCeciliaZ030%2FnearAMM-demo'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 524eeb175436e2d11bceb333914aa67ecf786b43
[INFO] checking CeciliaZ030/nearAMM-demo against 1.95.0 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FCeciliaZ030%2FnearAMM-demo" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/CeciliaZ030/nearAMM-demo
[INFO] finished tweaking git repo https://github.com/CeciliaZ030/nearAMM-demo
[INFO] tweaked toml for git repo https://github.com/CeciliaZ030/nearAMM-demo written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/CeciliaZ030/nearAMM-demo on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/CeciliaZ030/nearAMM-demo 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" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded wee_alloc v0.4.5
[INFO] [stderr]   Downloaded serde_derive v1.0.147
[INFO] [stderr]   Downloaded schemars_derive v0.8.11
[INFO] [stderr]   Downloaded near-account-id v0.14.0
[INFO] [stderr]   Downloaded near-rpc-error-core v0.14.0
[INFO] [stderr]   Downloaded near-rpc-error-macro v0.14.0
[INFO] [stderr]   Downloaded near-abi v0.3.0
[INFO] [stderr]   Downloaded near-sys v0.2.0
[INFO] [stderr]   Downloaded smart-default v0.6.0
[INFO] [stderr]   Downloaded cxxbridge-flags v1.0.81
[INFO] [stderr]   Downloaded near-sdk-macros v4.1.1
[INFO] [stderr]   Downloaded near-contract-standards v4.1.1
[INFO] [stderr]   Downloaded near-crypto v0.14.0
[INFO] [stderr]   Downloaded near-primitives-core v0.14.0
[INFO] [stderr]   Downloaded easy-ext v0.2.9
[INFO] [stderr]   Downloaded schemars v0.8.11
[INFO] [stderr]   Downloaded reed-solomon-erasure v4.0.2
[INFO] [stderr]   Downloaded cxxbridge-macro v1.0.81
[INFO] [stderr]   Downloaded cc v1.0.76
[INFO] [stderr]   Downloaded near-vm-logic v0.14.0
[INFO] [stderr]   Downloaded cxx-build v1.0.81
[INFO] [stderr]   Downloaded zeropool-bn v0.5.11
[INFO] [stderr]   Downloaded near-primitives v0.14.0
[INFO] [stderr]   Downloaded near-sdk v4.1.1
[INFO] [stderr]   Downloaded serde_json v1.0.87
[INFO] [stderr]   Downloaded parity-secp256k1 v0.7.0
[INFO] [stderr]   Downloaded serde v1.0.147
[INFO] [stderr]   Downloaded near-vm-errors v0.14.0
[INFO] [stderr]   Downloaded cxx v1.0.81
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] cf66064f2a390b301b86210325fa9fe2ccf6b7f22bcfe83b37d53aabf8920747
[INFO] running `Command { std: "docker" "start" "-a" "cf66064f2a390b301b86210325fa9fe2ccf6b7f22bcfe83b37d53aabf8920747", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "cf66064f2a390b301b86210325fa9fe2ccf6b7f22bcfe83b37d53aabf8920747", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cf66064f2a390b301b86210325fa9fe2ccf6b7f22bcfe83b37d53aabf8920747", kill_on_drop: false }`
[INFO] [stdout] cf66064f2a390b301b86210325fa9fe2ccf6b7f22bcfe83b37d53aabf8920747
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 32d60f71f4aa7f7bed1fc21aee67af519cc68de18d11d2dd57278a2e69aa5c1e
[INFO] running `Command { std: "docker" "start" "-a" "32d60f71f4aa7f7bed1fc21aee67af519cc68de18d11d2dd57278a2e69aa5c1e", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.47
[INFO] [stderr]    Compiling unicode-ident v1.0.5
[INFO] [stderr]    Compiling quote v1.0.21
[INFO] [stderr]    Compiling syn v1.0.103
[INFO] [stderr]    Compiling libc v0.2.137
[INFO] [stderr]    Compiling serde_derive v1.0.147
[INFO] [stderr]    Compiling typenum v1.15.0
[INFO] [stderr]    Compiling serde v1.0.147
[INFO] [stderr]     Checking once_cell v1.16.0
[INFO] [stderr]    Compiling thiserror v1.0.37
[INFO] [stderr]    Compiling getrandom v0.1.16
[INFO] [stderr]    Compiling generic-array v0.14.6
[INFO] [stderr]    Compiling ahash v0.7.6
[INFO] [stderr]    Compiling radium v0.6.2
[INFO] [stderr]    Compiling crunchy v0.2.2
[INFO] [stderr]    Compiling serde_json v1.0.87
[INFO] [stderr]    Compiling rustversion v1.0.9
[INFO] [stderr]     Checking funty v1.1.0
[INFO] [stderr]     Checking wyz v0.2.0
[INFO] [stderr]    Compiling num-bigint v0.3.3
[INFO] [stderr]    Compiling cc v1.0.76
[INFO] [stderr]     Checking itoa v1.0.4
[INFO] [stderr]     Checking rustc-hex v2.1.0
[INFO] [stderr]    Compiling cfg-if v0.1.10
[INFO] [stderr]     Checking ryu v1.0.11
[INFO] [stderr]     Checking byte-slice-cast v1.2.2
[INFO] [stderr]    Compiling num-rational v0.3.2
[INFO] [stderr]    Compiling convert_case v0.4.0
[INFO] [stderr]    Compiling heck v0.4.0
[INFO] [stderr]     Checking arrayvec v0.5.2
[INFO] [stderr]    Compiling reed-solomon-erasure v4.0.2
[INFO] [stderr]     Checking uint v0.9.4
[INFO] [stderr]     Checking spin v0.5.2
[INFO] [stderr]    Compiling semver v1.0.14
[INFO] [stderr]     Checking base64 v0.11.0
[INFO] [stderr]    Compiling schemars v0.8.11
[INFO] [stderr]     Checking iana-time-zone v0.1.53
[INFO] [stderr]     Checking lazy_static v1.4.0
[INFO] [stderr]     Checking dyn-clone v1.0.9
[INFO] [stderr]     Checking bytesize v1.1.0
[INFO] [stderr]    Compiling easy-ext v0.2.9
[INFO] [stderr]     Checking bitvec v0.20.4
[INFO] [stderr]    Compiling wee_alloc v0.4.5
[INFO] [stderr]    Compiling Inflector v0.11.4
[INFO] [stderr]     Checking base64 v0.13.1
[INFO] [stderr]     Checking memory_units v0.4.0
[INFO] [stderr]     Checking near-sys v0.2.0
[INFO] [stderr]     Checking getrandom v0.2.8
[INFO] [stderr]     Checking time v0.1.44
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking hashbrown v0.11.2
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling parity-secp256k1 v0.7.0
[INFO] [stderr]     Checking fixed-hash v0.7.0
[INFO] [stderr]     Checking crypto-common v0.1.6
[INFO] [stderr]     Checking block-buffer v0.10.3
[INFO] [stderr]     Checking digest v0.9.0
[INFO] [stderr]     Checking block-buffer v0.9.0
[INFO] [stderr]     Checking crypto-mac v0.8.0
[INFO] [stderr]     Checking cipher v0.2.5
[INFO] [stderr]     Checking blake2 v0.9.2
[INFO] [stderr]     Checking sha2 v0.9.9
[INFO] [stderr]     Checking digest v0.10.5
[INFO] [stderr]     Checking c2-chacha v0.3.3
[INFO] [stderr]     Checking sha2 v0.10.6
[INFO] [stderr]     Checking ripemd v0.1.3
[INFO] [stderr]     Checking sha3 v0.10.6
[INFO] [stderr]    Compiling borsh-derive-internal v0.9.3
[INFO] [stderr]    Compiling borsh-schema-derive-internal v0.9.3
[INFO] [stderr]    Compiling synstructure v0.12.6
[INFO] [stderr]    Compiling serde_derive_internals v0.26.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.37
[INFO] [stderr]    Compiling impl-trait-for-tuples v0.2.2
[INFO] [stderr]    Compiling zeroize_derive v1.3.2
[INFO] [stderr]    Compiling strum_macros v0.24.3
[INFO] [stderr]    Compiling derive_more v0.99.17
[INFO] [stderr]    Compiling smart-default v0.6.0
[INFO] [stderr]    Compiling near-sdk-macros v4.1.1
[INFO] [stderr]    Compiling schemars_derive v0.8.11
[INFO] [stderr]     Checking zeroize v1.3.0
[INFO] [stderr]     Checking curve25519-dalek v3.2.1
[INFO] [stderr]     Checking strum v0.24.1
[INFO] [stderr]     Checking ed25519-dalek v1.0.1
[INFO] [stderr]     Checking chrono v0.4.23
[INFO] [stderr]    Compiling toml v0.5.9
[INFO] [stderr]    Compiling near-rpc-error-core v0.14.0
[INFO] [stderr]    Compiling near-rpc-error-macro v0.14.0
[INFO] [stderr]    Compiling proc-macro-crate v0.1.5
[INFO] [stderr]    Compiling proc-macro-crate v1.2.1
[INFO] [stderr]    Compiling borsh-derive v0.9.3
[INFO] [stderr]    Compiling parity-scale-codec-derive v2.3.1
[INFO] [stderr]     Checking borsh v0.9.3
[INFO] [stderr]     Checking near-account-id v0.14.0
[INFO] [stderr]     Checking zeropool-bn v0.5.11
[INFO] [stderr]     Checking near-abi v0.3.0
[INFO] [stderr]     Checking near-vm-errors v0.14.0
[INFO] [stderr]     Checking near-primitives-core v0.14.0
[INFO] [stderr]     Checking parity-scale-codec v2.3.1
[INFO] [stderr]     Checking impl-codec v0.5.1
[INFO] [stderr]     Checking primitive-types v0.10.1
[INFO] [stderr]     Checking near-crypto v0.14.0
[INFO] [stderr]     Checking near-primitives v0.14.0
[INFO] [stderr]     Checking near-vm-logic v0.14.0
[INFO] [stderr]     Checking near-sdk v4.1.1
[INFO] [stderr]     Checking near-contract-standards v4.1.1
[INFO] [stderr]     Checking nearAMM-demo v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `log`
[INFO] [stdout]  --> src/lib.rs:2:21
[INFO] [stdout]   |
[INFO] [stdout] 2 | use near_sdk::{env, log, near_bindgen, AccountId, Balance, require, PromiseOrValue, Promise};
[INFO] [stdout]   |                     ^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `UnorderedMap`
[INFO] [stdout]  --> src/lib.rs:3:29
[INFO] [stdout]   |
[INFO] [stdout] 3 | use near_sdk::collections::{UnorderedMap};
[INFO] [stdout]   |                             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `near_sdk::serde::Serialize`
[INFO] [stdout]  --> src/lib.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use near_sdk::serde::Serialize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LookupSet` and `key::Keccak256`
[INFO] [stdout]  --> src/lib.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use near_sdk::store::{LookupSet, key::Keccak256, LookupMap};
[INFO] [stdout]   |                       ^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `metadata::FungibleTokenMetadata`
[INFO] [stdout]  --> src/lib.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     metadata::FungibleTokenMetadata,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::str::FromStr`
[INFO] [stdout]   --> src/lib.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::str::FromStr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::convert::TryInto`
[INFO] [stdout]   --> src/lib.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::convert::TryInto;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `near_contract_standards::non_fungible_token::metadata::TokenMetadata`
[INFO] [stdout]   --> src/lib.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use near_contract_standards::non_fungible_token::metadata::TokenMetadata;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `abort`
[INFO] [stdout]   --> src/lib.rs:16:21
[INFO] [stdout]    |
[INFO] [stdout] 16 | use near_sdk::env::{abort, panic_str};
[INFO] [stdout]    |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `env`
[INFO] [stdout]  --> src/ft_token.rs:2:30
[INFO] [stdout]   |
[INFO] [stdout] 2 | use near_sdk::{ext_contract, env, Gas, AccountId, PromiseOrValue};
[INFO] [stdout]   |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `near_contract_standards::fungible_token::receiver::FungibleTokenReceiver`
[INFO] [stdout]  --> src/ft_token.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use near_contract_standards::fungible_token::receiver::FungibleTokenReceiver;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::Market`
[INFO] [stdout]  --> src/ft_token.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::Market;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Promise`, `log`, `near_bindgen`, and `require`
[INFO] [stdout]  --> src/pool.rs:2:21
[INFO] [stdout]   |
[INFO] [stdout] 2 | use near_sdk::{env, log, near_bindgen, AccountId, Balance, Promise, require};
[INFO] [stdout]   |                     ^^^  ^^^^^^^^^^^^                      ^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `UnorderedMap`
[INFO] [stdout]  --> src/pool.rs:3:29
[INFO] [stdout]   |
[INFO] [stdout] 3 | use near_sdk::collections::{UnorderedMap};
[INFO] [stdout]   |                             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LookupSet` and `UnorderedSet`
[INFO] [stdout]  --> src/pool.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use near_sdk::store::{LookupSet, UnorderedSet};
[INFO] [stdout]   |                       ^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]   --> src/lib.rs:86:72
[INFO] [stdout]    |
[INFO] [stdout] 86 |             .unwrap_or_else(|| env::panic_str("Pool does not exist."));;
[INFO] [stdout]    |                                                                        ^ help: remove this semicolon
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(redundant_semicolons)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/lib.rs:110:72
[INFO] [stdout]     |
[INFO] [stdout] 110 |             .unwrap_or_else(|| env::panic_str("Pool does not exist."));;
[INFO] [stdout]     |                                                                        ^ help: remove this semicolon
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `near_sdk::testing_env`
[INFO] [stdout]    --> src/lib.rs:193:9
[INFO] [stdout]     |
[INFO] [stdout] 193 |     use near_sdk::testing_env;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `near_sdk::test_utils::VMContextBuilder`
[INFO] [stdout]    --> src/lib.rs:194:9
[INFO] [stdout]     |
[INFO] [stdout] 194 |     use near_sdk::test_utils::VMContextBuilder;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `near_sdk::Balance`
[INFO] [stdout]    --> src/lib.rs:195:9
[INFO] [stdout]     |
[INFO] [stdout] 195 |     use near_sdk::Balance;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `near_contract_standards::fungible_token::FungibleToken`
[INFO] [stdout]    --> src/lib.rs:196:9
[INFO] [stdout]     |
[INFO] [stdout] 196 |     use near_contract_standards::fungible_token::FungibleToken;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `near_sdk::json_types::ValidAccountId`: ValidAccountId is no longer maintained, and AccountId should be used instead
[INFO] [stdout]  --> src/lib.rs:5:34
[INFO] [stdout]   |
[INFO] [stdout] 5 | use near_sdk::json_types::{U128, ValidAccountId};
[INFO] [stdout]   |                                  ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `near_sdk::json_types::ValidAccountId`: ValidAccountId is no longer maintained, and AccountId should be used instead
[INFO] [stdout]    --> src/lib.rs:178:20
[INFO] [stdout]     |
[INFO] [stdout] 178 |         sender_id: ValidAccountId,
[INFO] [stdout]     |                    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `near_sdk::json_types::ValidAccountId`: ValidAccountId is no longer maintained, and AccountId should be used instead
[INFO] [stdout]  --> src/ft_token.rs:1:28
[INFO] [stdout]   |
[INFO] [stdout] 1 | use near_sdk::json_types::{ValidAccountId, U128};
[INFO] [stdout]   |                            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `near_sdk::json_types::ValidAccountId`: ValidAccountId is no longer maintained, and AccountId should be used instead
[INFO] [stdout]   --> src/ft_token.rs:16:22
[INFO] [stdout]    |
[INFO] [stdout] 16 |         receiver_id: ValidAccountId,
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `near_sdk::json_types::ValidAccountId`: ValidAccountId is no longer maintained, and AccountId should be used instead
[INFO] [stdout]   --> src/ft_token.rs:26:41
[INFO] [stdout]    |
[INFO] [stdout] 26 |     fn ft_balance_of(&self, account_id: ValidAccountId) -> U128;
[INFO] [stdout]    |                                         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log`
[INFO] [stdout]  --> src/lib.rs:2:21
[INFO] [stdout]   |
[INFO] [stdout] 2 | use near_sdk::{env, log, near_bindgen, AccountId, Balance, require, PromiseOrValue, Promise};
[INFO] [stdout]   |                     ^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `UnorderedMap`
[INFO] [stdout]  --> src/lib.rs:3:29
[INFO] [stdout]   |
[INFO] [stdout] 3 | use near_sdk::collections::{UnorderedMap};
[INFO] [stdout]   |                             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `near_sdk::serde::Serialize`
[INFO] [stdout]  --> src/lib.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use near_sdk::serde::Serialize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LookupSet` and `key::Keccak256`
[INFO] [stdout]  --> src/lib.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use near_sdk::store::{LookupSet, key::Keccak256, LookupMap};
[INFO] [stdout]   |                       ^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `metadata::FungibleTokenMetadata`
[INFO] [stdout]  --> src/lib.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     metadata::FungibleTokenMetadata,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::str::FromStr`
[INFO] [stdout]   --> src/lib.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::str::FromStr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::convert::TryInto`
[INFO] [stdout]   --> src/lib.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::convert::TryInto;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `near_contract_standards::non_fungible_token::metadata::TokenMetadata`
[INFO] [stdout]   --> src/lib.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use near_contract_standards::non_fungible_token::metadata::TokenMetadata;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `abort`
[INFO] [stdout]   --> src/lib.rs:16:21
[INFO] [stdout]    |
[INFO] [stdout] 16 | use near_sdk::env::{abort, panic_str};
[INFO] [stdout]    |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `env`
[INFO] [stdout]  --> src/ft_token.rs:2:30
[INFO] [stdout]   |
[INFO] [stdout] 2 | use near_sdk::{ext_contract, env, Gas, AccountId, PromiseOrValue};
[INFO] [stdout]   |                              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `near_contract_standards::fungible_token::receiver::FungibleTokenReceiver`
[INFO] [stdout]  --> src/ft_token.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use near_contract_standards::fungible_token::receiver::FungibleTokenReceiver;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::Market`
[INFO] [stdout]  --> src/ft_token.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::Market;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Promise`, `log`, `near_bindgen`, and `require`
[INFO] [stdout]  --> src/pool.rs:2:21
[INFO] [stdout]   |
[INFO] [stdout] 2 | use near_sdk::{env, log, near_bindgen, AccountId, Balance, Promise, require};
[INFO] [stdout]   |                     ^^^  ^^^^^^^^^^^^                      ^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `UnorderedMap`
[INFO] [stdout]  --> src/pool.rs:3:29
[INFO] [stdout]   |
[INFO] [stdout] 3 | use near_sdk::collections::{UnorderedMap};
[INFO] [stdout]   |                             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LookupSet` and `UnorderedSet`
[INFO] [stdout]  --> src/pool.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use near_sdk::store::{LookupSet, UnorderedSet};
[INFO] [stdout]   |                       ^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]   --> src/lib.rs:86:72
[INFO] [stdout]    |
[INFO] [stdout] 86 |             .unwrap_or_else(|| env::panic_str("Pool does not exist."));;
[INFO] [stdout]    |                                                                        ^ help: remove this semicolon
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(redundant_semicolons)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/lib.rs:110:72
[INFO] [stdout]     |
[INFO] [stdout] 110 |             .unwrap_or_else(|| env::panic_str("Pool does not exist."));;
[INFO] [stdout]     |                                                                        ^ help: remove this semicolon
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `near_sdk::json_types::ValidAccountId`: ValidAccountId is no longer maintained, and AccountId should be used instead
[INFO] [stdout]  --> src/lib.rs:5:34
[INFO] [stdout]   |
[INFO] [stdout] 5 | use near_sdk::json_types::{U128, ValidAccountId};
[INFO] [stdout]   |                                  ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `near_sdk::json_types::ValidAccountId`: ValidAccountId is no longer maintained, and AccountId should be used instead
[INFO] [stdout]    --> src/lib.rs:178:20
[INFO] [stdout]     |
[INFO] [stdout] 178 |         sender_id: ValidAccountId,
[INFO] [stdout]     |                    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `near_sdk::json_types::ValidAccountId`: ValidAccountId is no longer maintained, and AccountId should be used instead
[INFO] [stdout]  --> src/ft_token.rs:1:28
[INFO] [stdout]   |
[INFO] [stdout] 1 | use near_sdk::json_types::{ValidAccountId, U128};
[INFO] [stdout]   |                            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `near_sdk::json_types::ValidAccountId`: ValidAccountId is no longer maintained, and AccountId should be used instead
[INFO] [stdout]   --> src/ft_token.rs:16:22
[INFO] [stdout]    |
[INFO] [stdout] 16 |         receiver_id: ValidAccountId,
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `near_sdk::json_types::ValidAccountId`: ValidAccountId is no longer maintained, and AccountId should be used instead
[INFO] [stdout]   --> src/ft_token.rs:26:41
[INFO] [stdout]    |
[INFO] [stdout] 26 |     fn ft_balance_of(&self, account_id: ValidAccountId) -> U128;
[INFO] [stdout]    |                                         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `p`
[INFO] [stdout]    --> src/lib.rs:168:18
[INFO] [stdout]     |
[INFO] [stdout] 168 |             Some(p) => self.pools.get_mut(&(tokenIn.clone(), tokenOut.clone())),
[INFO] [stdout]     |                  ^ help: if this is intentional, prefix it with an underscore: `_p`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `msg`
[INFO] [stdout]    --> src/lib.rs:180:9
[INFO] [stdout]     |
[INFO] [stdout] 180 |         msg: String,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_msg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INITIAL_BALANCE` is never used
[INFO] [stdout]   --> src/lib.rs:23:7
[INFO] [stdout]    |
[INFO] [stdout] 23 | const INITIAL_BALANCE: Balance = 250_000_000_000_000_000_000_000; // 2.5e23yN, 0.25N
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GAS_FOR_FT_TRANSFER` is never used
[INFO] [stdout]  --> src/ft_token.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const GAS_FOR_FT_TRANSFER: Gas = Gas(10_000_000_000_000);
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `FungibleToken` is never used
[INFO] [stdout]   --> src/ft_token.rs:11:11
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub trait FungibleToken {
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `FungibleTokenMetadataProvider` is never used
[INFO] [stdout]   --> src/ft_token.rs:30:11
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub trait FungibleTokenMetadataProvider {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NEAR` is never used
[INFO] [stdout]    --> src/lib.rs:199:11
[INFO] [stdout]     |
[INFO] [stdout] 199 |     const NEAR: u128 = 1000000000000000000000000;
[INFO] [stdout]     |           ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenA` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:53:33
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn init_pool(&mut self, tokenA: AccountId, tokenB: AccountId) {
[INFO] [stdout]    |                                 ^^^^^^ help: convert the identifier to snake case: `token_a`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenB` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:53:52
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn init_pool(&mut self, tokenA: AccountId, tokenB: AccountId) {
[INFO] [stdout]    |                                                    ^^^^^^ help: convert the identifier to snake case: `token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenA` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:53:33
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn init_pool(&mut self, tokenA: AccountId, tokenB: AccountId) {
[INFO] [stdout]    |                                 ^^^^^^ help: convert the identifier to snake case: `token_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenB` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:53:52
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn init_pool(&mut self, tokenA: AccountId, tokenB: AccountId) {
[INFO] [stdout]    |                                                    ^^^^^^ help: convert the identifier to snake case: `token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:58:28
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn get_pool(&self, tokenIn: AccountId, tokenOut: AccountId) -> Option<&Pool> {
[INFO] [stdout]    |                            ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenOut` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:58:48
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn get_pool(&self, tokenIn: AccountId, tokenOut: AccountId) -> Option<&Pool> {
[INFO] [stdout]    |                                                ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:58:28
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn get_pool(&self, tokenIn: AccountId, tokenOut: AccountId) -> Option<&Pool> {
[INFO] [stdout]    |                            ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenOut` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:58:48
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn get_pool(&self, tokenIn: AccountId, tokenOut: AccountId) -> Option<&Pool> {
[INFO] [stdout]    |                                                ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:80:9
[INFO] [stdout]    |
[INFO] [stdout] 80 |         tokenIn: AccountId,
[INFO] [stdout]    |         ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:81:9
[INFO] [stdout]    |
[INFO] [stdout] 81 |         amountIn: U128,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `amount_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenOut` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:82:9
[INFO] [stdout]    |
[INFO] [stdout] 82 |         tokenOut: AccountId,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:80:9
[INFO] [stdout]    |
[INFO] [stdout] 80 |         tokenIn: AccountId,
[INFO] [stdout]    |         ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `amountIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:81:9
[INFO] [stdout]    |
[INFO] [stdout] 81 |         amountIn: U128,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `amount_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenOut` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:82:9
[INFO] [stdout]    |
[INFO] [stdout] 82 |         tokenOut: AccountId,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:104:9
[INFO] [stdout]     |
[INFO] [stdout] 104 |         tokenIn: AccountId,
[INFO] [stdout]     |         ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `maxIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:105:9
[INFO] [stdout]     |
[INFO] [stdout] 105 |         maxIn: U128,
[INFO] [stdout]     |         ^^^^^ help: convert the identifier to snake case: `max_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:106:9
[INFO] [stdout]     |
[INFO] [stdout] 106 |         tokenOut: AccountId,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:107:9
[INFO] [stdout]     |
[INFO] [stdout] 107 |         amountOut: U128
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `amount_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:104:9
[INFO] [stdout]     |
[INFO] [stdout] 104 |         tokenIn: AccountId,
[INFO] [stdout]     |         ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `maxIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:105:9
[INFO] [stdout]     |
[INFO] [stdout] 105 |         maxIn: U128,
[INFO] [stdout]     |         ^^^^^ help: convert the identifier to snake case: `max_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:106:9
[INFO] [stdout]     |
[INFO] [stdout] 106 |         tokenOut: AccountId,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `amountOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:107:9
[INFO] [stdout]     |
[INFO] [stdout] 107 |         amountOut: U128
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `amount_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountOut` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:93:13
[INFO] [stdout]    |
[INFO] [stdout] 93 |         let amountOut = pool.calculate_in_to_out(&tokenIn, amountIn);
[INFO] [stdout]    |             ^^^^^^^^^ help: convert the identifier to snake case: `amount_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:117:13
[INFO] [stdout]     |
[INFO] [stdout] 117 |         let amountIn = pool.calculate_out_to_in(&tokenOut, amountOut);
[INFO] [stdout]     |             ^^^^^^^^ help: convert the identifier to snake case: `amount_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:126:9
[INFO] [stdout]     |
[INFO] [stdout] 126 |         tokenIn: &AccountId,
[INFO] [stdout]     |         ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:127:9
[INFO] [stdout]     |
[INFO] [stdout] 127 |         amountIn: U128,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `amount_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:128:9
[INFO] [stdout]     |
[INFO] [stdout] 128 |         tokenOut: &AccountId,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:129:9
[INFO] [stdout]     |
[INFO] [stdout] 129 |         amountOut: U128
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `amount_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:166:32
[INFO] [stdout]     |
[INFO] [stdout] 166 |     fn get_mut_pool(&mut self, tokenIn: &AccountId, tokenOut: &AccountId) -> Option<&mut Pool> {
[INFO] [stdout]     |                                ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:166:53
[INFO] [stdout]     |
[INFO] [stdout] 166 |     fn get_mut_pool(&mut self, tokenIn: &AccountId, tokenOut: &AccountId) -> Option<&mut Pool> {
[INFO] [stdout]     |                                                     ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub tokenA: AccountId,
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `token_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub tokenB: AccountId,
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `balanceA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub balanceA: Balance,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `balance_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `balanceB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub balanceB: Balance,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `balance_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:21:16
[INFO] [stdout]    |
[INFO] [stdout] 21 |     pub fn new(tokenA: &AccountId, tokenB: &AccountId) -> Self {
[INFO] [stdout]    |                ^^^^^^ help: convert the identifier to snake case: `token_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:21:36
[INFO] [stdout]    |
[INFO] [stdout] 21 |     pub fn new(tokenA: &AccountId, tokenB: &AccountId) -> Self {
[INFO] [stdout]    |                                    ^^^^^^ help: convert the identifier to snake case: `token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:30:30
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub fn incr_a(&mut self, amountA: U128) {
[INFO] [stdout]    |                              ^^^^^^^ help: convert the identifier to snake case: `amount_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:35:30
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub fn incr_b(&mut self, amountB: U128) {
[INFO] [stdout]    |                              ^^^^^^^ help: convert the identifier to snake case: `amount_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:40:30
[INFO] [stdout]    |
[INFO] [stdout] 40 |     pub fn decr_a(&mut self, amountA: U128) {
[INFO] [stdout]    |                              ^^^^^^^ help: convert the identifier to snake case: `amount_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:45:30
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub fn decr_b(&mut self, amountB: U128) {
[INFO] [stdout]    |                              ^^^^^^^ help: convert the identifier to snake case: `amount_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `inToken` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:77:39
[INFO] [stdout]    |
[INFO] [stdout] 77 |     pub fn calculate_in_to_out(&self, inToken: &AccountId, amount: U128) -> U128 {
[INFO] [stdout]    |                                       ^^^^^^^ help: convert the identifier to snake case: `in_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `constK` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:78:13
[INFO] [stdout]    |
[INFO] [stdout] 78 |         let constK = self.balanceA
[INFO] [stdout]    |             ^^^^^^ help: convert the identifier to snake case: `const_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:83:17
[INFO] [stdout]    |
[INFO] [stdout] 83 |             let newB = constK
[INFO] [stdout]    |                 ^^^^ help: convert the identifier to snake case: `new_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:90:17
[INFO] [stdout]    |
[INFO] [stdout] 90 |             let newA = constK
[INFO] [stdout]    |                 ^^^^ help: convert the identifier to snake case: `new_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `outToken` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:98:39
[INFO] [stdout]    |
[INFO] [stdout] 98 |     pub fn calculate_out_to_in(&self, outToken: &AccountId, amount: U128) -> U128 {
[INFO] [stdout]    |                                       ^^^^^^^^ help: convert the identifier to snake case: `out_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `constK` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:99:13
[INFO] [stdout]    |
[INFO] [stdout] 99 |         let constK = self.balanceA
[INFO] [stdout]    |             ^^^^^^ help: convert the identifier to snake case: `const_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newB` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:104:17
[INFO] [stdout]     |
[INFO] [stdout] 104 |             let newB = constK
[INFO] [stdout]     |                 ^^^^ help: convert the identifier to snake case: `new_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newA` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:111:17
[INFO] [stdout]     |
[INFO] [stdout] 111 |             let newA = constK
[INFO] [stdout]     |                 ^^^^ help: convert the identifier to snake case: `new_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountA` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:120:36
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn calculate_a_to_b(&self, amountA: U128) -> U128 {
[INFO] [stdout]     |                                    ^^^^^^^ help: convert the identifier to snake case: `amount_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `constK` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:121:13
[INFO] [stdout]     |
[INFO] [stdout] 121 |         let constK = self.balanceA
[INFO] [stdout]     |             ^^^^^^ help: convert the identifier to snake case: `const_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newB` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:124:13
[INFO] [stdout]     |
[INFO] [stdout] 124 |         let newB = constK
[INFO] [stdout]     |             ^^^^ help: convert the identifier to snake case: `new_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountB` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:131:36
[INFO] [stdout]     |
[INFO] [stdout] 131 |     pub fn calculate_b_to_a(&self, amountB: U128) -> U128 {
[INFO] [stdout]     |                                    ^^^^^^^ help: convert the identifier to snake case: `amount_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `constK` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:132:13
[INFO] [stdout]     |
[INFO] [stdout] 132 |         let constK = self.balanceA
[INFO] [stdout]     |             ^^^^^^ help: convert the identifier to snake case: `const_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newA` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:135:13
[INFO] [stdout]     |
[INFO] [stdout] 135 |         let newA = constK
[INFO] [stdout]     |             ^^^^ help: convert the identifier to snake case: `new_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenA` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:210:13
[INFO] [stdout]     |
[INFO] [stdout] 210 |         let tokenA: AccountId = "tokena".parse().unwrap();
[INFO] [stdout]     |             ^^^^^^ help: convert the identifier to snake case: `token_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenB` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:211:13
[INFO] [stdout]     |
[INFO] [stdout] 211 |         let tokenB: AccountId = "tokenb".parse().unwrap();
[INFO] [stdout]     |             ^^^^^^ help: convert the identifier to snake case: `token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `p`
[INFO] [stdout]    --> src/lib.rs:168:18
[INFO] [stdout]     |
[INFO] [stdout] 168 |             Some(p) => self.pools.get_mut(&(tokenIn.clone(), tokenOut.clone())),
[INFO] [stdout]     |                  ^ help: if this is intentional, prefix it with an underscore: `_p`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `msg`
[INFO] [stdout]    --> src/lib.rs:180:9
[INFO] [stdout]     |
[INFO] [stdout] 180 |         msg: String,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_msg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INITIAL_BALANCE` is never used
[INFO] [stdout]   --> src/lib.rs:23:7
[INFO] [stdout]    |
[INFO] [stdout] 23 | const INITIAL_BALANCE: Balance = 250_000_000_000_000_000_000_000; // 2.5e23yN, 0.25N
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GAS_FOR_FT_TRANSFER` is never used
[INFO] [stdout]  --> src/ft_token.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const GAS_FOR_FT_TRANSFER: Gas = Gas(10_000_000_000_000);
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `FungibleToken` is never used
[INFO] [stdout]   --> src/ft_token.rs:11:11
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub trait FungibleToken {
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `FungibleTokenMetadataProvider` is never used
[INFO] [stdout]   --> src/ft_token.rs:30:11
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub trait FungibleTokenMetadataProvider {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: crate `nearAMM_demo` should have a snake case name
[INFO] [stdout]   |
[INFO] [stdout]   = help: convert the identifier to snake case: `near_amm_demo`
[INFO] [stdout]   = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenA` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:53:33
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn init_pool(&mut self, tokenA: AccountId, tokenB: AccountId) {
[INFO] [stdout]    |                                 ^^^^^^ help: convert the identifier to snake case: `token_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenB` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:53:52
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn init_pool(&mut self, tokenA: AccountId, tokenB: AccountId) {
[INFO] [stdout]    |                                                    ^^^^^^ help: convert the identifier to snake case: `token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenA` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:53:33
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn init_pool(&mut self, tokenA: AccountId, tokenB: AccountId) {
[INFO] [stdout]    |                                 ^^^^^^ help: convert the identifier to snake case: `token_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenB` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:53:52
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn init_pool(&mut self, tokenA: AccountId, tokenB: AccountId) {
[INFO] [stdout]    |                                                    ^^^^^^ help: convert the identifier to snake case: `token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:58:28
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn get_pool(&self, tokenIn: AccountId, tokenOut: AccountId) -> Option<&Pool> {
[INFO] [stdout]    |                            ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenOut` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:58:48
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn get_pool(&self, tokenIn: AccountId, tokenOut: AccountId) -> Option<&Pool> {
[INFO] [stdout]    |                                                ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:58:28
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn get_pool(&self, tokenIn: AccountId, tokenOut: AccountId) -> Option<&Pool> {
[INFO] [stdout]    |                            ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenOut` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:58:48
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn get_pool(&self, tokenIn: AccountId, tokenOut: AccountId) -> Option<&Pool> {
[INFO] [stdout]    |                                                ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:80:9
[INFO] [stdout]    |
[INFO] [stdout] 80 |         tokenIn: AccountId,
[INFO] [stdout]    |         ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:81:9
[INFO] [stdout]    |
[INFO] [stdout] 81 |         amountIn: U128,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `amount_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenOut` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:82:9
[INFO] [stdout]    |
[INFO] [stdout] 82 |         tokenOut: AccountId,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:80:9
[INFO] [stdout]    |
[INFO] [stdout] 80 |         tokenIn: AccountId,
[INFO] [stdout]    |         ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `amountIn` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:81:9
[INFO] [stdout]    |
[INFO] [stdout] 81 |         amountIn: U128,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `amount_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenOut` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:82:9
[INFO] [stdout]    |
[INFO] [stdout] 82 |         tokenOut: AccountId,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:104:9
[INFO] [stdout]     |
[INFO] [stdout] 104 |         tokenIn: AccountId,
[INFO] [stdout]     |         ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `maxIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:105:9
[INFO] [stdout]     |
[INFO] [stdout] 105 |         maxIn: U128,
[INFO] [stdout]     |         ^^^^^ help: convert the identifier to snake case: `max_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:106:9
[INFO] [stdout]     |
[INFO] [stdout] 106 |         tokenOut: AccountId,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:107:9
[INFO] [stdout]     |
[INFO] [stdout] 107 |         amountOut: U128
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `amount_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:104:9
[INFO] [stdout]     |
[INFO] [stdout] 104 |         tokenIn: AccountId,
[INFO] [stdout]     |         ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `maxIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:105:9
[INFO] [stdout]     |
[INFO] [stdout] 105 |         maxIn: U128,
[INFO] [stdout]     |         ^^^^^ help: convert the identifier to snake case: `max_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:106:9
[INFO] [stdout]     |
[INFO] [stdout] 106 |         tokenOut: AccountId,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `amountOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:107:9
[INFO] [stdout]     |
[INFO] [stdout] 107 |         amountOut: U128
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `amount_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountOut` should have a snake case name
[INFO] [stdout]   --> src/lib.rs:93:13
[INFO] [stdout]    |
[INFO] [stdout] 93 |         let amountOut = pool.calculate_in_to_out(&tokenIn, amountIn);
[INFO] [stdout]    |             ^^^^^^^^^ help: convert the identifier to snake case: `amount_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:117:13
[INFO] [stdout]     |
[INFO] [stdout] 117 |         let amountIn = pool.calculate_out_to_in(&tokenOut, amountOut);
[INFO] [stdout]     |             ^^^^^^^^ help: convert the identifier to snake case: `amount_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:126:9
[INFO] [stdout]     |
[INFO] [stdout] 126 |         tokenIn: &AccountId,
[INFO] [stdout]     |         ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:127:9
[INFO] [stdout]     |
[INFO] [stdout] 127 |         amountIn: U128,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `amount_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:128:9
[INFO] [stdout]     |
[INFO] [stdout] 128 |         tokenOut: &AccountId,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:129:9
[INFO] [stdout]     |
[INFO] [stdout] 129 |         amountOut: U128
[INFO] [stdout]     |         ^^^^^^^^^ help: convert the identifier to snake case: `amount_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenIn` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:166:32
[INFO] [stdout]     |
[INFO] [stdout] 166 |     fn get_mut_pool(&mut self, tokenIn: &AccountId, tokenOut: &AccountId) -> Option<&mut Pool> {
[INFO] [stdout]     |                                ^^^^^^^ help: convert the identifier to snake case: `token_in`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenOut` should have a snake case name
[INFO] [stdout]    --> src/lib.rs:166:53
[INFO] [stdout]     |
[INFO] [stdout] 166 |     fn get_mut_pool(&mut self, tokenIn: &AccountId, tokenOut: &AccountId) -> Option<&mut Pool> {
[INFO] [stdout]     |                                                     ^^^^^^^^ help: convert the identifier to snake case: `token_out`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub tokenA: AccountId,
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `token_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `tokenB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub tokenB: AccountId,
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `balanceA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub balanceA: Balance,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `balance_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `balanceB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub balanceB: Balance,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `balance_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:21:16
[INFO] [stdout]    |
[INFO] [stdout] 21 |     pub fn new(tokenA: &AccountId, tokenB: &AccountId) -> Self {
[INFO] [stdout]    |                ^^^^^^ help: convert the identifier to snake case: `token_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `tokenB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:21:36
[INFO] [stdout]    |
[INFO] [stdout] 21 |     pub fn new(tokenA: &AccountId, tokenB: &AccountId) -> Self {
[INFO] [stdout]    |                                    ^^^^^^ help: convert the identifier to snake case: `token_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:30:30
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub fn incr_a(&mut self, amountA: U128) {
[INFO] [stdout]    |                              ^^^^^^^ help: convert the identifier to snake case: `amount_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:35:30
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub fn incr_b(&mut self, amountB: U128) {
[INFO] [stdout]    |                              ^^^^^^^ help: convert the identifier to snake case: `amount_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:40:30
[INFO] [stdout]    |
[INFO] [stdout] 40 |     pub fn decr_a(&mut self, amountA: U128) {
[INFO] [stdout]    |                              ^^^^^^^ help: convert the identifier to snake case: `amount_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:45:30
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub fn decr_b(&mut self, amountB: U128) {
[INFO] [stdout]    |                              ^^^^^^^ help: convert the identifier to snake case: `amount_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `inToken` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:77:39
[INFO] [stdout]    |
[INFO] [stdout] 77 |     pub fn calculate_in_to_out(&self, inToken: &AccountId, amount: U128) -> U128 {
[INFO] [stdout]    |                                       ^^^^^^^ help: convert the identifier to snake case: `in_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `constK` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:78:13
[INFO] [stdout]    |
[INFO] [stdout] 78 |         let constK = self.balanceA
[INFO] [stdout]    |             ^^^^^^ help: convert the identifier to snake case: `const_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newB` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:83:17
[INFO] [stdout]    |
[INFO] [stdout] 83 |             let newB = constK
[INFO] [stdout]    |                 ^^^^ help: convert the identifier to snake case: `new_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newA` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:90:17
[INFO] [stdout]    |
[INFO] [stdout] 90 |             let newA = constK
[INFO] [stdout]    |                 ^^^^ help: convert the identifier to snake case: `new_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `outToken` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:98:39
[INFO] [stdout]    |
[INFO] [stdout] 98 |     pub fn calculate_out_to_in(&self, outToken: &AccountId, amount: U128) -> U128 {
[INFO] [stdout]    |                                       ^^^^^^^^ help: convert the identifier to snake case: `out_token`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `constK` should have a snake case name
[INFO] [stdout]   --> src/pool.rs:99:13
[INFO] [stdout]    |
[INFO] [stdout] 99 |         let constK = self.balanceA
[INFO] [stdout]    |             ^^^^^^ help: convert the identifier to snake case: `const_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newB` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:104:17
[INFO] [stdout]     |
[INFO] [stdout] 104 |             let newB = constK
[INFO] [stdout]     |                 ^^^^ help: convert the identifier to snake case: `new_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newA` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:111:17
[INFO] [stdout]     |
[INFO] [stdout] 111 |             let newA = constK
[INFO] [stdout]     |                 ^^^^ help: convert the identifier to snake case: `new_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountA` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:120:36
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn calculate_a_to_b(&self, amountA: U128) -> U128 {
[INFO] [stdout]     |                                    ^^^^^^^ help: convert the identifier to snake case: `amount_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `constK` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:121:13
[INFO] [stdout]     |
[INFO] [stdout] 121 |         let constK = self.balanceA
[INFO] [stdout]     |             ^^^^^^ help: convert the identifier to snake case: `const_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newB` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:124:13
[INFO] [stdout]     |
[INFO] [stdout] 124 |         let newB = constK
[INFO] [stdout]     |             ^^^^ help: convert the identifier to snake case: `new_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `amountB` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:131:36
[INFO] [stdout]     |
[INFO] [stdout] 131 |     pub fn calculate_b_to_a(&self, amountB: U128) -> U128 {
[INFO] [stdout]     |                                    ^^^^^^^ help: convert the identifier to snake case: `amount_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `constK` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:132:13
[INFO] [stdout]     |
[INFO] [stdout] 132 |         let constK = self.balanceA
[INFO] [stdout]     |             ^^^^^^ help: convert the identifier to snake case: `const_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `newA` should have a snake case name
[INFO] [stdout]    --> src/pool.rs:135:13
[INFO] [stdout]     |
[INFO] [stdout] 135 |         let newA = constK
[INFO] [stdout]     |             ^^^^ help: convert the identifier to snake case: `new_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 47.67s
[INFO] running `Command { std: "docker" "inspect" "32d60f71f4aa7f7bed1fc21aee67af519cc68de18d11d2dd57278a2e69aa5c1e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "32d60f71f4aa7f7bed1fc21aee67af519cc68de18d11d2dd57278a2e69aa5c1e", kill_on_drop: false }`
[INFO] [stdout] 32d60f71f4aa7f7bed1fc21aee67af519cc68de18d11d2dd57278a2e69aa5c1e
