[INFO] cloning repository https://github.com/1sra3l/rpg-stat
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/1sra3l/rpg-stat" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F1sra3l%2Frpg-stat", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F1sra3l%2Frpg-stat'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 921b18bc05f317498680938443cf474eec15da31
[INFO] building 1sra3l/rpg-stat against try#334963c956d25708feab489a3816ae63f639355d for pr-135216
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F1sra3l%2Frpg-stat" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc2/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/1sra3l/rpg-stat on toolchain 334963c956d25708feab489a3816ae63f639355d
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+334963c956d25708feab489a3816ae63f639355d" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/1sra3l/rpg-stat
[INFO] finished tweaking git repo https://github.com/1sra3l/rpg-stat
[INFO] tweaked toml for git repo https://github.com/1sra3l/rpg-stat written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] crate git repo https://github.com/1sra3l/rpg-stat 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" "+334963c956d25708feab489a3816ae63f639355d" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:f3a9d4ad9d972b27faf3965f35b62e55ba32bbce8f20bc8fe909558a86702fde" "/opt/rustwide/cargo-home/bin/cargo" "+334963c956d25708feab489a3816ae63f639355d" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2d05895c295932819e1e8501e97148246bbc7fd9be523cf9e2f648735e6c0a0e
[INFO] running `Command { std: "docker" "start" "-a" "2d05895c295932819e1e8501e97148246bbc7fd9be523cf9e2f648735e6c0a0e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2d05895c295932819e1e8501e97148246bbc7fd9be523cf9e2f648735e6c0a0e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2d05895c295932819e1e8501e97148246bbc7fd9be523cf9e2f648735e6c0a0e", kill_on_drop: false }`
[INFO] [stdout] 2d05895c295932819e1e8501e97148246bbc7fd9be523cf9e2f648735e6c0a0e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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" "-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:f3a9d4ad9d972b27faf3965f35b62e55ba32bbce8f20bc8fe909558a86702fde" "/opt/rustwide/cargo-home/bin/cargo" "+334963c956d25708feab489a3816ae63f639355d" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 029bdb0d4d15d302d0a019bbaf7186347673e4133c0cb9f75aee01d46020f8b2
[INFO] running `Command { std: "docker" "start" "-a" "029bdb0d4d15d302d0a019bbaf7186347673e4133c0cb9f75aee01d46020f8b2", kill_on_drop: false }`
[INFO] [stderr]    Compiling num-traits v0.2.14
[INFO] [stderr]    Compiling libc v0.2.109
[INFO] [stderr]    Compiling proc-macro2 v1.0.33
[INFO] [stderr]    Compiling num-integer v0.1.44
[INFO] [stderr]    Compiling syn v1.0.82
[INFO] [stderr]    Compiling num-bigint v0.2.6
[INFO] [stderr]    Compiling serde_derive v1.0.130
[INFO] [stderr]    Compiling num-rational v0.2.4
[INFO] [stderr]    Compiling num-iter v0.1.42
[INFO] [stderr]    Compiling num-complex v0.2.4
[INFO] [stderr]    Compiling serde v1.0.130
[INFO] [stderr]    Compiling unicode-width v0.1.9
[INFO] [stderr]    Compiling ppv-lite86 v0.2.15
[INFO] [stderr]    Compiling textwrap v0.11.0
[INFO] [stderr]    Compiling yaml-rust v0.3.5
[INFO] [stderr]    Compiling strsim v0.8.0
[INFO] [stderr]    Compiling vec_map v0.8.2
[INFO] [stderr]    Compiling quote v1.0.10
[INFO] [stderr]    Compiling getrandom v0.2.3
[INFO] [stderr]    Compiling atty v0.2.14
[INFO] [stderr]    Compiling clap v2.34.0
[INFO] [stderr]    Compiling rand_core v0.6.3
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.4
[INFO] [stderr]    Compiling num v0.2.1
[INFO] [stderr]    Compiling toml v0.5.8
[INFO] [stderr]    Compiling rpg-stat v2021.12.16 (/opt/rustwide/workdir)
[INFO] [stdout] warning: trait `Functions` is never used
[INFO] [stdout]    --> src/stats.rs:262:11
[INFO] [stdout]     |
[INFO] [stdout] 262 | pub trait Functions <T:Copy
[INFO] [stdout]     |           ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `build_basic`, `build_normal`, and `build_advanced` are never used
[INFO] [stdout]    --> src/stats.rs:304:8
[INFO] [stdout]     |
[INFO] [stdout] 287 | pub trait Builder <T:Copy
[INFO] [stdout]     |           ------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 304 |     fn build_basic(&self, id:T, level:T) -> Basic<T>;
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 305 |     // Build a `Normal` stat
[INFO] [stdout] 306 |     fn build_normal(&self, id:T, level:T) -> Normal<T>;
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 307 |     // Build an `Advanced` stat
[INFO] [stdout] 308 |     fn build_advanced(&self, id:T, level:T) -> Advanced<T>;
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `BasicPremade` is never used
[INFO] [stdout]    --> src/stats.rs:315:11
[INFO] [stdout]     |
[INFO] [stdout] 315 | pub trait BasicPremade<T:Copy
[INFO] [stdout]     |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `NormalPremade` is never used
[INFO] [stdout]    --> src/stats.rs:562:11
[INFO] [stdout]     |
[INFO] [stdout] 562 | pub trait NormalPremade<T:Copy
[INFO] [stdout]     |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `AdvancedPremade` is never used
[INFO] [stdout]    --> src/stats.rs:884:11
[INFO] [stdout]     |
[INFO] [stdout] 884 | pub trait AdvancedPremade<T:Copy
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]     --> src/stats.rs:1527:8
[INFO] [stdout]      |
[INFO] [stdout] 1521 | pub trait Premade {
[INFO] [stdout]      |           ------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 1527 |     fn set_hp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1530 |     fn set_mp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1533 |     fn set_xp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1542 |     fn set_xp_next(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1545 |     fn set_gp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1567 |     fn id(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1571 |     fn hp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1575 |     fn mp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1583 |     fn hp_max(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1587 |     fn mp_max(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1591 |     fn xp_next(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1595 |     fn level(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1599 |     fn speed(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1603 |     fn gp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1607 |     fn atk(&self) -> f64 {
[INFO] [stdout]      |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 1611 |     fn def(&self) -> f64 {
[INFO] [stdout]      |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 1615 |     fn m_atk(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1619 |     fn m_def(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1638 |     fn add_xp(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1658 |     fn damage(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1668 |     fn heal(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1685 |     fn attack(&self, other:Stats) -> f64 {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1689 |     fn accuracy(&self) -> bool {
[INFO] [stdout]      |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1694 |     fn defense(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1697 |     fn buy(&mut self, price:f64) -> bool {
[INFO] [stdout]      |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 1705 |     fn earn(&mut self, price:f64) {
[INFO] [stdout]      |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `tp_cost` and `tp_total` are never used
[INFO] [stdout]    --> src/special.rs:506:8
[INFO] [stdout]     |
[INFO] [stdout] 488 | pub trait SpecialMove <T:Copy 
[INFO] [stdout]     |           ----------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 506 |     fn tp_cost(&self, input:T) -> T {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 509 |     fn tp_total(&self, input:T) -> T{
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `cost` and `resell` are never used
[INFO] [stdout]   --> src/item.rs:43:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub trait Item {
[INFO] [stdout]    |           ---- methods in this trait
[INFO] [stdout] 42 |     fn value(&self) -> f64;
[INFO] [stdout] 43 |     fn cost(&self) -> f64;
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 44 |     fn resell(&self) -> f64;
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 35.11s
[INFO] running `Command { std: "docker" "inspect" "029bdb0d4d15d302d0a019bbaf7186347673e4133c0cb9f75aee01d46020f8b2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "029bdb0d4d15d302d0a019bbaf7186347673e4133c0cb9f75aee01d46020f8b2", kill_on_drop: false }`
[INFO] [stdout] 029bdb0d4d15d302d0a019bbaf7186347673e4133c0cb9f75aee01d46020f8b2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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" "-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:f3a9d4ad9d972b27faf3965f35b62e55ba32bbce8f20bc8fe909558a86702fde" "/opt/rustwide/cargo-home/bin/cargo" "+334963c956d25708feab489a3816ae63f639355d" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6d1442d6b22421eba2368e4f5aee312aa78177e529c9aba1e15113c1db12917e
[INFO] running `Command { std: "docker" "start" "-a" "6d1442d6b22421eba2368e4f5aee312aa78177e529c9aba1e15113c1db12917e", kill_on_drop: false }`
[INFO] [stderr]    Compiling rpg-stat v2021.12.16 (/opt/rustwide/workdir)
[INFO] [stdout] warning: trait `Functions` is never used
[INFO] [stdout]    --> src/stats.rs:262:11
[INFO] [stdout]     |
[INFO] [stdout] 262 | pub trait Functions <T:Copy
[INFO] [stdout]     |           ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `build_normal` and `build_advanced` are never used
[INFO] [stdout]    --> src/stats.rs:306:8
[INFO] [stdout]     |
[INFO] [stdout] 287 | pub trait Builder <T:Copy
[INFO] [stdout]     |           ------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 306 |     fn build_normal(&self, id:T, level:T) -> Normal<T>;
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 307 |     // Build an `Advanced` stat
[INFO] [stdout] 308 |     fn build_advanced(&self, id:T, level:T) -> Advanced<T>;
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/stats.rs:339:8
[INFO] [stdout]     |
[INFO] [stdout] 315 | pub trait BasicPremade<T:Copy
[INFO] [stdout]     |           ------------ methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 339 |     fn set_mp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 342 |     fn set_xp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 345 |     fn set_hp_max(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 348 |     fn set_mp_max(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 351 |     fn set_xp_next(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 354 |     fn set_gp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 358 |     fn id(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 366 |     fn mp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 370 |     fn xp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 378 |     fn mp_max(&self) -> T {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 382 |     fn xp_next(&self) -> T {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 386 |     fn level(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 390 |     fn speed(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 394 |     fn gp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/stats.rs:586:8
[INFO] [stdout]     |
[INFO] [stdout] 562 | pub trait NormalPremade<T:Copy
[INFO] [stdout]     |           ------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 586 |     fn set_mp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 589 |     fn set_xp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 592 |     fn set_hp_max(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 595 |     fn set_mp_max(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 598 |     fn set_xp_next(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 601 |     fn set_gp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 607 |     fn set_def(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 610 |     fn set_m_atk(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 613 |     fn set_m_def(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     fn id(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 625 |     fn mp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 629 |     fn xp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 633 |     fn hp_max(&self) -> T {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 637 |     fn mp_max(&self) -> T {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 641 |     fn xp_next(&self) -> T {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 645 |     fn level(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 649 |     fn speed(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 653 |     fn gp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 661 |     fn def(&self) -> T {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 665 |     fn m_atk(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 669 |     fn m_def(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 673 |     fn damage(&mut self, amount:T) {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 683 |     fn heal(&mut self, amount:T) {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     fn attack_stable(&self, other:Normal<T>) -> T { 
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 703 |     fn attack(&self, other:Normal<T>) -> T {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 717 |     fn defense(&self) -> T {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `AdvancedPremade` is never used
[INFO] [stdout]    --> src/stats.rs:884:11
[INFO] [stdout]     |
[INFO] [stdout] 884 | pub trait AdvancedPremade<T:Copy
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]     --> src/stats.rs:1527:8
[INFO] [stdout]      |
[INFO] [stdout] 1521 | pub trait Premade {
[INFO] [stdout]      |           ------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 1527 |     fn set_hp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1530 |     fn set_mp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1533 |     fn set_xp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1542 |     fn set_xp_next(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1545 |     fn set_gp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1567 |     fn id(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1571 |     fn hp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1575 |     fn mp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1583 |     fn hp_max(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1587 |     fn mp_max(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1591 |     fn xp_next(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1595 |     fn level(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1599 |     fn speed(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1603 |     fn gp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1607 |     fn atk(&self) -> f64 {
[INFO] [stdout]      |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 1611 |     fn def(&self) -> f64 {
[INFO] [stdout]      |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 1615 |     fn m_atk(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1619 |     fn m_def(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1638 |     fn add_xp(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1658 |     fn damage(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1668 |     fn heal(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1685 |     fn attack(&self, other:Stats) -> f64 {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1689 |     fn accuracy(&self) -> bool {
[INFO] [stdout]      |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1694 |     fn defense(&self) -> f64 {
[INFO] [stdout]      |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1697 |     fn buy(&mut self, price:f64) -> bool {
[INFO] [stdout]      |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 1705 |     fn earn(&mut self, price:f64) {
[INFO] [stdout]      |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `tp_cost` and `tp_total` are never used
[INFO] [stdout]    --> src/special.rs:506:8
[INFO] [stdout]     |
[INFO] [stdout] 488 | pub trait SpecialMove <T:Copy 
[INFO] [stdout]     |           ----------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 506 |     fn tp_cost(&self, input:T) -> T {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 509 |     fn tp_total(&self, input:T) -> T{
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `cost` and `resell` are never used
[INFO] [stdout]   --> src/item.rs:43:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub trait Item {
[INFO] [stdout]    |           ---- methods in this trait
[INFO] [stdout] 42 |     fn value(&self) -> f64;
[INFO] [stdout] 43 |     fn cost(&self) -> f64;
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 44 |     fn resell(&self) -> f64;
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 5.56s
[INFO] running `Command { std: "docker" "inspect" "6d1442d6b22421eba2368e4f5aee312aa78177e529c9aba1e15113c1db12917e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6d1442d6b22421eba2368e4f5aee312aa78177e529c9aba1e15113c1db12917e", kill_on_drop: false }`
[INFO] [stdout] 6d1442d6b22421eba2368e4f5aee312aa78177e529c9aba1e15113c1db12917e
