[INFO] fetching crate rpg-stat 2021.12.16...
[INFO] building rpg-stat-2021.12.16 against try#d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6 for pr-146237-1
[INFO] extracting crate rpg-stat 2021.12.16 into /workspace/builds/worker-6-tc2/source
[INFO] started tweaking crates.io crate rpg-stat 2021.12.16
[INFO] finished tweaking crates.io crate rpg-stat 2021.12.16
[INFO] tweaked toml for crates.io crate rpg-stat 2021.12.16 written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate rpg-stat 2021.12.16 on toolchain d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate rpg-stat 2021.12.16 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" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 758190542a05009f4380034db69b6e848b524923f91a603d4f0d440c6a01eb0e
[INFO] running `Command { std: "docker" "start" "-a" "758190542a05009f4380034db69b6e848b524923f91a603d4f0d440c6a01eb0e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "758190542a05009f4380034db69b6e848b524923f91a603d4f0d440c6a01eb0e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "758190542a05009f4380034db69b6e848b524923f91a603d4f0d440c6a01eb0e", kill_on_drop: false }`
[INFO] [stdout] 758190542a05009f4380034db69b6e848b524923f91a603d4f0d440c6a01eb0e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] fe46cc662ec0fae775b27533d9a0bede4aaa1452e73310d704cd1ccfeff6c848
[INFO] running `Command { std: "docker" "start" "-a" "fe46cc662ec0fae775b27533d9a0bede4aaa1452e73310d704cd1ccfeff6c848", kill_on_drop: false }`
[INFO] [stderr]    Compiling autocfg v1.0.1
[INFO] [stderr]    Compiling libc v0.2.109
[INFO] [stderr]    Compiling proc-macro2 v1.0.33
[INFO] [stderr]    Compiling unicode-xid v0.2.2
[INFO] [stderr]    Compiling syn v1.0.82
[INFO] [stderr]    Compiling serde_derive v1.0.130
[INFO] [stderr]    Compiling serde v1.0.130
[INFO] [stderr]    Compiling ppv-lite86 v0.2.15
[INFO] [stderr]    Compiling unicode-width v0.1.9
[INFO] [stderr]    Compiling strsim v0.8.0
[INFO] [stderr]    Compiling ansi_term v0.12.1
[INFO] [stderr]    Compiling yaml-rust v0.3.5
[INFO] [stderr]    Compiling vec_map v0.8.2
[INFO] [stderr]    Compiling textwrap v0.11.0
[INFO] [stderr]    Compiling num-traits v0.2.14
[INFO] [stderr]    Compiling num-integer v0.1.44
[INFO] [stderr]    Compiling num-bigint v0.2.6
[INFO] [stderr]    Compiling num-complex v0.2.4
[INFO] [stderr]    Compiling num-rational v0.2.4
[INFO] [stderr]    Compiling num-iter v0.1.42
[INFO] [stderr]    Compiling getrandom v0.2.3
[INFO] [stderr]    Compiling atty v0.2.14
[INFO] [stderr]    Compiling quote v1.0.10
[INFO] [stderr]    Compiling rand_core v0.6.3
[INFO] [stderr]    Compiling clap v2.34.0
[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: unused import: `crate::stats::Stats`
[INFO] [stdout]   --> src/chemistry.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::stats::Stats;
[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: `crate::stats::Builder`
[INFO] [stdout]   --> src/chemistry.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use crate::stats::Builder;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:116:13
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:172:13
[INFO] [stdout]     |
[INFO] [stdout] 172 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:242:13
[INFO] [stdout]     |
[INFO] [stdout] 242 |         let mut mp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hp` is never read
[INFO] [stdout]    --> src/armor.rs:626:17
[INFO] [stdout]     |
[INFO] [stdout] 626 |         let mut hp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `mp` is never read
[INFO] [stdout]    --> src/armor.rs:627:17
[INFO] [stdout]     |
[INFO] [stdout] 627 |         let mut mp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `xp` is never read
[INFO] [stdout]    --> src/armor.rs:628:17
[INFO] [stdout]     |
[INFO] [stdout] 628 |         let mut xp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `speed` is never read
[INFO] [stdout]    --> src/armor.rs:631:17
[INFO] [stdout]     |
[INFO] [stdout] 631 |         let mut speed:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:630:13
[INFO] [stdout]     |
[INFO] [stdout] 630 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hp` is never read
[INFO] [stdout]    --> src/armor.rs:658:17
[INFO] [stdout]     |
[INFO] [stdout] 658 |         let mut hp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `xp` is never read
[INFO] [stdout]    --> src/armor.rs:660:17
[INFO] [stdout]     |
[INFO] [stdout] 660 |         let mut xp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `speed` is never read
[INFO] [stdout]    --> src/armor.rs:663:17
[INFO] [stdout]     |
[INFO] [stdout] 663 |         let mut speed:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `atk` is never read
[INFO] [stdout]    --> src/armor.rs:664:17
[INFO] [stdout]     |
[INFO] [stdout] 664 |         let mut atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `def` is never read
[INFO] [stdout]    --> src/armor.rs:665:17
[INFO] [stdout]     |
[INFO] [stdout] 665 |         let mut def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_atk` is never read
[INFO] [stdout]    --> src/armor.rs:666:17
[INFO] [stdout]     |
[INFO] [stdout] 666 |         let mut m_atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_def` is never read
[INFO] [stdout]    --> src/armor.rs:667:17
[INFO] [stdout]     |
[INFO] [stdout] 667 |         let mut m_def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:662:13
[INFO] [stdout]     |
[INFO] [stdout] 662 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hp` is never read
[INFO] [stdout]    --> src/armor.rs:700:17
[INFO] [stdout]     |
[INFO] [stdout] 700 |         let mut hp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `xp` is never read
[INFO] [stdout]    --> src/armor.rs:702:17
[INFO] [stdout]     |
[INFO] [stdout] 702 |         let mut xp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `speed` is never read
[INFO] [stdout]    --> src/armor.rs:705:17
[INFO] [stdout]     |
[INFO] [stdout] 705 |         let mut speed:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `atk` is never read
[INFO] [stdout]    --> src/armor.rs:706:17
[INFO] [stdout]     |
[INFO] [stdout] 706 |         let mut atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `def` is never read
[INFO] [stdout]    --> src/armor.rs:707:17
[INFO] [stdout]     |
[INFO] [stdout] 707 |         let mut def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_atk` is never read
[INFO] [stdout]    --> src/armor.rs:708:17
[INFO] [stdout]     |
[INFO] [stdout] 708 |         let mut m_atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_def` is never read
[INFO] [stdout]    --> src/armor.rs:709:17
[INFO] [stdout]     |
[INFO] [stdout] 709 |         let mut m_def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `agility` is never read
[INFO] [stdout]    --> src/armor.rs:710:17
[INFO] [stdout]     |
[INFO] [stdout] 710 |         let mut agility:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `strength` is never read
[INFO] [stdout]    --> src/armor.rs:711:17
[INFO] [stdout]     |
[INFO] [stdout] 711 |         let mut strength:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `dexterity` is never read
[INFO] [stdout]    --> src/armor.rs:712:17
[INFO] [stdout]     |
[INFO] [stdout] 712 |         let mut dexterity:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `constitution` is never read
[INFO] [stdout]    --> src/armor.rs:713:17
[INFO] [stdout]     |
[INFO] [stdout] 713 |         let mut constitution:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `charisma` is never read
[INFO] [stdout]    --> src/armor.rs:715:17
[INFO] [stdout]     |
[INFO] [stdout] 715 |         let mut charisma:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:701:13
[INFO] [stdout]     |
[INFO] [stdout] 701 |         let mut mp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Functions` is never used
[INFO] [stdout]    --> src/stats.rs:258:11
[INFO] [stdout]     |
[INFO] [stdout] 258 | pub trait Functions <T:Copy
[INFO] [stdout]     |           ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Advanced` is never used
[INFO] [stdout]    --> src/class.rs:851:10
[INFO] [stdout]     |
[INFO] [stdout] 851 | pub enum Advanced {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Basic` is never used
[INFO] [stdout]    --> src/types.rs:134:10
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub enum Basic {
[INFO] [stdout]     |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Basic` is never used
[INFO] [stdout]   --> src/effect.rs:26:10
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub enum Basic {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Shape` is never used
[INFO] [stdout]  --> src/body.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub enum Shape {
[INFO] [stdout]   |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Body` is never constructed
[INFO] [stdout]   --> src/body.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct Body {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `random_type` and `random` are never used
[INFO] [stdout]   --> src/random.rs:4:8
[INFO] [stdout]    |
[INFO] [stdout]  2 | pub trait Random {
[INFO] [stdout]    |           ------ methods in this trait
[INFO] [stdout]  3 |     type Type;
[INFO] [stdout]  4 |     fn random_type(&self) -> Self::Type;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 10 |     fn random(&self, min:f64, max:f64) -> f64 {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Basic` is never used
[INFO] [stdout]    --> src/special.rs:199:10
[INFO] [stdout]     |
[INFO] [stdout] 199 | pub enum Basic {
[INFO] [stdout]     |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Advanced` is never used
[INFO] [stdout]    --> src/special.rs:454:10
[INFO] [stdout]     |
[INFO] [stdout] 454 | pub enum Advanced {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/body.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 37 | impl Body {
[INFO] [stdout]    | --------- associated function in this implementation
[INFO] [stdout] 38 |     pub fn new()-> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_0max` is never used
[INFO] [stdout]   --> src/random.rs:51:8
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub fn random_0max(value:u32) -> u32 {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_character_name` is never used
[INFO] [stdout]   --> src/random.rs:56:8
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub fn random_character_name() ->String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_creature_name` is never used
[INFO] [stdout]   --> src/random.rs:85:8
[INFO] [stdout]    |
[INFO] [stdout] 85 | pub fn random_creature_name() -> String {
[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] [stdout] warning: enum `Advanced` is never used
[INFO] [stdout]    --> src/effect.rs:175:10
[INFO] [stdout]     |
[INFO] [stdout] 175 | pub enum Advanced {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `tp_cost` and `tp_total` are never used
[INFO] [stdout]    --> src/special.rs:508:8
[INFO] [stdout]     |
[INFO] [stdout] 490 | pub trait SpecialMove <T:Copy 
[INFO] [stdout]     |           ----------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 508 |     fn tp_cost(&self, input:T) -> T {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 511 |     fn tp_total(&self, input:T) -> T{
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Basic` is never used
[INFO] [stdout]   --> src/item.rs:49:10
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub enum Basic {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Advanced` is never used
[INFO] [stdout]    --> src/item.rs:369:10
[INFO] [stdout]     |
[INFO] [stdout] 369 | pub enum Advanced {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Builder` is never used
[INFO] [stdout]    --> src/stats.rs:283:11
[INFO] [stdout]     |
[INFO] [stdout] 283 | pub trait Builder <T:Copy
[INFO] [stdout]     |           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `BasicPremade` is never used
[INFO] [stdout]    --> src/stats.rs:311:11
[INFO] [stdout]     |
[INFO] [stdout] 311 | pub trait BasicPremade<T:Copy
[INFO] [stdout]     |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `NormalPremade` is never used
[INFO] [stdout]    --> src/stats.rs:557:11
[INFO] [stdout]     |
[INFO] [stdout] 557 | pub trait NormalPremade<T:Copy
[INFO] [stdout]     |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `AdvancedPremade` is never used
[INFO] [stdout]    --> src/stats.rs:869:11
[INFO] [stdout]     |
[INFO] [stdout] 869 | pub trait AdvancedPremade<T:Copy
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]     --> src/stats.rs:1399:8
[INFO] [stdout]      |
[INFO] [stdout] 1393 | pub trait Premade {
[INFO] [stdout]      |           ------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 1399 |     fn set_hp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1402 |     fn set_mp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1405 |     fn set_xp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1414 |     fn set_xp_next(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1417 |     fn set_gp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1439 |     fn id(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1443 |     fn hp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1447 |     fn mp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1475 |     fn gp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1510 |     fn add_xp(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1530 |     fn damage(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1540 |     fn heal(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1551 |     fn attack_stable(&self, other:Stats) -> f64 { 
[INFO] [stdout]      |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1560 |     fn attack(&self, other:Stats) -> f64 {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1567 |     fn buy(&mut self, price:f64) -> bool {
[INFO] [stdout]      |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 1575 |     fn earn(&mut self, price:f64) {
[INFO] [stdout]      |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 23.24s
[INFO] running `Command { std: "docker" "inspect" "fe46cc662ec0fae775b27533d9a0bede4aaa1452e73310d704cd1ccfeff6c848", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fe46cc662ec0fae775b27533d9a0bede4aaa1452e73310d704cd1ccfeff6c848", kill_on_drop: false }`
[INFO] [stdout] fe46cc662ec0fae775b27533d9a0bede4aaa1452e73310d704cd1ccfeff6c848
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7e3c93582e4eafea89aa460f7da76bfae4803357615736f1bff10c6ef29d0b4a
[INFO] running `Command { std: "docker" "start" "-a" "7e3c93582e4eafea89aa460f7da76bfae4803357615736f1bff10c6ef29d0b4a", kill_on_drop: false }`
[INFO] [stdout] warning: unused import: `crate::stats::Stats`
[INFO] [stdout]   --> src/chemistry.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::stats::Stats;
[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: `crate::stats::Builder`
[INFO] [stdout]   --> src/chemistry.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use crate::stats::Builder;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:116:13
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:172:13
[INFO] [stdout]     |
[INFO] [stdout] 172 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:242:13
[INFO] [stdout]     |
[INFO] [stdout] 242 |         let mut mp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hp` is never read
[INFO] [stdout]    --> src/armor.rs:626:17
[INFO] [stdout]     |
[INFO] [stdout] 626 |         let mut hp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `mp` is never read
[INFO] [stdout]    --> src/armor.rs:627:17
[INFO] [stdout]     |
[INFO] [stdout] 627 |         let mut mp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `xp` is never read
[INFO] [stdout]    --> src/armor.rs:628:17
[INFO] [stdout]     |
[INFO] [stdout] 628 |         let mut xp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `speed` is never read
[INFO] [stdout]    --> src/armor.rs:631:17
[INFO] [stdout]     |
[INFO] [stdout] 631 |         let mut speed:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:630:13
[INFO] [stdout]     |
[INFO] [stdout] 630 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hp` is never read
[INFO] [stdout]    --> src/armor.rs:658:17
[INFO] [stdout]     |
[INFO] [stdout] 658 |         let mut hp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `xp` is never read
[INFO] [stdout]    --> src/armor.rs:660:17
[INFO] [stdout]     |
[INFO] [stdout] 660 |         let mut xp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `speed` is never read
[INFO] [stdout]    --> src/armor.rs:663:17
[INFO] [stdout]     |
[INFO] [stdout] 663 |         let mut speed:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `atk` is never read
[INFO] [stdout]    --> src/armor.rs:664:17
[INFO] [stdout]     |
[INFO] [stdout] 664 |         let mut atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `def` is never read
[INFO] [stdout]    --> src/armor.rs:665:17
[INFO] [stdout]     |
[INFO] [stdout] 665 |         let mut def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_atk` is never read
[INFO] [stdout]    --> src/armor.rs:666:17
[INFO] [stdout]     |
[INFO] [stdout] 666 |         let mut m_atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_def` is never read
[INFO] [stdout]    --> src/armor.rs:667:17
[INFO] [stdout]     |
[INFO] [stdout] 667 |         let mut m_def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:662:13
[INFO] [stdout]     |
[INFO] [stdout] 662 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hp` is never read
[INFO] [stdout]    --> src/armor.rs:700:17
[INFO] [stdout]     |
[INFO] [stdout] 700 |         let mut hp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `xp` is never read
[INFO] [stdout]    --> src/armor.rs:702:17
[INFO] [stdout]     |
[INFO] [stdout] 702 |         let mut xp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `speed` is never read
[INFO] [stdout]    --> src/armor.rs:705:17
[INFO] [stdout]     |
[INFO] [stdout] 705 |         let mut speed:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `atk` is never read
[INFO] [stdout]    --> src/armor.rs:706:17
[INFO] [stdout]     |
[INFO] [stdout] 706 |         let mut atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `def` is never read
[INFO] [stdout]    --> src/armor.rs:707:17
[INFO] [stdout]     |
[INFO] [stdout] 707 |         let mut def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_atk` is never read
[INFO] [stdout]    --> src/armor.rs:708:17
[INFO] [stdout]     |
[INFO] [stdout] 708 |         let mut m_atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling rpg-stat v2021.12.16 (/opt/rustwide/workdir)
[INFO] [stdout] warning: value assigned to `m_def` is never read
[INFO] [stdout]    --> src/armor.rs:709:17
[INFO] [stdout]     |
[INFO] [stdout] 709 |         let mut m_def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `agility` is never read
[INFO] [stdout]    --> src/armor.rs:710:17
[INFO] [stdout]     |
[INFO] [stdout] 710 |         let mut agility:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `strength` is never read
[INFO] [stdout]    --> src/armor.rs:711:17
[INFO] [stdout]     |
[INFO] [stdout] 711 |         let mut strength:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `dexterity` is never read
[INFO] [stdout]    --> src/armor.rs:712:17
[INFO] [stdout]     |
[INFO] [stdout] 712 |         let mut dexterity:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `constitution` is never read
[INFO] [stdout]    --> src/armor.rs:713:17
[INFO] [stdout]     |
[INFO] [stdout] 713 |         let mut constitution:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `charisma` is never read
[INFO] [stdout]    --> src/armor.rs:715:17
[INFO] [stdout]     |
[INFO] [stdout] 715 |         let mut charisma:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:701:13
[INFO] [stdout]     |
[INFO] [stdout] 701 |         let mut mp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::stats::Stats`
[INFO] [stdout]   --> src/chemistry.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::stats::Stats;
[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: `crate::stats::Builder`
[INFO] [stdout]   --> src/chemistry.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use crate::stats::Builder;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Basic` is never used
[INFO] [stdout]    --> src/types.rs:134:10
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub enum Basic {
[INFO] [stdout]     |          ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Functions` is never used
[INFO] [stdout]    --> src/stats.rs:258:11
[INFO] [stdout]     |
[INFO] [stdout] 258 | pub trait Functions <T:Copy
[INFO] [stdout]     |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `build_normal` and `build_advanced` are never used
[INFO] [stdout]    --> src/stats.rs:302:8
[INFO] [stdout]     |
[INFO] [stdout] 283 | pub trait Builder <T:Copy
[INFO] [stdout]     |           ------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 302 |     fn build_normal(&self, id:T, level:T) -> Normal<T>;
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 303 |     // Build an `Advanced` stat
[INFO] [stdout] 304 |     fn build_advanced(&self, id:T, level:T) -> Advanced<T>;
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `EquationalEnemy` is never constructed
[INFO] [stdout]   --> src/tests.rs:66:16
[INFO] [stdout]    |
[INFO] [stdout] 66 |     pub struct EquationalEnemy {
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/stats.rs:335:8
[INFO] [stdout]     |
[INFO] [stdout] 311 | pub trait BasicPremade<T:Copy
[INFO] [stdout]     |           ------------ methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 335 |     fn set_mp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 338 |     fn set_xp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 341 |     fn set_hp_max(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 344 |     fn set_mp_max(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 347 |     fn set_xp_next(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 350 |     fn set_gp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 354 |     fn id(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 362 |     fn mp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 366 |     fn xp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 374 |     fn mp_max(&self) -> T {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 378 |     fn xp_next(&self) -> T {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 382 |     fn level(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 386 |     fn speed(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 390 |     fn gp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Shape` is never used
[INFO] [stdout]  --> src/body.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub enum Shape {
[INFO] [stdout]   |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/stats.rs:581:8
[INFO] [stdout]     |
[INFO] [stdout] 557 | pub trait NormalPremade<T:Copy
[INFO] [stdout]     |           ------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 581 |     fn set_mp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     fn set_xp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 587 |     fn set_hp_max(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 590 |     fn set_mp_max(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 593 |     fn set_xp_next(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 596 |     fn set_gp(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 602 |     fn set_def(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 605 |     fn set_m_atk(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 608 |     fn set_m_def(&mut self, amount:T);
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 612 |     fn id(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 620 |     fn mp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 624 |     fn xp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 628 |     fn hp_max(&self) -> T {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 632 |     fn mp_max(&self) -> T {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 636 |     fn xp_next(&self) -> T {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 640 |     fn level(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 644 |     fn speed(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 648 |     fn gp(&self) -> T {
[INFO] [stdout]     |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 656 |     fn def(&self) -> T {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 660 |     fn m_atk(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 664 |     fn m_def(&self) -> T {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 669 |     fn damage(&mut self, amount:T) {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 679 |     fn heal(&mut self, amount:T) {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 690 |     fn attack_stable(&self, other:Normal<T>) -> T { 
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 699 |     fn attack(&self, other:Normal<T>) -> T {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Body` is never constructed
[INFO] [stdout]   --> src/body.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct Body {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/body.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 37 | impl Body {
[INFO] [stdout]    | --------- associated function in this implementation
[INFO] [stdout] 38 |     pub fn new()-> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Basic` is never used
[INFO] [stdout]   --> src/effect.rs:26:10
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub enum Basic {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Advanced` is never used
[INFO] [stdout]    --> src/effect.rs:175:10
[INFO] [stdout]     |
[INFO] [stdout] 175 | pub enum Advanced {
[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] [stdout] warning: enum `Basic` is never used
[INFO] [stdout]   --> src/item.rs:49:10
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub enum Basic {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Advanced` is never used
[INFO] [stdout]    --> src/item.rs:369:10
[INFO] [stdout]     |
[INFO] [stdout] 369 | pub enum Advanced {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Basic` is never used
[INFO] [stdout]    --> src/special.rs:199:10
[INFO] [stdout]     |
[INFO] [stdout] 199 | pub enum Basic {
[INFO] [stdout]     |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Advanced` is never used
[INFO] [stdout]    --> src/special.rs:454:10
[INFO] [stdout]     |
[INFO] [stdout] 454 | pub enum Advanced {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `tp_cost` and `tp_total` are never used
[INFO] [stdout]    --> src/special.rs:508:8
[INFO] [stdout]     |
[INFO] [stdout] 490 | pub trait SpecialMove <T:Copy 
[INFO] [stdout]     |           ----------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 508 |     fn tp_cost(&self, input:T) -> T {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 511 |     fn tp_total(&self, input:T) -> T{
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Advanced` is never used
[INFO] [stdout]    --> src/class.rs:851:10
[INFO] [stdout]     |
[INFO] [stdout] 851 | pub enum Advanced {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `random_type` and `random` are never used
[INFO] [stdout]   --> src/random.rs:4:8
[INFO] [stdout]    |
[INFO] [stdout]  2 | pub trait Random {
[INFO] [stdout]    |           ------ methods in this trait
[INFO] [stdout]  3 |     type Type;
[INFO] [stdout]  4 |     fn random_type(&self) -> Self::Type;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 10 |     fn random(&self, min:f64, max:f64) -> f64 {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_0max` is never used
[INFO] [stdout]   --> src/random.rs:51:8
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub fn random_0max(value:u32) -> u32 {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_character_name` is never used
[INFO] [stdout]   --> src/random.rs:56:8
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub fn random_character_name() ->String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_creature_name` is never used
[INFO] [stdout]   --> src/random.rs:85:8
[INFO] [stdout]    |
[INFO] [stdout] 85 | pub fn random_creature_name() -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `AdvancedPremade` is never used
[INFO] [stdout]    --> src/stats.rs:869:11
[INFO] [stdout]     |
[INFO] [stdout] 869 | pub trait AdvancedPremade<T:Copy
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]     --> src/stats.rs:1399:8
[INFO] [stdout]      |
[INFO] [stdout] 1393 | pub trait Premade {
[INFO] [stdout]      |           ------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 1399 |     fn set_hp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1402 |     fn set_mp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1405 |     fn set_xp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1414 |     fn set_xp_next(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1417 |     fn set_gp(&mut self, amount:f64);
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1439 |     fn id(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1443 |     fn hp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1447 |     fn mp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1475 |     fn gp(&self) -> f64 {
[INFO] [stdout]      |        ^^
[INFO] [stdout] ...
[INFO] [stdout] 1510 |     fn add_xp(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1530 |     fn damage(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1540 |     fn heal(&mut self, amount:f64) {
[INFO] [stdout]      |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1551 |     fn attack_stable(&self, other:Stats) -> f64 { 
[INFO] [stdout]      |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1560 |     fn attack(&self, other:Stats) -> f64 {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1567 |     fn buy(&mut self, price:f64) -> bool {
[INFO] [stdout]      |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 1575 |     fn earn(&mut self, price:f64) {
[INFO] [stdout]      |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:116:13
[INFO] [stdout]     |
[INFO] [stdout] 116 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:172:13
[INFO] [stdout]     |
[INFO] [stdout] 172 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:242:13
[INFO] [stdout]     |
[INFO] [stdout] 242 |         let mut mp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hp` is never read
[INFO] [stdout]    --> src/armor.rs:626:17
[INFO] [stdout]     |
[INFO] [stdout] 626 |         let mut hp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `mp` is never read
[INFO] [stdout]    --> src/armor.rs:627:17
[INFO] [stdout]     |
[INFO] [stdout] 627 |         let mut mp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `xp` is never read
[INFO] [stdout]    --> src/armor.rs:628:17
[INFO] [stdout]     |
[INFO] [stdout] 628 |         let mut xp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `speed` is never read
[INFO] [stdout]    --> src/armor.rs:631:17
[INFO] [stdout]     |
[INFO] [stdout] 631 |         let mut speed:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:630:13
[INFO] [stdout]     |
[INFO] [stdout] 630 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hp` is never read
[INFO] [stdout]    --> src/armor.rs:658:17
[INFO] [stdout]     |
[INFO] [stdout] 658 |         let mut hp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `xp` is never read
[INFO] [stdout]    --> src/armor.rs:660:17
[INFO] [stdout]     |
[INFO] [stdout] 660 |         let mut xp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `speed` is never read
[INFO] [stdout]    --> src/armor.rs:663:17
[INFO] [stdout]     |
[INFO] [stdout] 663 |         let mut speed:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `atk` is never read
[INFO] [stdout]    --> src/armor.rs:664:17
[INFO] [stdout]     |
[INFO] [stdout] 664 |         let mut atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `def` is never read
[INFO] [stdout]    --> src/armor.rs:665:17
[INFO] [stdout]     |
[INFO] [stdout] 665 |         let mut def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_atk` is never read
[INFO] [stdout]    --> src/armor.rs:666:17
[INFO] [stdout]     |
[INFO] [stdout] 666 |         let mut m_atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_def` is never read
[INFO] [stdout]    --> src/armor.rs:667:17
[INFO] [stdout]     |
[INFO] [stdout] 667 |         let mut m_def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:662:13
[INFO] [stdout]     |
[INFO] [stdout] 662 |         let mut gp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hp` is never read
[INFO] [stdout]    --> src/armor.rs:700:17
[INFO] [stdout]     |
[INFO] [stdout] 700 |         let mut hp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `xp` is never read
[INFO] [stdout]    --> src/armor.rs:702:17
[INFO] [stdout]     |
[INFO] [stdout] 702 |         let mut xp:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `speed` is never read
[INFO] [stdout]    --> src/armor.rs:705:17
[INFO] [stdout]     |
[INFO] [stdout] 705 |         let mut speed:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `atk` is never read
[INFO] [stdout]    --> src/armor.rs:706:17
[INFO] [stdout]     |
[INFO] [stdout] 706 |         let mut atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `def` is never read
[INFO] [stdout]    --> src/armor.rs:707:17
[INFO] [stdout]     |
[INFO] [stdout] 707 |         let mut def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_atk` is never read
[INFO] [stdout]    --> src/armor.rs:708:17
[INFO] [stdout]     |
[INFO] [stdout] 708 |         let mut m_atk:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `m_def` is never read
[INFO] [stdout]    --> src/armor.rs:709:17
[INFO] [stdout]     |
[INFO] [stdout] 709 |         let mut m_def:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `agility` is never read
[INFO] [stdout]    --> src/armor.rs:710:17
[INFO] [stdout]     |
[INFO] [stdout] 710 |         let mut agility:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `strength` is never read
[INFO] [stdout]    --> src/armor.rs:711:17
[INFO] [stdout]     |
[INFO] [stdout] 711 |         let mut strength:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `dexterity` is never read
[INFO] [stdout]    --> src/armor.rs:712:17
[INFO] [stdout]     |
[INFO] [stdout] 712 |         let mut dexterity:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `constitution` is never read
[INFO] [stdout]    --> src/armor.rs:713:17
[INFO] [stdout]     |
[INFO] [stdout] 713 |         let mut constitution:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `charisma` is never read
[INFO] [stdout]    --> src/armor.rs:715:17
[INFO] [stdout]     |
[INFO] [stdout] 715 |         let mut charisma:T = num::cast(0).unwrap();
[INFO] [stdout]     |                 ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/armor.rs:701:13
[INFO] [stdout]     |
[INFO] [stdout] 701 |         let mut mp:T = num::cast(0).unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 3.94s
[INFO] running `Command { std: "docker" "inspect" "7e3c93582e4eafea89aa460f7da76bfae4803357615736f1bff10c6ef29d0b4a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7e3c93582e4eafea89aa460f7da76bfae4803357615736f1bff10c6ef29d0b4a", kill_on_drop: false }`
[INFO] [stdout] 7e3c93582e4eafea89aa460f7da76bfae4803357615736f1bff10c6ef29d0b4a
