[INFO] cloning repository https://github.com/dgoetsch/dnd-character
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/dgoetsch/dnd-character" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdgoetsch%2Fdnd-character", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdgoetsch%2Fdnd-character'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 6d7a927507b46b25384b1baa4dea4c2cc3019c79
[INFO] testing dgoetsch/dnd-character against beta-2026-03-05 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdgoetsch%2Fdnd-character" "/workspace/builds/worker-0-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/dgoetsch/dnd-character
[INFO] finished tweaking git repo https://github.com/dgoetsch/dnd-character
[INFO] tweaked toml for git repo https://github.com/dgoetsch/dnd-character written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/dgoetsch/dnd-character on toolchain beta-2026-03-05
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/dgoetsch/dnd-character 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" "+beta-2026-03-05" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 66811d813781ff7f858c36a92443dc2353ef22cf95107ef2974b2164cd21246d
[INFO] running `Command { std: "docker" "start" "-a" "66811d813781ff7f858c36a92443dc2353ef22cf95107ef2974b2164cd21246d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "66811d813781ff7f858c36a92443dc2353ef22cf95107ef2974b2164cd21246d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "66811d813781ff7f858c36a92443dc2353ef22cf95107ef2974b2164cd21246d", kill_on_drop: false }`
[INFO] [stdout] 66811d813781ff7f858c36a92443dc2353ef22cf95107ef2974b2164cd21246d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-03-05" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] ce5506734972da7283de7d099513b77bda511c8748b89c7a27fe8333874e508a
[INFO] running `Command { std: "docker" "start" "-a" "ce5506734972da7283de7d099513b77bda511c8748b89c7a27fe8333874e508a", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.81
[INFO] [stderr]    Compiling proc-macro2 v1.0.24
[INFO] [stderr]    Compiling log v0.4.11
[INFO] [stderr]    Compiling pkg-config v0.3.19
[INFO] [stderr]    Compiling autocfg v1.0.1
[INFO] [stderr]    Compiling syn v1.0.56
[INFO] [stderr]    Compiling once_cell v1.5.2
[INFO] [stderr]    Compiling memchr v2.3.4
[INFO] [stderr]    Compiling xml-rs v0.8.3
[INFO] [stderr]    Compiling libloading v0.6.6
[INFO] [stderr]    Compiling num-traits v0.2.14
[INFO] [stderr]    Compiling smallvec v1.5.1
[INFO] [stderr]    Compiling futures-core v0.3.8
[INFO] [stderr]    Compiling slab v0.4.2
[INFO] [stderr]    Compiling version_check v0.9.2
[INFO] [stderr]    Compiling ab_glyph_rasterizer v0.1.4
[INFO] [stderr]    Compiling futures-io v0.3.8
[INFO] [stderr]    Compiling nix v0.18.0
[INFO] [stderr]    Compiling wayland-sys v0.28.2
[INFO] [stderr]    Compiling quote v1.0.8
[INFO] [stderr]    Compiling proc-macro-hack v0.5.19
[INFO] [stderr]    Compiling getrandom v0.1.15
[INFO] [stderr]    Compiling dlib v0.4.2
[INFO] [stderr]    Compiling crossbeam-utils v0.8.1
[INFO] [stderr]    Compiling wayland-scanner v0.28.2
[INFO] [stderr]    Compiling proc-macro-nested v0.1.6
[INFO] [stderr]    Compiling walkdir v2.3.1
[INFO] [stderr]    Compiling futures-sink v0.3.8
[INFO] [stderr]    Compiling futures-channel v0.3.8
[INFO] [stderr]    Compiling num_cpus v1.13.0
[INFO] [stderr]    Compiling jobserver v0.1.21
[INFO] [stderr]    Compiling raw-window-handle v0.3.3
[INFO] [stderr]    Compiling nom v6.0.1
[INFO] [stderr]    Compiling memoffset v0.6.1
[INFO] [stderr]    Compiling rand_core v0.5.1
[INFO] [stderr]    Compiling futures-task v0.3.8
[INFO] [stderr]    Compiling cc v1.0.66
[INFO] [stderr]    Compiling const_fn v0.4.4
[INFO] [stderr]    Compiling ppv-lite86 v0.2.10
[INFO] [stderr]    Compiling scoped-tls v1.0.0
[INFO] [stderr]    Compiling semver-parser v0.7.0
[INFO] [stderr]    Compiling downcast-rs v1.2.0
[INFO] [stderr]    Compiling cmake v0.1.45
[INFO] [stderr]    Compiling pin-project-lite v0.2.0
[INFO] [stderr]    Compiling semver v0.9.0
[INFO] [stderr]    Compiling ttf-parser v0.6.2
[INFO] [stderr]    Compiling rand_chacha v0.2.2
[INFO] [stderr]    Compiling rustc_version v0.2.3
[INFO] [stderr]    Compiling wayland-client v0.28.2
[INFO] [stderr]    Compiling servo-freetype-sys v4.0.5
[INFO] [stderr]    Compiling expat-sys v2.1.6
[INFO] [stderr]    Compiling rand v0.7.3
[INFO] [stderr]    Compiling wayland-protocols v0.28.2
[INFO] [stderr]    Compiling owned_ttf_parser v0.6.0
[INFO] [stderr]    Compiling instant v0.1.9
[INFO] [stderr]    Compiling rayon-core v1.9.0
[INFO] [stderr]    Compiling parking_lot_core v0.8.2
[INFO] [stderr]    Compiling rusttype v0.9.2
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.1
[INFO] [stderr]    Compiling twox-hash v1.6.0
[INFO] [stderr]    Compiling pathfinder_simd v0.5.0
[INFO] [stderr]    Compiling lock_api v0.4.2
[INFO] [stderr]    Compiling servo-fontconfig-sys v4.0.9
[INFO] [stderr]    Compiling ttf-parser v0.9.0
[INFO] [stderr]    Compiling xdg v2.2.0
[INFO] [stderr]    Compiling parking_lot v0.11.1
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]    Compiling xcursor v0.3.3
[INFO] [stderr]    Compiling andrew v0.3.1
[INFO] [stderr]    Compiling wayland-commons v0.28.2
[INFO] [stderr]    Compiling calloop v0.6.5
[INFO] [stderr]    Compiling crossbeam-deque v0.8.0
[INFO] [stderr]    Compiling gfx-hal v0.6.0
[INFO] [stderr]    Compiling crossbeam-channel v0.5.0
[INFO] [stderr]    Compiling owned_ttf_parser v0.9.0
[INFO] [stderr]    Compiling memmap2 v0.1.0
[INFO] [stderr]    Compiling rayon v1.5.0
[INFO] [stderr]    Compiling ab_glyph v0.2.7
[INFO] [stderr]    Compiling dirs-sys v0.3.5
[INFO] [stderr]    Compiling glam v0.10.2
[INFO] [stderr]    Compiling x11-dl v2.18.5
[INFO] [stderr]    Compiling x11 v2.18.2
[INFO] [stderr]    Compiling fxhash v0.2.1
[INFO] [stderr]    Compiling iced_core v0.3.0
[INFO] [stderr]    Compiling wayland-cursor v0.28.2
[INFO] [stderr]    Compiling pathfinder_geometry v0.5.1
[INFO] [stderr]    Compiling dirs v2.0.2
[INFO] [stderr]    Compiling servo-fontconfig v0.4.0
[INFO] [stderr]    Compiling freetype v0.4.1
[INFO] [stderr]    Compiling xcb v0.9.0
[INFO] [stderr]    Compiling approx v0.4.0
[INFO] [stderr]    Compiling net2 v0.2.37
[INFO] [stderr]    Compiling iovec v0.1.4
[INFO] [stderr]    Compiling cache-padded v1.1.1
[INFO] [stderr]    Compiling unicode-segmentation v1.7.1
[INFO] [stderr]    Compiling linked-hash-map v0.5.3
[INFO] [stderr]    Compiling float-ord v0.2.0
[INFO] [stderr]    Compiling bit-vec v0.6.3
[INFO] [stderr]    Compiling arrayvec v0.5.2
[INFO] [stderr]    Compiling xi-unicode v0.3.0
[INFO] [stderr]    Compiling bit-set v0.5.2
[INFO] [stderr]    Compiling font-kit v0.8.0
[INFO] [stderr]    Compiling glyph_brush_layout v0.2.1
[INFO] [stderr]    Compiling concurrent-queue v1.2.2
[INFO] [stderr]    Compiling mio v0.6.23
[INFO] [stderr]    Compiling pin-project-internal v1.0.2
[INFO] [stderr]    Compiling futures-macro v0.3.8
[INFO] [stderr]    Compiling thiserror-impl v1.0.23
[INFO] [stderr]    Compiling bytemuck_derive v1.0.1
[INFO] [stderr]    Compiling pin-project v1.0.2
[INFO] [stderr]    Compiling futures-util v0.3.8
[INFO] [stderr]    Compiling bytemuck v1.4.1
[INFO] [stderr]    Compiling glyph_brush_draw_cache v0.1.3
[INFO] [stderr]    Compiling thiserror v1.0.23
[INFO] [stderr]    Compiling iced_style v0.2.0
[INFO] [stderr]    Compiling spirv_headers v1.5.0
[INFO] [stderr]    Compiling ordered-float v2.0.1
[INFO] [stderr]    Compiling ash v0.31.0
[INFO] [stderr]    Compiling tracing-core v0.1.17
[INFO] [stderr]    Compiling lazycell v1.3.0
[INFO] [stderr]    Compiling inplace_it v0.3.2
[INFO] [stderr]    Compiling winit v0.23.0
[INFO] [stderr]    Compiling parking v2.0.0
[INFO] [stderr]    Compiling waker-fn v1.1.0
[INFO] [stderr]    Compiling fastrand v1.4.0
[INFO] [stderr]    Compiling tracing v0.1.22
[INFO] [stderr]    Compiling mio-extras v2.0.6
[INFO] [stderr]    Compiling futures-lite v1.11.3
[INFO] [stderr]    Compiling naga v0.2.0
[INFO] [stderr]    Compiling glyph_brush v0.7.1
[INFO] [stderr]    Compiling gfx-descriptor v0.2.0
[INFO] [stderr]    Compiling gfx-memory v0.2.2
[INFO] [stderr]    Compiling gfx-backend-empty v0.6.0
[INFO] [stderr]    Compiling synstructure v0.12.4
[INFO] [stderr]    Compiling glutin_glx_sys v0.1.7
[INFO] [stderr]    Compiling glutin_egl_sys v0.1.5
[INFO] [stderr]    Compiling futures-executor v0.3.8
[INFO] [stderr]    Compiling futures v0.3.8
[INFO] [stderr]    Compiling iced_futures v0.2.0
[INFO] [stderr]    Compiling wgpu-types v0.6.1
[INFO] [stderr]    Compiling iced_native v0.3.0
[INFO] [stderr]    Compiling percent-encoding v2.1.0
[INFO] [stderr]    Compiling copyless v0.1.5
[INFO] [stderr]    Compiling zerocopy-derive v0.2.0
[INFO] [stderr]    Compiling euclid v0.22.1
[INFO] [stderr]    Compiling shared_library v0.1.9
[INFO] [stderr]    Compiling serde_derive v1.0.118
[INFO] [stderr]    Compiling async-task v4.0.3
[INFO] [stderr]    Compiling vec-arena v1.0.0
[INFO] [stderr]    Compiling typed-arena v2.0.1
[INFO] [stderr]    Compiling event-listener v2.5.1
[INFO] [stderr]    Compiling zerocopy v0.3.0
[INFO] [stderr]    Compiling osmesa-sys v0.1.2
[INFO] [stderr]    Compiling iced_graphics v0.1.0
[INFO] [stderr]    Compiling wayland-egl v0.28.2
[INFO] [stderr]    Compiling polling v2.0.2
[INFO] [stderr]    Compiling nb-connect v1.0.2
[INFO] [stderr]    Compiling serde v1.0.118
[INFO] [stderr]    Compiling glow v0.6.1
[INFO] [stderr]    Compiling svg_fmt v0.4.1
[INFO] [stderr]    Compiling ryu v1.0.5
[INFO] [stderr]    Compiling async-io v1.3.1
[INFO] [stderr]    Compiling async-channel v1.5.1
[INFO] [stderr]    Compiling guillotiere v0.6.0
[INFO] [stderr]    Compiling async-executor v1.4.0
[INFO] [stderr]    Compiling atomic-waker v1.0.0
[INFO] [stderr]    Compiling serde_json v1.0.61
[INFO] [stderr]    Compiling blocking v1.0.2
[INFO] [stderr]    Compiling async-global-executor v1.4.3
[INFO] [stderr]    Compiling async-mutex v1.4.0
[INFO] [stderr]    Compiling kv-log-macro v1.0.7
[INFO] [stderr]    Compiling itoa v0.4.7
[INFO] [stderr]    Compiling async-std v1.8.0
[INFO] [stderr]    Compiling glow_glyph v0.4.0
[INFO] [stderr]    Compiling iced_glow v0.1.0
[INFO] [stderr]    Compiling gfx-backend-vulkan v0.6.5
[INFO] [stderr]    Compiling clipboard_x11 v0.1.0
[INFO] [stderr]    Compiling wgpu-core v0.6.5
[INFO] [stderr]    Compiling wgpu v0.6.2
[INFO] [stderr]    Compiling wgpu_glyph v0.10.0
[INFO] [stderr]    Compiling iced_wgpu v0.3.0
[INFO] [stderr]    Compiling smithay-client-toolkit v0.12.1
[INFO] [stderr]    Compiling smithay-clipboard v0.6.2
[INFO] [stderr]    Compiling clipboard_wayland v0.1.2
[INFO] [stderr]    Compiling window_clipboard v0.1.3
[INFO] [stderr]    Compiling glutin v0.25.1
[INFO] [stderr]    Compiling iced_winit v0.2.0
[INFO] [stderr]    Compiling iced_glutin v0.1.0
[INFO] [stderr]    Compiling iced v0.2.0
[INFO] [stderr]    Compiling dnd-character v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/character/class.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 |         if (self.classes.len() > 1) {
[INFO] [stdout]    |            ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 24 -         if (self.classes.len() > 1) {
[INFO] [stdout] 24 +         if self.classes.len() > 1  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Element`, `HorizontalAlignment`, and `VerticalAlignment`
[INFO] [stdout]  --> src/character/description.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use iced::{Column, Element, HorizontalAlignment, Length, Row, Text, VerticalAlignment};
[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: `FeatureState`
[INFO] [stdout]  --> src/character/persistence.rs:8:37
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::core::feature::{Feature, FeatureState, FeaturesState};
[INFO] [stdout]   |                                     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/character/proficiencies.rs:76:23
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let text = if (proficiencies.is_empty()) {
[INFO] [stdout]    |                       ^                        ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 76 -         let text = if (proficiencies.is_empty()) {
[INFO] [stdout] 76 +         let text = if proficiencies.is_empty()  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Dice` and `Roll`
[INFO] [stdout]  --> src/core/ability_score.rs:3:25
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::core::roll::{Dice, Roll};
[INFO] [stdout]   |                         ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::util::format_modifier`
[INFO] [stdout]  --> src/core/ability_score.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::util::format_modifier;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Element`
[INFO] [stdout]  --> src/core/ability_score.rs:5:20
[INFO] [stdout]   |
[INFO] [stdout] 5 | use iced::{Column, Element, HorizontalAlignment, Length, Row, Text, VerticalAlignment};
[INFO] [stdout]   |                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Dice`
[INFO] [stdout]  --> src/core/effect.rs:2:25
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::core::roll::{Dice, RollBonus, RollScope};
[INFO] [stdout]   |                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HorizontalAlignment`, `Length`, and `VerticalAlignment`
[INFO] [stdout]  --> src/core/effect.rs:4:29
[INFO] [stdout]   |
[INFO] [stdout] 4 | use iced::{Column, Element, HorizontalAlignment, Length, Row, Text, VerticalAlignment};
[INFO] [stdout]   |                             ^^^^^^^^^^^^^^^^^^^  ^^^^^^             ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EffectState`
[INFO] [stdout]  --> src/core/feature.rs:4:35
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::core::effect::{Effect, EffectState, EffectsState};
[INFO] [stdout]   |                                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RollScope`
[INFO] [stdout]  --> src/core/feature.rs:6:31
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::core::roll::{Roll, RollScope, RollState};
[INFO] [stdout]   |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Button` and `button`
[INFO] [stdout]  --> src/core/feature.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | use iced::{button, Button, Column, Element, Length, Row, Text};
[INFO] [stdout]   |            ^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde::export::Formatter`
[INFO] [stdout]   --> src/core/feature.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use serde::export::Formatter;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::borrow::Borrow`
[INFO] [stdout]   --> src/core/feature.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::borrow::Borrow;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Display`
[INFO] [stdout]   --> src/core/feature.rs:14:23
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::fmt::{Debug, Display};
[INFO] [stdout]    |                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/feature.rs:246:20
[INFO] [stdout]     |
[INFO] [stdout] 246 |                 if (matches) {
[INFO] [stdout]     |                    ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 246 -                 if (matches) {
[INFO] [stdout] 246 +                 if matches  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/feature.rs:383:16
[INFO] [stdout]     |
[INFO] [stdout] 383 |             if (!apply_to_children.is_empty()) {
[INFO] [stdout]     |                ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 383 -             if (!apply_to_children.is_empty()) {
[INFO] [stdout] 383 +             if !apply_to_children.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/feature.rs:509:12
[INFO] [stdout]     |
[INFO] [stdout] 509 |         if (!rolls_state.is_empty()) {
[INFO] [stdout]     |            ^                       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 509 -         if (!rolls_state.is_empty()) {
[INFO] [stdout] 509 +         if !rolls_state.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/core/feature_path.rs:40:20
[INFO] [stdout]    |
[INFO] [stdout] 40 |                 if (feature == head) {
[INFO] [stdout]    |                    ^               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 40 -                 if (feature == head) {
[INFO] [stdout] 40 +                 if feature == head  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Class`
[INFO] [stdout]  --> src/core/roll/mod.rs:1:31
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::character::class::{Class, Classes};
[INFO] [stdout]   |                               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ModifiedAbilityScores`
[INFO] [stdout]  --> src/core/roll/mod.rs:2:58
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::core::ability_score::{Ability, AbilityScores, ModifiedAbilityScores};
[INFO] [stdout]   |                                                          ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Element`
[INFO] [stdout]  --> src/core/roll/mod.rs:8:20
[INFO] [stdout]   |
[INFO] [stdout] 8 | use iced::{Column, Element, Length, Row, Text};
[INFO] [stdout]   |                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Roll`
[INFO] [stdout]  --> src/core/roll/rollable.rs:2:31
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::core::roll::{Dice, Roll};
[INFO] [stdout]   |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:212:20
[INFO] [stdout]     |
[INFO] [stdout] 212 |                 if (matches) {
[INFO] [stdout]     |                    ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 212 -                 if (matches) {
[INFO] [stdout] 212 +                 if matches  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:273:32
[INFO] [stdout]     |
[INFO] [stdout] 273 | ...                   if (prev.is_empty()) {
[INFO] [stdout]     |                          ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 273 -                             if (prev.is_empty()) {
[INFO] [stdout] 273 +                             if prev.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:286:16
[INFO] [stdout]     |
[INFO] [stdout] 286 |             if (prev.is_empty()) {
[INFO] [stdout]     |                ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 286 -             if (prev.is_empty()) {
[INFO] [stdout] 286 +             if prev.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:300:16
[INFO] [stdout]     |
[INFO] [stdout] 300 |             if (prev.is_empty()) {
[INFO] [stdout]     |                ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 300 -             if (prev.is_empty()) {
[INFO] [stdout] 300 +             if prev.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:311:20
[INFO] [stdout]     |
[INFO] [stdout] 311 |                 if (prev.is_empty()) {
[INFO] [stdout]     |                    ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 311 -                 if (prev.is_empty()) {
[INFO] [stdout] 311 +                 if prev.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:346:8
[INFO] [stdout]     |
[INFO] [stdout] 346 |     if (!external_bonuses.is_empty()) {
[INFO] [stdout]     |        ^                            ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 346 -     if (!external_bonuses.is_empty()) {
[INFO] [stdout] 346 +     if !external_bonuses.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:448:20
[INFO] [stdout]     |
[INFO] [stdout] 448 |                 if (is_matching) {
[INFO] [stdout]     |                    ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 448 -                 if (is_matching) {
[INFO] [stdout] 448 +                 if is_matching  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::core::feature_path::FeaturePath`
[INFO] [stdout]  --> src/core/slot.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::core::feature_path::FeaturePath;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Element` and `Length`
[INFO] [stdout]  --> src/core/slot.rs:2:36
[INFO] [stdout]   |
[INFO] [stdout] 2 | use iced::{button, Button, Column, Element, Length, Row, Text};
[INFO] [stdout]   |                                    ^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/core/slot.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 |         if (slot.max == Some(slot.current)) {
[INFO] [stdout]    |            ^                              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 51 -         if (slot.max == Some(slot.current)) {
[INFO] [stdout] 51 +         if slot.max == Some(slot.current)  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `iced::futures::StreamExt`
[INFO] [stdout]  --> src/core/feature.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use iced::futures::StreamExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `FromSlotCommand`
[INFO] [stdout]  --> src/core/feature.rs:7:25
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::core::slot::{FromSlotCommand, Slot, SlotCommand, SlotState};
[INFO] [stdout]   |                         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/character/description.rs:86:13
[INFO] [stdout]    |
[INFO] [stdout] 86 |         let mut column_1 = Column::new()
[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: unused variable: `state`
[INFO] [stdout]   --> src/character/mod.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |             Character::Loaded(state) => "Character".to_string(),
[INFO] [stdout]    |                               ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/character/mod.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |                         let mut active_effects = state.features.effects();
[INFO] [stdout]     |                             ----^^^^^^^^^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/character/mod.rs:148:17
[INFO] [stdout]     |
[INFO] [stdout] 148 |                 config,
[INFO] [stdout]     |                 ^^^^^^ help: try ignoring the field: `config: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]    --> src/character/mod.rs:149:17
[INFO] [stdout]     |
[INFO] [stdout] 149 |                 resources,
[INFO] [stdout]     |                 ^^^^^^^^^ help: try ignoring the field: `resources: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `saving`
[INFO] [stdout]    --> src/character/mod.rs:157:17
[INFO] [stdout]     |
[INFO] [stdout] 157 |                 saving,
[INFO] [stdout]     |                 ^^^^^^ help: try ignoring the field: `saving: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dirty`
[INFO] [stdout]    --> src/character/mod.rs:158:17
[INFO] [stdout]     |
[INFO] [stdout] 158 |                 dirty,
[INFO] [stdout]     |                 ^^^^^ help: try ignoring the field: `dirty: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]    --> src/core/feature.rs:102:26
[INFO] [stdout]     |
[INFO] [stdout] 102 |                 .filter(|n| !name.is_empty())
[INFO] [stdout]     |                          ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `effects_state`
[INFO] [stdout]    --> src/core/feature.rs:264:13
[INFO] [stdout]     |
[INFO] [stdout] 264 |             effects_state,
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: try ignoring the field: `effects_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rolls_state`
[INFO] [stdout]    --> src/core/feature.rs:265:13
[INFO] [stdout]     |
[INFO] [stdout] 265 |             rolls_state,
[INFO] [stdout]     |             ^^^^^^^^^^^ help: try ignoring the field: `rolls_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `overlayed_feature`
[INFO] [stdout]    --> src/core/feature.rs:266:13
[INFO] [stdout]     |
[INFO] [stdout] 266 |             overlayed_feature,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `f`
[INFO] [stdout]    --> src/core/feature.rs:379:33
[INFO] [stdout]     |
[INFO] [stdout] 379 |                 .filter(|(path, f)| path.include_children())
[INFO] [stdout]     |                                 ^ help: if this is intentional, prefix it with an underscore: `_f`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `feature`
[INFO] [stdout]    --> src/core/feature.rs:385:21
[INFO] [stdout]     |
[INFO] [stdout] 385 |                     feature,
[INFO] [stdout]     |                     ^^^^^^^ help: try ignoring the field: `feature: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `overlayed_feature`
[INFO] [stdout]    --> src/core/feature.rs:386:21
[INFO] [stdout]     |
[INFO] [stdout] 386 |                     overlayed_feature,
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slot_state`
[INFO] [stdout]    --> src/core/feature.rs:387:21
[INFO] [stdout]     |
[INFO] [stdout] 387 |                     slot_state,
[INFO] [stdout]     |                     ^^^^^^^^^^ help: try ignoring the field: `slot_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `effects_state`
[INFO] [stdout]    --> src/core/feature.rs:389:21
[INFO] [stdout]     |
[INFO] [stdout] 389 |                     effects_state,
[INFO] [stdout]     |                     ^^^^^^^^^^^^^ help: try ignoring the field: `effects_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rolls_state`
[INFO] [stdout]    --> src/core/feature.rs:390:21
[INFO] [stdout]     |
[INFO] [stdout] 390 |                     rolls_state,
[INFO] [stdout]     |                     ^^^^^^^^^^^ help: try ignoring the field: `rolls_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/feature.rs:416:13
[INFO] [stdout]     |
[INFO] [stdout] 416 |         let mut path = path.clone();
[INFO] [stdout]     |             ----^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `overlayed_feature`
[INFO] [stdout]    --> src/core/feature.rs:409:13
[INFO] [stdout]     |
[INFO] [stdout] 409 |             overlayed_feature,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slot_state`
[INFO] [stdout]    --> src/core/feature.rs:410:13
[INFO] [stdout]     |
[INFO] [stdout] 410 |             slot_state,
[INFO] [stdout]     |             ^^^^^^^^^^ help: try ignoring the field: `slot_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `effects_state`
[INFO] [stdout]    --> src/core/feature.rs:412:13
[INFO] [stdout]     |
[INFO] [stdout] 412 |             effects_state,
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: try ignoring the field: `effects_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rolls_state`
[INFO] [stdout]    --> src/core/feature.rs:413:13
[INFO] [stdout]     |
[INFO] [stdout] 413 |             rolls_state,
[INFO] [stdout]     |             ^^^^^^^^^^^ help: try ignoring the field: `rolls_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `remaining`
[INFO] [stdout]    --> src/core/feature.rs:437:21
[INFO] [stdout]     |
[INFO] [stdout] 437 |             (false, remaining) => false,
[INFO] [stdout]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_remaining`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `overlayed_feature`
[INFO] [stdout]    --> src/core/feature.rs:454:13
[INFO] [stdout]     |
[INFO] [stdout] 454 |             overlayed_feature,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slot`
[INFO] [stdout]    --> src/core/feature.rs:477:13
[INFO] [stdout]     |
[INFO] [stdout] 477 |             slot,
[INFO] [stdout]     |             ^^^^ help: try ignoring the field: `slot: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `children`
[INFO] [stdout]    --> src/core/feature.rs:478:13
[INFO] [stdout]     |
[INFO] [stdout] 478 |             children,
[INFO] [stdout]     |             ^^^^^^^^ help: try ignoring the field: `children: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `show_reset_chidren`
[INFO] [stdout]    --> src/core/feature.rs:479:13
[INFO] [stdout]     |
[INFO] [stdout] 479 |             show_reset_chidren,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^ help: try ignoring the field: `show_reset_chidren: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `effects`
[INFO] [stdout]    --> src/core/feature.rs:481:13
[INFO] [stdout]     |
[INFO] [stdout] 481 |             effects,
[INFO] [stdout]     |             ^^^^^^^ help: try ignoring the field: `effects: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rolls`
[INFO] [stdout]    --> src/core/feature.rs:482:13
[INFO] [stdout]     |
[INFO] [stdout] 482 |             rolls,
[INFO] [stdout]     |             ^^^^^ help: try ignoring the field: `rolls: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `templates`
[INFO] [stdout]    --> src/core/feature.rs:483:13
[INFO] [stdout]     |
[INFO] [stdout] 483 |             templates,
[INFO] [stdout]     |             ^^^^^^^^^ help: try ignoring the field: `templates: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]   --> src/core/roll/mod.rs:85:13
[INFO] [stdout]    |
[INFO] [stdout] 85 |             name,
[INFO] [stdout]    |             ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/roll/mod.rs:233:13
[INFO] [stdout]     |
[INFO] [stdout] 233 |         let mut tags = self.tags.clone();
[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/core/roll/mod.rs:343:9
[INFO] [stdout]     |
[INFO] [stdout] 343 |     let mut dice = dice.clone();
[INFO] [stdout]     |         ----^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/core/roll/mod.rs:335:9
[INFO] [stdout]     |
[INFO] [stdout] 335 |         name,
[INFO] [stdout]     |         ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tags`
[INFO] [stdout]    --> src/core/roll/mod.rs:336:9
[INFO] [stdout]     |
[INFO] [stdout] 336 |         tags,
[INFO] [stdout]     |         ^^^^ help: try ignoring the field: `tags: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `range`
[INFO] [stdout]    --> src/core/roll/mod.rs:338:9
[INFO] [stdout]     |
[INFO] [stdout] 338 |         range,
[INFO] [stdout]     |         ^^^^^ help: try ignoring the field: `range: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dice`
[INFO] [stdout]    --> src/core/roll/mod.rs:405:21
[INFO] [stdout]     |
[INFO] [stdout] 405 |                     dice,
[INFO] [stdout]     |                     ^^^^ help: try ignoring the field: `dice: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `bonuses`
[INFO] [stdout]    --> src/core/roll/mod.rs:406:21
[INFO] [stdout]     |
[INFO] [stdout] 406 |                     bonuses,
[INFO] [stdout]     |                     ^^^^^^^ help: try ignoring the field: `bonuses: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sub_path`
[INFO] [stdout]    --> src/core/roll/mod.rs:422:36
[INFO] [stdout]     |
[INFO] [stdout] 422 |                 let (path_matches, sub_path) = match path {
[INFO] [stdout]     |                                    ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/roll/mod.rs:512:13
[INFO] [stdout]     |
[INFO] [stdout] 512 |         let mut column = Column::new().push(row);
[INFO] [stdout]     |             ----^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tags`
[INFO] [stdout]    --> src/core/roll/mod.rs:473:13
[INFO] [stdout]     |
[INFO] [stdout] 473 |             tags,
[INFO] [stdout]     |             ^^^^ help: try ignoring the field: `tags: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dice`
[INFO] [stdout]    --> src/core/roll/mod.rs:476:13
[INFO] [stdout]     |
[INFO] [stdout] 476 |             dice,
[INFO] [stdout]     |             ^^^^ help: try ignoring the field: `dice: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `bonuses`
[INFO] [stdout]    --> src/core/roll/mod.rs:477:13
[INFO] [stdout]     |
[INFO] [stdout] 477 |             bonuses,
[INFO] [stdout]     |             ^^^^^^^ help: try ignoring the field: `bonuses: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `control`
[INFO] [stdout]   --> src/core/slot.rs:32:25
[INFO] [stdout]    |
[INFO] [stdout] 32 |         let SlotState { control, slot } = self;
[INFO] [stdout]    |                         ^^^^^^^ help: try ignoring the field: `control: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `control`
[INFO] [stdout]   --> src/core/slot.rs:44:25
[INFO] [stdout]    |
[INFO] [stdout] 44 |         let SlotState { control, slot } = self;
[INFO] [stdout]    |                         ^^^^^^^ help: try ignoring the field: `control: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `control`
[INFO] [stdout]   --> src/core/slot.rs:50:25
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let SlotState { control, slot } = self;
[INFO] [stdout]    |                         ^^^^^^^ help: try ignoring the field: `control: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `reset_all`
[INFO] [stdout]   --> src/core/slot.rs:87:13
[INFO] [stdout]    |
[INFO] [stdout] 87 |             reset_all,
[INFO] [stdout]    |             ^^^^^^^^^ help: try ignoring the field: `reset_all: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/character/mod.rs:29:13
[INFO] [stdout]    |
[INFO] [stdout] 29 |     Loading(CharacterPersistenceConfig),
[INFO] [stdout]    |     ------- ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Character` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 29 -     Loading(CharacterPersistenceConfig),
[INFO] [stdout] 29 +     Loading(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/character/mod.rs:67:11
[INFO] [stdout]    |
[INFO] [stdout] 67 |     Saved(Result<(), LoadError>),
[INFO] [stdout]    |     ----- ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Message` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 67 -     Saved(Result<(), LoadError>),
[INFO] [stdout] 67 +     Saved(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/character/class.rs:95:12
[INFO] [stdout]    |
[INFO] [stdout] 94 | impl Class {
[INFO] [stdout]    | ---------- associated function in this implementation
[INFO] [stdout] 95 |     pub fn new(name: String, level: isize) -> Class {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `modifier_for_bonus` and `modifier` are never used
[INFO] [stdout]   --> src/character/proficiencies.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl ProficiencyType {
[INFO] [stdout]    | -------------------- methods in this implementation
[INFO] [stdout] 20 |     pub fn modifier_for_bonus(&self, class_proficiency_bonus: isize) -> isize {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn modifier(&self, class: Classes) -> isize {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `name` and `proficiency_type` are never used
[INFO] [stdout]   --> src/character/proficiencies.rs:43:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl Proficiency {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] 43 |     pub fn name(&self) -> String {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn proficiency_type(&self) -> ProficiencyType {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `default` and `with` are never used
[INFO] [stdout]   --> src/core/ability_score.rs:66:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | impl AbilityScores {
[INFO] [stdout]    | ------------------ associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub fn default() -> AbilityScores {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88 |     pub fn with(&self, ability: Ability, score: AbilityScore) -> AbilityScores {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get` is never used
[INFO] [stdout]    --> src/core/ability_score.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | impl ModifiedAbilityScores {
[INFO] [stdout]     | -------------------------- method in this implementation
[INFO] [stdout] 103 |     pub fn get(&self, ability: Ability) -> ModifiedAbilityScore {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `roll` and `score` are never used
[INFO] [stdout]    --> src/core/ability_score.rs:283:12
[INFO] [stdout]     |
[INFO] [stdout] 282 | impl ModifiedAbilityScore {
[INFO] [stdout]     | ------------------------- methods in this implementation
[INFO] [stdout] 283 |     pub fn roll(&self) -> Rollable {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 286 |     pub fn score(&self) -> AbilityScore {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `persistable` is never used
[INFO] [stdout]   --> src/core/effect.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl EffectsState {
[INFO] [stdout]    | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 29 |     pub fn persistable(&self) -> Vec<Effect> {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `persistable` is never used
[INFO] [stdout]   --> src/core/effect.rs:64:12
[INFO] [stdout]    |
[INFO] [stdout] 59 | impl EffectState {
[INFO] [stdout]    | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn persistable(&self) -> Effect {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_empty` is never used
[INFO] [stdout]    --> src/core/feature.rs:154:12
[INFO] [stdout]     |
[INFO] [stdout] 138 | impl FeaturesState {
[INFO] [stdout]     | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 154 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `apply` is never used
[INFO] [stdout]    --> src/core/feature.rs:403:8
[INFO] [stdout]     |
[INFO] [stdout] 210 | impl FeatureState {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 403 |     fn apply<F>(&mut self, path: &FeaturePath, f: &F) -> IsDirty
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `of` and `with_include_children` are never used
[INFO] [stdout]   --> src/core/feature_path.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl FeaturePath {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub fn of(path: Vec<String>) -> FeaturePath {
[INFO] [stdout]    |            ^^
[INFO] [stdout] ...
[INFO] [stdout] 75 |     pub fn with_include_children(&self, include: bool) -> FeaturePath {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/core/roll/mod.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | impl Dice {
[INFO] [stdout]    | --------- associated function in this implementation
[INFO] [stdout] 23 |     pub fn new(count: isize, sides: isize) -> Dice {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `name`, `ability`, `dice`, and `tags` are never used
[INFO] [stdout]    --> src/core/roll/mod.rs:138:12
[INFO] [stdout]     |
[INFO] [stdout] 109 | impl Roll {
[INFO] [stdout]     | --------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 138 |     pub fn name(&mut self, name: String) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn ability(&mut self, ability: Ability) {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn dice(&mut self, dice: Vec<Dice>) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub fn tags(&mut self, tags: HashMap<String, Vec<String>>) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `name`, `ability`, `path`, `tag`, and `tags` are never used
[INFO] [stdout]    --> src/core/roll/mod.rs:220:12
[INFO] [stdout]     |
[INFO] [stdout] 205 | impl RollScope {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 220 |     pub fn name(&mut self, name: String) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 224 |     pub fn ability(&mut self, ability: Ability) {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn path(&mut self, path: FeaturePath) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 232 |     pub fn tag(&mut self, tag: String, value: Vec<String>) {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 247 |     pub fn tags(&mut self, tags: HashMap<String, Vec<String>>) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `persistable` is never used
[INFO] [stdout]    --> src/core/roll/mod.rs:383:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | impl RollState {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] 383 |     pub fn persistable(&self) -> Roll {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/core/slot.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl Slot {
[INFO] [stdout]    | --------- associated function in this implementation
[INFO] [stdout] 13 |     pub fn new(current: isize, max: Option<isize>) -> Slot {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `FromSlotCommand` is never used
[INFO] [stdout]    --> src/core/slot.rs:111:11
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub trait FromSlotCommand<T> {
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/dimensions.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl Weight {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 13 |     pub fn new(lbs: isize, oz: isize) -> Weight {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from` is never used
[INFO] [stdout]   --> src/resources/persistence.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl ResourcePersistence {
[INFO] [stdout]    | ------------------------ associated function in this implementation
[INFO] [stdout] 22 |     pub fn from(templates: Templates) -> ResourcePersistence {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/resources/template.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl Templates {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 12 |     pub fn new(features: HashMap<String, Feature>) -> Templates {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `two_element_row` is never used
[INFO] [stdout]   --> src/util.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub fn two_element_row<'a, T: Debug + Clone + 'a>(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `three_column_row` is never used
[INFO] [stdout]   --> src/util.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub fn three_column_row<'a>(left: Text, middle: Text, right: Text) -> Row<'a, Message> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `three_element_row` is never used
[INFO] [stdout]   --> src/util.rs:62:8
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub fn three_element_row<'a, T: Debug + Clone + 'a>(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/class.rs:19:17
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stdout]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stdout]    |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/class.rs:99:13
[INFO] [stdout]    |
[INFO] [stdout] 99 |     fn view(&mut self) -> Row<Message> {
[INFO] [stdout]    |             ^^^^^^^^^     ^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |             |
[INFO] [stdout]    |             the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 99 |     fn view(&mut self) -> Row<'_, Message> {
[INFO] [stdout]    |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/description.rs:74:17
[INFO] [stdout]    |
[INFO] [stdout] 74 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stdout]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 74 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stdout]    |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/hitpoints.rs:98:17
[INFO] [stdout]    |
[INFO] [stdout] 98 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stdout]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 98 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stdout]    |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/character/hitpoints.rs:132:13
[INFO] [stdout]     |
[INFO] [stdout] 132 |     fn view(&mut self) -> Row<Message> {
[INFO] [stdout]     |             ^^^^^^^^^     ^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |             |
[INFO] [stdout]     |             the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 132 |     fn view(&mut self) -> Row<'_, Message> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/name.rs:10:17
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub fn view(&mut self) -> Row<Message> {
[INFO] [stdout]    |                 ^^^^^^^^^     ^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub fn view(&mut self) -> Row<'_, Message> {
[INFO] [stdout]    |                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/proficiencies.rs:65:17
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stdout]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stdout]    |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/ability_score.rs:212:35
[INFO] [stdout]     |
[INFO] [stdout] 212 |     pub fn view<T: Debug + Clone>(&mut self, name: &str) -> Row<T> {
[INFO] [stdout]     |                                   ^^^^^^^^^                 ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 212 |     pub fn view<T: Debug + Clone>(&mut self, name: &str) -> Row<'_, T> {
[INFO] [stdout]     |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `isNoneOr` should have a snake case name
[INFO] [stdout]    --> src/core/roll/mod.rs:154:4
[INFO] [stdout]     |
[INFO] [stdout] 154 | fn isNoneOr<'a, 'b, T>(option: &'a Option<T>, compare_to: &'b T) -> bool
[INFO] [stdout]     |    ^^^^^^^^ help: convert the identifier to snake case: `is_none_or`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `isNoneOrOpt` should have a snake case name
[INFO] [stdout]    --> src/core/roll/mod.rs:164:4
[INFO] [stdout]     |
[INFO] [stdout] 164 | fn isNoneOrOpt<'a, 'b, T>(option: &'a Option<T>, compare_to: &'b Option<T>) -> bool
[INFO] [stdout]     |    ^^^^^^^^^^^ help: convert the identifier to snake case: `is_none_or_opt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 3m 51s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: nom v6.0.1, wgpu-core v0.6.5
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] running `Command { std: "docker" "inspect" "ce5506734972da7283de7d099513b77bda511c8748b89c7a27fe8333874e508a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ce5506734972da7283de7d099513b77bda511c8748b89c7a27fe8333874e508a", kill_on_drop: false }`
[INFO] [stdout] ce5506734972da7283de7d099513b77bda511c8748b89c7a27fe8333874e508a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-03-05" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6f4508bc800499c202f4a92d780fef248219be5ce32db2446dbbba87d63031cd
[INFO] running `Command { std: "docker" "start" "-a" "6f4508bc800499c202f4a92d780fef248219be5ce32db2446dbbba87d63031cd", kill_on_drop: false }`
[INFO] [stderr]    Compiling mio-uds v0.6.8
[INFO] [stderr]    Compiling threadpool v1.8.1
[INFO] [stderr]    Compiling derive_more v0.99.11
[INFO] [stderr]    Compiling signal-hook-registry v1.3.0
[INFO] [stderr]    Compiling bytes v0.5.6
[INFO] [stderr]    Compiling pin-project-lite v0.1.11
[INFO] [stderr]    Compiling actix-macros v0.1.3
[INFO] [stderr]    Compiling tokio v0.2.24
[INFO] [stderr]    Compiling actix-threadpool v0.3.3
[INFO] [stderr]    Compiling actix-rt v1.1.1
[INFO] [stderr]    Compiling dnd-character v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/character/class.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 |         if (self.classes.len() > 1) {
[INFO] [stdout]    |            ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 24 -         if (self.classes.len() > 1) {
[INFO] [stdout] 24 +         if self.classes.len() > 1  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Element`, `HorizontalAlignment`, and `VerticalAlignment`
[INFO] [stdout]  --> src/character/description.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use iced::{Column, Element, HorizontalAlignment, Length, Row, Text, VerticalAlignment};
[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: `FeatureState`
[INFO] [stdout]  --> src/character/persistence.rs:8:37
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::core::feature::{Feature, FeatureState, FeaturesState};
[INFO] [stdout]   |                                     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/character/proficiencies.rs:76:23
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let text = if (proficiencies.is_empty()) {
[INFO] [stdout]    |                       ^                        ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 76 -         let text = if (proficiencies.is_empty()) {
[INFO] [stdout] 76 +         let text = if proficiencies.is_empty()  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Dice` and `Roll`
[INFO] [stdout]  --> src/core/ability_score.rs:3:25
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::core::roll::{Dice, Roll};
[INFO] [stdout]   |                         ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::util::format_modifier`
[INFO] [stdout]  --> src/core/ability_score.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::util::format_modifier;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Element`
[INFO] [stdout]  --> src/core/ability_score.rs:5:20
[INFO] [stdout]   |
[INFO] [stdout] 5 | use iced::{Column, Element, HorizontalAlignment, Length, Row, Text, VerticalAlignment};
[INFO] [stdout]   |                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Dice`
[INFO] [stdout]  --> src/core/effect.rs:2:25
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::core::roll::{Dice, RollBonus, RollScope};
[INFO] [stdout]   |                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HorizontalAlignment`, `Length`, and `VerticalAlignment`
[INFO] [stdout]  --> src/core/effect.rs:4:29
[INFO] [stdout]   |
[INFO] [stdout] 4 | use iced::{Column, Element, HorizontalAlignment, Length, Row, Text, VerticalAlignment};
[INFO] [stdout]   |                             ^^^^^^^^^^^^^^^^^^^  ^^^^^^             ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EffectState`
[INFO] [stdout]  --> src/core/feature.rs:4:35
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::core::effect::{Effect, EffectState, EffectsState};
[INFO] [stdout]   |                                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RollScope`
[INFO] [stdout]  --> src/core/feature.rs:6:31
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::core::roll::{Roll, RollScope, RollState};
[INFO] [stdout]   |                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Button` and `button`
[INFO] [stdout]  --> src/core/feature.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | use iced::{button, Button, Column, Element, Length, Row, Text};
[INFO] [stdout]   |            ^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde::export::Formatter`
[INFO] [stdout]   --> src/core/feature.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use serde::export::Formatter;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::borrow::Borrow`
[INFO] [stdout]   --> src/core/feature.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::borrow::Borrow;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Display`
[INFO] [stdout]   --> src/core/feature.rs:14:23
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::fmt::{Debug, Display};
[INFO] [stdout]    |                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/feature.rs:246:20
[INFO] [stdout]     |
[INFO] [stdout] 246 |                 if (matches) {
[INFO] [stdout]     |                    ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 246 -                 if (matches) {
[INFO] [stdout] 246 +                 if matches  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/feature.rs:383:16
[INFO] [stdout]     |
[INFO] [stdout] 383 |             if (!apply_to_children.is_empty()) {
[INFO] [stdout]     |                ^                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 383 -             if (!apply_to_children.is_empty()) {
[INFO] [stdout] 383 +             if !apply_to_children.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/feature.rs:509:12
[INFO] [stdout]     |
[INFO] [stdout] 509 |         if (!rolls_state.is_empty()) {
[INFO] [stdout]     |            ^                       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 509 -         if (!rolls_state.is_empty()) {
[INFO] [stdout] 509 +         if !rolls_state.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::core::feature_path::FeaturePath`
[INFO] [stdout]    --> src/core/feature.rs:570:9
[INFO] [stdout]     |
[INFO] [stdout] 570 |     use crate::core::feature_path::FeaturePath;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/core/feature_path.rs:40:20
[INFO] [stdout]    |
[INFO] [stdout] 40 |                 if (feature == head) {
[INFO] [stdout]    |                    ^               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 40 -                 if (feature == head) {
[INFO] [stdout] 40 +                 if feature == head  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Class`
[INFO] [stdout]  --> src/core/roll/mod.rs:1:31
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::character::class::{Class, Classes};
[INFO] [stdout]   |                               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ModifiedAbilityScores`
[INFO] [stdout]  --> src/core/roll/mod.rs:2:58
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::core::ability_score::{Ability, AbilityScores, ModifiedAbilityScores};
[INFO] [stdout]   |                                                          ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Element`
[INFO] [stdout]  --> src/core/roll/mod.rs:8:20
[INFO] [stdout]   |
[INFO] [stdout] 8 | use iced::{Column, Element, Length, Row, Text};
[INFO] [stdout]   |                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Roll`
[INFO] [stdout]  --> src/core/roll/rollable.rs:2:31
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::core::roll::{Dice, Roll};
[INFO] [stdout]   |                               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:212:20
[INFO] [stdout]     |
[INFO] [stdout] 212 |                 if (matches) {
[INFO] [stdout]     |                    ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 212 -                 if (matches) {
[INFO] [stdout] 212 +                 if matches  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:273:32
[INFO] [stdout]     |
[INFO] [stdout] 273 | ...                   if (prev.is_empty()) {
[INFO] [stdout]     |                          ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 273 -                             if (prev.is_empty()) {
[INFO] [stdout] 273 +                             if prev.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:286:16
[INFO] [stdout]     |
[INFO] [stdout] 286 |             if (prev.is_empty()) {
[INFO] [stdout]     |                ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 286 -             if (prev.is_empty()) {
[INFO] [stdout] 286 +             if prev.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:300:16
[INFO] [stdout]     |
[INFO] [stdout] 300 |             if (prev.is_empty()) {
[INFO] [stdout]     |                ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 300 -             if (prev.is_empty()) {
[INFO] [stdout] 300 +             if prev.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:311:20
[INFO] [stdout]     |
[INFO] [stdout] 311 |                 if (prev.is_empty()) {
[INFO] [stdout]     |                    ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 311 -                 if (prev.is_empty()) {
[INFO] [stdout] 311 +                 if prev.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:346:8
[INFO] [stdout]     |
[INFO] [stdout] 346 |     if (!external_bonuses.is_empty()) {
[INFO] [stdout]     |        ^                            ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 346 -     if (!external_bonuses.is_empty()) {
[INFO] [stdout] 346 +     if !external_bonuses.is_empty()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/core/roll/mod.rs:448:20
[INFO] [stdout]     |
[INFO] [stdout] 448 |                 if (is_matching) {
[INFO] [stdout]     |                    ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 448 -                 if (is_matching) {
[INFO] [stdout] 448 +                 if is_matching  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::core::feature_path::FeaturePath`
[INFO] [stdout]  --> src/core/slot.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::core::feature_path::FeaturePath;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Element` and `Length`
[INFO] [stdout]  --> src/core/slot.rs:2:36
[INFO] [stdout]   |
[INFO] [stdout] 2 | use iced::{button, Button, Column, Element, Length, Row, Text};
[INFO] [stdout]   |                                    ^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/core/slot.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 |         if (slot.max == Some(slot.current)) {
[INFO] [stdout]    |            ^                              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 51 -         if (slot.max == Some(slot.current)) {
[INFO] [stdout] 51 +         if slot.max == Some(slot.current)  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `iced::futures::StreamExt`
[INFO] [stdout]  --> src/core/feature.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use iced::futures::StreamExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `FromSlotCommand`
[INFO] [stdout]  --> src/core/feature.rs:7:25
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::core::slot::{FromSlotCommand, Slot, SlotCommand, SlotState};
[INFO] [stdout]   |                         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/character/description.rs:86:13
[INFO] [stdout]    |
[INFO] [stdout] 86 |         let mut column_1 = Column::new()
[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: unused variable: `state`
[INFO] [stdout]   --> src/character/mod.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |             Character::Loaded(state) => "Character".to_string(),
[INFO] [stdout]    |                               ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/character/mod.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |                         let mut active_effects = state.features.effects();
[INFO] [stdout]     |                             ----^^^^^^^^^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/character/mod.rs:148:17
[INFO] [stdout]     |
[INFO] [stdout] 148 |                 config,
[INFO] [stdout]     |                 ^^^^^^ help: try ignoring the field: `config: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `resources`
[INFO] [stdout]    --> src/character/mod.rs:149:17
[INFO] [stdout]     |
[INFO] [stdout] 149 |                 resources,
[INFO] [stdout]     |                 ^^^^^^^^^ help: try ignoring the field: `resources: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `saving`
[INFO] [stdout]    --> src/character/mod.rs:157:17
[INFO] [stdout]     |
[INFO] [stdout] 157 |                 saving,
[INFO] [stdout]     |                 ^^^^^^ help: try ignoring the field: `saving: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dirty`
[INFO] [stdout]    --> src/character/mod.rs:158:17
[INFO] [stdout]     |
[INFO] [stdout] 158 |                 dirty,
[INFO] [stdout]     |                 ^^^^^ help: try ignoring the field: `dirty: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]    --> src/core/feature.rs:102:26
[INFO] [stdout]     |
[INFO] [stdout] 102 |                 .filter(|n| !name.is_empty())
[INFO] [stdout]     |                          ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `effects_state`
[INFO] [stdout]    --> src/core/feature.rs:264:13
[INFO] [stdout]     |
[INFO] [stdout] 264 |             effects_state,
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: try ignoring the field: `effects_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rolls_state`
[INFO] [stdout]    --> src/core/feature.rs:265:13
[INFO] [stdout]     |
[INFO] [stdout] 265 |             rolls_state,
[INFO] [stdout]     |             ^^^^^^^^^^^ help: try ignoring the field: `rolls_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `overlayed_feature`
[INFO] [stdout]    --> src/core/feature.rs:266:13
[INFO] [stdout]     |
[INFO] [stdout] 266 |             overlayed_feature,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `f`
[INFO] [stdout]    --> src/core/feature.rs:379:33
[INFO] [stdout]     |
[INFO] [stdout] 379 |                 .filter(|(path, f)| path.include_children())
[INFO] [stdout]     |                                 ^ help: if this is intentional, prefix it with an underscore: `_f`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `feature`
[INFO] [stdout]    --> src/core/feature.rs:385:21
[INFO] [stdout]     |
[INFO] [stdout] 385 |                     feature,
[INFO] [stdout]     |                     ^^^^^^^ help: try ignoring the field: `feature: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `overlayed_feature`
[INFO] [stdout]    --> src/core/feature.rs:386:21
[INFO] [stdout]     |
[INFO] [stdout] 386 |                     overlayed_feature,
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slot_state`
[INFO] [stdout]    --> src/core/feature.rs:387:21
[INFO] [stdout]     |
[INFO] [stdout] 387 |                     slot_state,
[INFO] [stdout]     |                     ^^^^^^^^^^ help: try ignoring the field: `slot_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `effects_state`
[INFO] [stdout]    --> src/core/feature.rs:389:21
[INFO] [stdout]     |
[INFO] [stdout] 389 |                     effects_state,
[INFO] [stdout]     |                     ^^^^^^^^^^^^^ help: try ignoring the field: `effects_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rolls_state`
[INFO] [stdout]    --> src/core/feature.rs:390:21
[INFO] [stdout]     |
[INFO] [stdout] 390 |                     rolls_state,
[INFO] [stdout]     |                     ^^^^^^^^^^^ help: try ignoring the field: `rolls_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/feature.rs:416:13
[INFO] [stdout]     |
[INFO] [stdout] 416 |         let mut path = path.clone();
[INFO] [stdout]     |             ----^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `overlayed_feature`
[INFO] [stdout]    --> src/core/feature.rs:409:13
[INFO] [stdout]     |
[INFO] [stdout] 409 |             overlayed_feature,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slot_state`
[INFO] [stdout]    --> src/core/feature.rs:410:13
[INFO] [stdout]     |
[INFO] [stdout] 410 |             slot_state,
[INFO] [stdout]     |             ^^^^^^^^^^ help: try ignoring the field: `slot_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `effects_state`
[INFO] [stdout]    --> src/core/feature.rs:412:13
[INFO] [stdout]     |
[INFO] [stdout] 412 |             effects_state,
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: try ignoring the field: `effects_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rolls_state`
[INFO] [stdout]    --> src/core/feature.rs:413:13
[INFO] [stdout]     |
[INFO] [stdout] 413 |             rolls_state,
[INFO] [stdout]     |             ^^^^^^^^^^^ help: try ignoring the field: `rolls_state: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `remaining`
[INFO] [stdout]    --> src/core/feature.rs:437:21
[INFO] [stdout]     |
[INFO] [stdout] 437 |             (false, remaining) => false,
[INFO] [stdout]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_remaining`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `overlayed_feature`
[INFO] [stdout]    --> src/core/feature.rs:454:13
[INFO] [stdout]     |
[INFO] [stdout] 454 |             overlayed_feature,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `slot`
[INFO] [stdout]    --> src/core/feature.rs:477:13
[INFO] [stdout]     |
[INFO] [stdout] 477 |             slot,
[INFO] [stdout]     |             ^^^^ help: try ignoring the field: `slot: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `children`
[INFO] [stdout]    --> src/core/feature.rs:478:13
[INFO] [stdout]     |
[INFO] [stdout] 478 |             children,
[INFO] [stdout]     |             ^^^^^^^^ help: try ignoring the field: `children: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `show_reset_chidren`
[INFO] [stdout]    --> src/core/feature.rs:479:13
[INFO] [stdout]     |
[INFO] [stdout] 479 |             show_reset_chidren,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^ help: try ignoring the field: `show_reset_chidren: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `effects`
[INFO] [stdout]    --> src/core/feature.rs:481:13
[INFO] [stdout]     |
[INFO] [stdout] 481 |             effects,
[INFO] [stdout]     |             ^^^^^^^ help: try ignoring the field: `effects: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rolls`
[INFO] [stdout]    --> src/core/feature.rs:482:13
[INFO] [stdout]     |
[INFO] [stdout] 482 |             rolls,
[INFO] [stdout]     |             ^^^^^ help: try ignoring the field: `rolls: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `templates`
[INFO] [stdout]    --> src/core/feature.rs:483:13
[INFO] [stdout]     |
[INFO] [stdout] 483 |             templates,
[INFO] [stdout]     |             ^^^^^^^^^ help: try ignoring the field: `templates: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]   --> src/core/roll/mod.rs:85:13
[INFO] [stdout]    |
[INFO] [stdout] 85 |             name,
[INFO] [stdout]    |             ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/roll/mod.rs:233:13
[INFO] [stdout]     |
[INFO] [stdout] 233 |         let mut tags = self.tags.clone();
[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/core/roll/mod.rs:343:9
[INFO] [stdout]     |
[INFO] [stdout] 343 |     let mut dice = dice.clone();
[INFO] [stdout]     |         ----^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `name`
[INFO] [stdout]    --> src/core/roll/mod.rs:335:9
[INFO] [stdout]     |
[INFO] [stdout] 335 |         name,
[INFO] [stdout]     |         ^^^^ help: try ignoring the field: `name: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tags`
[INFO] [stdout]    --> src/core/roll/mod.rs:336:9
[INFO] [stdout]     |
[INFO] [stdout] 336 |         tags,
[INFO] [stdout]     |         ^^^^ help: try ignoring the field: `tags: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `range`
[INFO] [stdout]    --> src/core/roll/mod.rs:338:9
[INFO] [stdout]     |
[INFO] [stdout] 338 |         range,
[INFO] [stdout]     |         ^^^^^ help: try ignoring the field: `range: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dice`
[INFO] [stdout]    --> src/core/roll/mod.rs:405:21
[INFO] [stdout]     |
[INFO] [stdout] 405 |                     dice,
[INFO] [stdout]     |                     ^^^^ help: try ignoring the field: `dice: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `bonuses`
[INFO] [stdout]    --> src/core/roll/mod.rs:406:21
[INFO] [stdout]     |
[INFO] [stdout] 406 |                     bonuses,
[INFO] [stdout]     |                     ^^^^^^^ help: try ignoring the field: `bonuses: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sub_path`
[INFO] [stdout]    --> src/core/roll/mod.rs:422:36
[INFO] [stdout]     |
[INFO] [stdout] 422 |                 let (path_matches, sub_path) = match path {
[INFO] [stdout]     |                                    ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/roll/mod.rs:512:13
[INFO] [stdout]     |
[INFO] [stdout] 512 |         let mut column = Column::new().push(row);
[INFO] [stdout]     |             ----^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tags`
[INFO] [stdout]    --> src/core/roll/mod.rs:473:13
[INFO] [stdout]     |
[INFO] [stdout] 473 |             tags,
[INFO] [stdout]     |             ^^^^ help: try ignoring the field: `tags: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dice`
[INFO] [stdout]    --> src/core/roll/mod.rs:476:13
[INFO] [stdout]     |
[INFO] [stdout] 476 |             dice,
[INFO] [stdout]     |             ^^^^ help: try ignoring the field: `dice: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `bonuses`
[INFO] [stdout]    --> src/core/roll/mod.rs:477:13
[INFO] [stdout]     |
[INFO] [stdout] 477 |             bonuses,
[INFO] [stdout]     |             ^^^^^^^ help: try ignoring the field: `bonuses: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `control`
[INFO] [stdout]   --> src/core/slot.rs:32:25
[INFO] [stdout]    |
[INFO] [stdout] 32 |         let SlotState { control, slot } = self;
[INFO] [stdout]    |                         ^^^^^^^ help: try ignoring the field: `control: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `control`
[INFO] [stdout]   --> src/core/slot.rs:44:25
[INFO] [stdout]    |
[INFO] [stdout] 44 |         let SlotState { control, slot } = self;
[INFO] [stdout]    |                         ^^^^^^^ help: try ignoring the field: `control: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `control`
[INFO] [stdout]   --> src/core/slot.rs:50:25
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let SlotState { control, slot } = self;
[INFO] [stdout]    |                         ^^^^^^^ help: try ignoring the field: `control: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `reset_all`
[INFO] [stdout]   --> src/core/slot.rs:87:13
[INFO] [stdout]    |
[INFO] [stdout] 87 |             reset_all,
[INFO] [stdout]    |             ^^^^^^^^^ help: try ignoring the field: `reset_all: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/character/mod.rs:29:13
[INFO] [stdout]    |
[INFO] [stdout] 29 |     Loading(CharacterPersistenceConfig),
[INFO] [stdout]    |     ------- ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Character` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 29 -     Loading(CharacterPersistenceConfig),
[INFO] [stdout] 29 +     Loading(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/character/mod.rs:67:11
[INFO] [stdout]    |
[INFO] [stdout] 67 |     Saved(Result<(), LoadError>),
[INFO] [stdout]    |     ----- ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Message` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 67 -     Saved(Result<(), LoadError>),
[INFO] [stdout] 67 +     Saved(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/character/class.rs:95:12
[INFO] [stdout]    |
[INFO] [stdout] 94 | impl Class {
[INFO] [stdout]    | ---------- associated function in this implementation
[INFO] [stdout] 95 |     pub fn new(name: String, level: isize) -> Class {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `modifier_for_bonus` and `modifier` are never used
[INFO] [stdout]   --> src/character/proficiencies.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl ProficiencyType {
[INFO] [stdout]    | -------------------- methods in this implementation
[INFO] [stdout] 20 |     pub fn modifier_for_bonus(&self, class_proficiency_bonus: isize) -> isize {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn modifier(&self, class: Classes) -> isize {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `name` and `proficiency_type` are never used
[INFO] [stdout]   --> src/character/proficiencies.rs:43:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl Proficiency {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] 43 |     pub fn name(&self) -> String {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn proficiency_type(&self) -> ProficiencyType {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `default` and `with` are never used
[INFO] [stdout]   --> src/core/ability_score.rs:66:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | impl AbilityScores {
[INFO] [stdout]    | ------------------ associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub fn default() -> AbilityScores {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88 |     pub fn with(&self, ability: Ability, score: AbilityScore) -> AbilityScores {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get` is never used
[INFO] [stdout]    --> src/core/ability_score.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | impl ModifiedAbilityScores {
[INFO] [stdout]     | -------------------------- method in this implementation
[INFO] [stdout] 103 |     pub fn get(&self, ability: Ability) -> ModifiedAbilityScore {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `roll` and `score` are never used
[INFO] [stdout]    --> src/core/ability_score.rs:283:12
[INFO] [stdout]     |
[INFO] [stdout] 282 | impl ModifiedAbilityScore {
[INFO] [stdout]     | ------------------------- methods in this implementation
[INFO] [stdout] 283 |     pub fn roll(&self) -> Rollable {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 286 |     pub fn score(&self) -> AbilityScore {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `persistable` is never used
[INFO] [stdout]   --> src/core/effect.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl EffectsState {
[INFO] [stdout]    | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 29 |     pub fn persistable(&self) -> Vec<Effect> {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `persistable` is never used
[INFO] [stdout]   --> src/core/effect.rs:64:12
[INFO] [stdout]    |
[INFO] [stdout] 59 | impl EffectState {
[INFO] [stdout]    | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn persistable(&self) -> Effect {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_empty` is never used
[INFO] [stdout]    --> src/core/feature.rs:154:12
[INFO] [stdout]     |
[INFO] [stdout] 138 | impl FeaturesState {
[INFO] [stdout]     | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 154 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `apply` is never used
[INFO] [stdout]    --> src/core/feature.rs:403:8
[INFO] [stdout]     |
[INFO] [stdout] 210 | impl FeatureState {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 403 |     fn apply<F>(&mut self, path: &FeaturePath, f: &F) -> IsDirty
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `emptyFeature` is never used
[INFO] [stdout]    --> src/core/feature.rs:575:8
[INFO] [stdout]     |
[INFO] [stdout] 575 |     fn emptyFeature() -> Feature {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `of` and `with_include_children` are never used
[INFO] [stdout]   --> src/core/feature_path.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl FeaturePath {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub fn of(path: Vec<String>) -> FeaturePath {
[INFO] [stdout]    |            ^^
[INFO] [stdout] ...
[INFO] [stdout] 75 |     pub fn with_include_children(&self, include: bool) -> FeaturePath {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `path` is never used
[INFO] [stdout]    --> src/core/roll/mod.rs:228:12
[INFO] [stdout]     |
[INFO] [stdout] 205 | impl RollScope {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn path(&mut self, path: FeaturePath) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `persistable` is never used
[INFO] [stdout]    --> src/core/roll/mod.rs:383:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | impl RollState {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] 383 |     pub fn persistable(&self) -> Roll {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/core/slot.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl Slot {
[INFO] [stdout]    | --------- associated function in this implementation
[INFO] [stdout] 13 |     pub fn new(current: isize, max: Option<isize>) -> Slot {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `FromSlotCommand` is never used
[INFO] [stdout]    --> src/core/slot.rs:111:11
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub trait FromSlotCommand<T> {
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/dimensions.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl Weight {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 13 |     pub fn new(lbs: isize, oz: isize) -> Weight {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from` is never used
[INFO] [stdout]   --> src/resources/persistence.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl ResourcePersistence {
[INFO] [stdout]    | ------------------------ associated function in this implementation
[INFO] [stdout] 22 |     pub fn from(templates: Templates) -> ResourcePersistence {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/resources/template.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl Templates {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 12 |     pub fn new(features: HashMap<String, Feature>) -> Templates {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `two_element_row` is never used
[INFO] [stdout]   --> src/util.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub fn two_element_row<'a, T: Debug + Clone + 'a>(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `three_column_row` is never used
[INFO] [stdout]   --> src/util.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub fn three_column_row<'a>(left: Text, middle: Text, right: Text) -> Row<'a, Message> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `three_element_row` is never used
[INFO] [stdout]   --> src/util.rs:62:8
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub fn three_element_row<'a, T: Debug + Clone + 'a>(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/class.rs:19:17
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stdout]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stdout]    |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/class.rs:99:13
[INFO] [stdout]    |
[INFO] [stdout] 99 |     fn view(&mut self) -> Row<Message> {
[INFO] [stdout]    |             ^^^^^^^^^     ^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |             |
[INFO] [stdout]    |             the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 99 |     fn view(&mut self) -> Row<'_, Message> {
[INFO] [stdout]    |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/description.rs:74:17
[INFO] [stdout]    |
[INFO] [stdout] 74 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stdout]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 74 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stdout]    |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/hitpoints.rs:98:17
[INFO] [stdout]    |
[INFO] [stdout] 98 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stdout]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 98 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stdout]    |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/character/hitpoints.rs:132:13
[INFO] [stdout]     |
[INFO] [stdout] 132 |     fn view(&mut self) -> Row<Message> {
[INFO] [stdout]     |             ^^^^^^^^^     ^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |             |
[INFO] [stdout]     |             the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 132 |     fn view(&mut self) -> Row<'_, Message> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/name.rs:10:17
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub fn view(&mut self) -> Row<Message> {
[INFO] [stdout]    |                 ^^^^^^^^^     ^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub fn view(&mut self) -> Row<'_, Message> {
[INFO] [stdout]    |                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/character/proficiencies.rs:65:17
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stdout]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stdout]    |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/ability_score.rs:212:35
[INFO] [stdout]     |
[INFO] [stdout] 212 |     pub fn view<T: Debug + Clone>(&mut self, name: &str) -> Row<T> {
[INFO] [stdout]     |                                   ^^^^^^^^^                 ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 212 |     pub fn view<T: Debug + Clone>(&mut self, name: &str) -> Row<'_, T> {
[INFO] [stdout]     |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `emptyFeature` should have a snake case name
[INFO] [stdout]    --> src/core/feature.rs:575:8
[INFO] [stdout]     |
[INFO] [stdout] 575 |     fn emptyFeature() -> Feature {
[INFO] [stdout]     |        ^^^^^^^^^^^^ help: convert the identifier to snake case: `empty_feature`
[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 `skillProficiencies` should have a snake case name
[INFO] [stdout]    --> src/core/feature.rs:727:13
[INFO] [stdout]     |
[INFO] [stdout] 727 |         let skillProficiencies = skills
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `skill_proficiencies`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `isNoneOr` should have a snake case name
[INFO] [stdout]    --> src/core/roll/mod.rs:154:4
[INFO] [stdout]     |
[INFO] [stdout] 154 | fn isNoneOr<'a, 'b, T>(option: &'a Option<T>, compare_to: &'b T) -> bool
[INFO] [stdout]     |    ^^^^^^^^ help: convert the identifier to snake case: `is_none_or`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `isNoneOrOpt` should have a snake case name
[INFO] [stdout]    --> src/core/roll/mod.rs:164:4
[INFO] [stdout]     |
[INFO] [stdout] 164 | fn isNoneOrOpt<'a, 'b, T>(option: &'a Option<T>, compare_to: &'b Option<T>) -> bool
[INFO] [stdout]     |    ^^^^^^^^^^^ help: convert the identifier to snake case: `is_none_or_opt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/store.rs:101:9
[INFO] [stdout]     |
[INFO] [stdout] 101 |         std::fs::remove_dir_all(test_directory);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let _ = std::fs::remove_dir_all(test_directory);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 13.98s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: nom v6.0.1, wgpu-core v0.6.5
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] running `Command { std: "docker" "inspect" "6f4508bc800499c202f4a92d780fef248219be5ce32db2446dbbba87d63031cd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6f4508bc800499c202f4a92d780fef248219be5ce32db2446dbbba87d63031cd", kill_on_drop: false }`
[INFO] [stdout] 6f4508bc800499c202f4a92d780fef248219be5ce32db2446dbbba87d63031cd
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+beta-2026-03-05" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] a50d0ea0aecf3d751864caac070a331daf08ddcbd7826201941ca662c9d512ec
[INFO] running `Command { std: "docker" "start" "-a" "a50d0ea0aecf3d751864caac070a331daf08ddcbd7826201941ca662c9d512ec", kill_on_drop: false }`
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/character/class.rs:24:12
[INFO] [stderr]    |
[INFO] [stderr] 24 |         if (self.classes.len() > 1) {
[INFO] [stderr]    |            ^                      ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 24 -         if (self.classes.len() > 1) {
[INFO] [stderr] 24 +         if self.classes.len() > 1  {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Element`, `HorizontalAlignment`, and `VerticalAlignment`
[INFO] [stderr]  --> src/character/description.rs:4:20
[INFO] [stderr]   |
[INFO] [stderr] 4 | use iced::{Column, Element, HorizontalAlignment, Length, Row, Text, VerticalAlignment};
[INFO] [stderr]   |                    ^^^^^^^  ^^^^^^^^^^^^^^^^^^^                     ^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `FeatureState`
[INFO] [stderr]  --> src/character/persistence.rs:8:37
[INFO] [stderr]   |
[INFO] [stderr] 8 | use crate::core::feature::{Feature, FeatureState, FeaturesState};
[INFO] [stderr]   |                                     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/character/proficiencies.rs:76:23
[INFO] [stderr]    |
[INFO] [stderr] 76 |         let text = if (proficiencies.is_empty()) {
[INFO] [stderr]    |                       ^                        ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 76 -         let text = if (proficiencies.is_empty()) {
[INFO] [stderr] 76 +         let text = if proficiencies.is_empty()  {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Dice` and `Roll`
[INFO] [stderr]  --> src/core/ability_score.rs:3:25
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::core::roll::{Dice, Roll};
[INFO] [stderr]   |                         ^^^^  ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::util::format_modifier`
[INFO] [stderr]  --> src/core/ability_score.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use crate::util::format_modifier;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Element`
[INFO] [stderr]  --> src/core/ability_score.rs:5:20
[INFO] [stderr]   |
[INFO] [stderr] 5 | use iced::{Column, Element, HorizontalAlignment, Length, Row, Text, VerticalAlignment};
[INFO] [stderr]   |                    ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Dice`
[INFO] [stderr]  --> src/core/effect.rs:2:25
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::core::roll::{Dice, RollBonus, RollScope};
[INFO] [stderr]   |                         ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `HorizontalAlignment`, `Length`, and `VerticalAlignment`
[INFO] [stderr]  --> src/core/effect.rs:4:29
[INFO] [stderr]   |
[INFO] [stderr] 4 | use iced::{Column, Element, HorizontalAlignment, Length, Row, Text, VerticalAlignment};
[INFO] [stderr]   |                             ^^^^^^^^^^^^^^^^^^^  ^^^^^^             ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `EffectState`
[INFO] [stderr]  --> src/core/feature.rs:4:35
[INFO] [stderr]   |
[INFO] [stderr] 4 | use crate::core::effect::{Effect, EffectState, EffectsState};
[INFO] [stderr]   |                                   ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `RollScope`
[INFO] [stderr]  --> src/core/feature.rs:6:31
[INFO] [stderr]   |
[INFO] [stderr] 6 | use crate::core::roll::{Roll, RollScope, RollState};
[INFO] [stderr]   |                               ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Button` and `button`
[INFO] [stderr]  --> src/core/feature.rs:9:12
[INFO] [stderr]   |
[INFO] [stderr] 9 | use iced::{button, Button, Column, Element, Length, Row, Text};
[INFO] [stderr]   |            ^^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `serde::export::Formatter`
[INFO] [stderr]   --> src/core/feature.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use serde::export::Formatter;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::borrow::Borrow`
[INFO] [stderr]   --> src/core/feature.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | use std::borrow::Borrow;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Display`
[INFO] [stderr]   --> src/core/feature.rs:14:23
[INFO] [stderr]    |
[INFO] [stderr] 14 | use std::fmt::{Debug, Display};
[INFO] [stderr]    |                       ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/core/feature.rs:246:20
[INFO] [stderr]     |
[INFO] [stderr] 246 |                 if (matches) {
[INFO] [stderr]     |                    ^       ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 246 -                 if (matches) {
[INFO] [stderr] 246 +                 if matches  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/core/feature.rs:383:16
[INFO] [stderr]     |
[INFO] [stderr] 383 |             if (!apply_to_children.is_empty()) {
[INFO] [stderr]     |                ^                             ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 383 -             if (!apply_to_children.is_empty()) {
[INFO] [stderr] 383 +             if !apply_to_children.is_empty()  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/core/feature.rs:509:12
[INFO] [stderr]     |
[INFO] [stderr] 509 |         if (!rolls_state.is_empty()) {
[INFO] [stderr]     |            ^                       ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 509 -         if (!rolls_state.is_empty()) {
[INFO] [stderr] 509 +         if !rolls_state.is_empty()  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::core::feature_path::FeaturePath`
[INFO] [stderr]    --> src/core/feature.rs:570:9
[INFO] [stderr]     |
[INFO] [stderr] 570 |     use crate::core::feature_path::FeaturePath;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/core/feature_path.rs:40:20
[INFO] [stderr]    |
[INFO] [stderr] 40 |                 if (feature == head) {
[INFO] [stderr]    |                    ^               ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 40 -                 if (feature == head) {
[INFO] [stderr] 40 +                 if feature == head  {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Class`
[INFO] [stderr]  --> src/core/roll/mod.rs:1:31
[INFO] [stderr]   |
[INFO] [stderr] 1 | use crate::character::class::{Class, Classes};
[INFO] [stderr]   |                               ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ModifiedAbilityScores`
[INFO] [stderr]  --> src/core/roll/mod.rs:2:58
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::core::ability_score::{Ability, AbilityScores, ModifiedAbilityScores};
[INFO] [stderr]   |                                                          ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Element`
[INFO] [stderr]  --> src/core/roll/mod.rs:8:20
[INFO] [stderr]   |
[INFO] [stderr] 8 | use iced::{Column, Element, Length, Row, Text};
[INFO] [stderr]   |                    ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Roll`
[INFO] [stderr]  --> src/core/roll/rollable.rs:2:31
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::core::roll::{Dice, Roll};
[INFO] [stderr]   |                               ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/core/roll/mod.rs:212:20
[INFO] [stderr]     |
[INFO] [stderr] 212 |                 if (matches) {
[INFO] [stderr]     |                    ^       ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 212 -                 if (matches) {
[INFO] [stderr] 212 +                 if matches  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/core/roll/mod.rs:273:32
[INFO] [stderr]     |
[INFO] [stderr] 273 | ...                   if (prev.is_empty()) {
[INFO] [stderr]     |                          ^               ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 273 -                             if (prev.is_empty()) {
[INFO] [stderr] 273 +                             if prev.is_empty()  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/core/roll/mod.rs:286:16
[INFO] [stderr]     |
[INFO] [stderr] 286 |             if (prev.is_empty()) {
[INFO] [stderr]     |                ^               ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 286 -             if (prev.is_empty()) {
[INFO] [stderr] 286 +             if prev.is_empty()  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/core/roll/mod.rs:300:16
[INFO] [stderr]     |
[INFO] [stderr] 300 |             if (prev.is_empty()) {
[INFO] [stderr]     |                ^               ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 300 -             if (prev.is_empty()) {
[INFO] [stderr] 300 +             if prev.is_empty()  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/core/roll/mod.rs:311:20
[INFO] [stderr]     |
[INFO] [stderr] 311 |                 if (prev.is_empty()) {
[INFO] [stderr]     |                    ^               ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 311 -                 if (prev.is_empty()) {
[INFO] [stderr] 311 +                 if prev.is_empty()  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/core/roll/mod.rs:346:8
[INFO] [stderr]     |
[INFO] [stderr] 346 |     if (!external_bonuses.is_empty()) {
[INFO] [stderr]     |        ^                            ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 346 -     if (!external_bonuses.is_empty()) {
[INFO] [stderr] 346 +     if !external_bonuses.is_empty()  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/core/roll/mod.rs:448:20
[INFO] [stderr]     |
[INFO] [stderr] 448 |                 if (is_matching) {
[INFO] [stderr]     |                    ^           ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 448 -                 if (is_matching) {
[INFO] [stderr] 448 +                 if is_matching  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::core::feature_path::FeaturePath`
[INFO] [stderr]  --> src/core/slot.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use crate::core::feature_path::FeaturePath;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Element` and `Length`
[INFO] [stderr]  --> src/core/slot.rs:2:36
[INFO] [stderr]   |
[INFO] [stderr] 2 | use iced::{button, Button, Column, Element, Length, Row, Text};
[INFO] [stderr]   |                                    ^^^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/core/slot.rs:51:12
[INFO] [stderr]    |
[INFO] [stderr] 51 |         if (slot.max == Some(slot.current)) {
[INFO] [stderr]    |            ^                              ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 51 -         if (slot.max == Some(slot.current)) {
[INFO] [stderr] 51 +         if slot.max == Some(slot.current)  {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `iced::futures::StreamExt`
[INFO] [stderr]  --> src/core/feature.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use iced::futures::StreamExt;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `FromSlotCommand`
[INFO] [stderr]  --> src/core/feature.rs:7:25
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::core::slot::{FromSlotCommand, Slot, SlotCommand, SlotState};
[INFO] [stderr]   |                         ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/character/description.rs:86:13
[INFO] [stderr]    |
[INFO] [stderr] 86 |         let mut column_1 = Column::new()
[INFO] [stderr]    |             ----^^^^^^^^
[INFO] [stderr]    |             |
[INFO] [stderr]    |             help: remove this `mut`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `state`
[INFO] [stderr]   --> src/character/mod.rs:87:31
[INFO] [stderr]    |
[INFO] [stderr] 87 |             Character::Loaded(state) => "Character".to_string(),
[INFO] [stderr]    |                               ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/character/mod.rs:115:29
[INFO] [stderr]     |
[INFO] [stderr] 115 |                         let mut active_effects = state.features.effects();
[INFO] [stderr]     |                             ----^^^^^^^^^^^^^^
[INFO] [stderr]     |                             |
[INFO] [stderr]     |                             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `config`
[INFO] [stderr]    --> src/character/mod.rs:148:17
[INFO] [stderr]     |
[INFO] [stderr] 148 |                 config,
[INFO] [stderr]     |                 ^^^^^^ help: try ignoring the field: `config: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `resources`
[INFO] [stderr]    --> src/character/mod.rs:149:17
[INFO] [stderr]     |
[INFO] [stderr] 149 |                 resources,
[INFO] [stderr]     |                 ^^^^^^^^^ help: try ignoring the field: `resources: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `saving`
[INFO] [stderr]    --> src/character/mod.rs:157:17
[INFO] [stderr]     |
[INFO] [stderr] 157 |                 saving,
[INFO] [stderr]     |                 ^^^^^^ help: try ignoring the field: `saving: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dirty`
[INFO] [stderr]    --> src/character/mod.rs:158:17
[INFO] [stderr]     |
[INFO] [stderr] 158 |                 dirty,
[INFO] [stderr]     |                 ^^^^^ help: try ignoring the field: `dirty: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `n`
[INFO] [stderr]    --> src/core/feature.rs:102:26
[INFO] [stderr]     |
[INFO] [stderr] 102 |                 .filter(|n| !name.is_empty())
[INFO] [stderr]     |                          ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `effects_state`
[INFO] [stderr]    --> src/core/feature.rs:264:13
[INFO] [stderr]     |
[INFO] [stderr] 264 |             effects_state,
[INFO] [stderr]     |             ^^^^^^^^^^^^^ help: try ignoring the field: `effects_state: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rolls_state`
[INFO] [stderr]    --> src/core/feature.rs:265:13
[INFO] [stderr]     |
[INFO] [stderr] 265 |             rolls_state,
[INFO] [stderr]     |             ^^^^^^^^^^^ help: try ignoring the field: `rolls_state: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `overlayed_feature`
[INFO] [stderr]    --> src/core/feature.rs:266:13
[INFO] [stderr]     |
[INFO] [stderr] 266 |             overlayed_feature,
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `f`
[INFO] [stderr]    --> src/core/feature.rs:379:33
[INFO] [stderr]     |
[INFO] [stderr] 379 |                 .filter(|(path, f)| path.include_children())
[INFO] [stderr]     |                                 ^ help: if this is intentional, prefix it with an underscore: `_f`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `feature`
[INFO] [stderr]    --> src/core/feature.rs:385:21
[INFO] [stderr]     |
[INFO] [stderr] 385 |                     feature,
[INFO] [stderr]     |                     ^^^^^^^ help: try ignoring the field: `feature: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `overlayed_feature`
[INFO] [stderr]    --> src/core/feature.rs:386:21
[INFO] [stderr]     |
[INFO] [stderr] 386 |                     overlayed_feature,
[INFO] [stderr]     |                     ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `slot_state`
[INFO] [stderr]    --> src/core/feature.rs:387:21
[INFO] [stderr]     |
[INFO] [stderr] 387 |                     slot_state,
[INFO] [stderr]     |                     ^^^^^^^^^^ help: try ignoring the field: `slot_state: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `effects_state`
[INFO] [stderr]    --> src/core/feature.rs:389:21
[INFO] [stderr]     |
[INFO] [stderr] 389 |                     effects_state,
[INFO] [stderr]     |                     ^^^^^^^^^^^^^ help: try ignoring the field: `effects_state: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rolls_state`
[INFO] [stderr]    --> src/core/feature.rs:390:21
[INFO] [stderr]     |
[INFO] [stderr] 390 |                     rolls_state,
[INFO] [stderr]     |                     ^^^^^^^^^^^ help: try ignoring the field: `rolls_state: _`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/core/feature.rs:416:13
[INFO] [stderr]     |
[INFO] [stderr] 416 |         let mut path = path.clone();
[INFO] [stderr]     |             ----^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `overlayed_feature`
[INFO] [stderr]    --> src/core/feature.rs:409:13
[INFO] [stderr]     |
[INFO] [stderr] 409 |             overlayed_feature,
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `slot_state`
[INFO] [stderr]    --> src/core/feature.rs:410:13
[INFO] [stderr]     |
[INFO] [stderr] 410 |             slot_state,
[INFO] [stderr]     |             ^^^^^^^^^^ help: try ignoring the field: `slot_state: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `effects_state`
[INFO] [stderr]    --> src/core/feature.rs:412:13
[INFO] [stderr]     |
[INFO] [stderr] 412 |             effects_state,
[INFO] [stderr]     |             ^^^^^^^^^^^^^ help: try ignoring the field: `effects_state: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rolls_state`
[INFO] [stderr]    --> src/core/feature.rs:413:13
[INFO] [stderr]     |
[INFO] [stderr] 413 |             rolls_state,
[INFO] [stderr]     |             ^^^^^^^^^^^ help: try ignoring the field: `rolls_state: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `remaining`
[INFO] [stderr]    --> src/core/feature.rs:437:21
[INFO] [stderr]     |
[INFO] [stderr] 437 |             (false, remaining) => false,
[INFO] [stderr]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_remaining`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `overlayed_feature`
[INFO] [stderr]    --> src/core/feature.rs:454:13
[INFO] [stderr]     |
[INFO] [stderr] 454 |             overlayed_feature,
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^ help: try ignoring the field: `overlayed_feature: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `slot`
[INFO] [stderr]    --> src/core/feature.rs:477:13
[INFO] [stderr]     |
[INFO] [stderr] 477 |             slot,
[INFO] [stderr]     |             ^^^^ help: try ignoring the field: `slot: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `children`
[INFO] [stderr]    --> src/core/feature.rs:478:13
[INFO] [stderr]     |
[INFO] [stderr] 478 |             children,
[INFO] [stderr]     |             ^^^^^^^^ help: try ignoring the field: `children: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `show_reset_chidren`
[INFO] [stderr]    --> src/core/feature.rs:479:13
[INFO] [stderr]     |
[INFO] [stderr] 479 |             show_reset_chidren,
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^ help: try ignoring the field: `show_reset_chidren: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `effects`
[INFO] [stderr]    --> src/core/feature.rs:481:13
[INFO] [stderr]     |
[INFO] [stderr] 481 |             effects,
[INFO] [stderr]     |             ^^^^^^^ help: try ignoring the field: `effects: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rolls`
[INFO] [stderr]    --> src/core/feature.rs:482:13
[INFO] [stderr]     |
[INFO] [stderr] 482 |             rolls,
[INFO] [stderr]     |             ^^^^^ help: try ignoring the field: `rolls: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `templates`
[INFO] [stderr]    --> src/core/feature.rs:483:13
[INFO] [stderr]     |
[INFO] [stderr] 483 |             templates,
[INFO] [stderr]     |             ^^^^^^^^^ help: try ignoring the field: `templates: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `name`
[INFO] [stderr]   --> src/core/roll/mod.rs:85:13
[INFO] [stderr]    |
[INFO] [stderr] 85 |             name,
[INFO] [stderr]    |             ^^^^ help: try ignoring the field: `name: _`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/core/roll/mod.rs:233:13
[INFO] [stderr]     |
[INFO] [stderr] 233 |         let mut tags = self.tags.clone();
[INFO] [stderr]     |             ----^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/core/roll/mod.rs:343:9
[INFO] [stderr]     |
[INFO] [stderr] 343 |     let mut dice = dice.clone();
[INFO] [stderr]     |         ----^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `name`
[INFO] [stderr]    --> src/core/roll/mod.rs:335:9
[INFO] [stderr]     |
[INFO] [stderr] 335 |         name,
[INFO] [stderr]     |         ^^^^ help: try ignoring the field: `name: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `tags`
[INFO] [stderr]    --> src/core/roll/mod.rs:336:9
[INFO] [stderr]     |
[INFO] [stderr] 336 |         tags,
[INFO] [stderr]     |         ^^^^ help: try ignoring the field: `tags: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `range`
[INFO] [stderr]    --> src/core/roll/mod.rs:338:9
[INFO] [stderr]     |
[INFO] [stderr] 338 |         range,
[INFO] [stderr]     |         ^^^^^ help: try ignoring the field: `range: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dice`
[INFO] [stderr]    --> src/core/roll/mod.rs:405:21
[INFO] [stderr]     |
[INFO] [stderr] 405 |                     dice,
[INFO] [stderr]     |                     ^^^^ help: try ignoring the field: `dice: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `bonuses`
[INFO] [stderr]    --> src/core/roll/mod.rs:406:21
[INFO] [stderr]     |
[INFO] [stderr] 406 |                     bonuses,
[INFO] [stderr]     |                     ^^^^^^^ help: try ignoring the field: `bonuses: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `sub_path`
[INFO] [stderr]    --> src/core/roll/mod.rs:422:36
[INFO] [stderr]     |
[INFO] [stderr] 422 |                 let (path_matches, sub_path) = match path {
[INFO] [stderr]     |                                    ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_path`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/core/roll/mod.rs:512:13
[INFO] [stderr]     |
[INFO] [stderr] 512 |         let mut column = Column::new().push(row);
[INFO] [stderr]     |             ----^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `tags`
[INFO] [stderr]    --> src/core/roll/mod.rs:473:13
[INFO] [stderr]     |
[INFO] [stderr] 473 |             tags,
[INFO] [stderr]     |             ^^^^ help: try ignoring the field: `tags: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dice`
[INFO] [stderr]    --> src/core/roll/mod.rs:476:13
[INFO] [stderr]     |
[INFO] [stderr] 476 |             dice,
[INFO] [stderr]     |             ^^^^ help: try ignoring the field: `dice: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `bonuses`
[INFO] [stderr]    --> src/core/roll/mod.rs:477:13
[INFO] [stderr]     |
[INFO] [stderr] 477 |             bonuses,
[INFO] [stderr]     |             ^^^^^^^ help: try ignoring the field: `bonuses: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `control`
[INFO] [stderr]   --> src/core/slot.rs:32:25
[INFO] [stderr]    |
[INFO] [stderr] 32 |         let SlotState { control, slot } = self;
[INFO] [stderr]    |                         ^^^^^^^ help: try ignoring the field: `control: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `control`
[INFO] [stderr]   --> src/core/slot.rs:44:25
[INFO] [stderr]    |
[INFO] [stderr] 44 |         let SlotState { control, slot } = self;
[INFO] [stderr]    |                         ^^^^^^^ help: try ignoring the field: `control: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `control`
[INFO] [stderr]   --> src/core/slot.rs:50:25
[INFO] [stderr]    |
[INFO] [stderr] 50 |         let SlotState { control, slot } = self;
[INFO] [stderr]    |                         ^^^^^^^ help: try ignoring the field: `control: _`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `reset_all`
[INFO] [stderr]   --> src/core/slot.rs:87:13
[INFO] [stderr]    |
[INFO] [stderr] 87 |             reset_all,
[INFO] [stderr]    |             ^^^^^^^^^ help: try ignoring the field: `reset_all: _`
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/character/mod.rs:29:13
[INFO] [stderr]    |
[INFO] [stderr] 29 |     Loading(CharacterPersistenceConfig),
[INFO] [stderr]    |     ------- ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Character` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 29 -     Loading(CharacterPersistenceConfig),
[INFO] [stderr] 29 +     Loading(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/character/mod.rs:67:11
[INFO] [stderr]    |
[INFO] [stderr] 67 |     Saved(Result<(), LoadError>),
[INFO] [stderr]    |     ----- ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Message` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 67 -     Saved(Result<(), LoadError>),
[INFO] [stderr] 67 +     Saved(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/character/class.rs:95:12
[INFO] [stderr]    |
[INFO] [stderr] 94 | impl Class {
[INFO] [stderr]    | ---------- associated function in this implementation
[INFO] [stderr] 95 |     pub fn new(name: String, level: isize) -> Class {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `modifier_for_bonus` and `modifier` are never used
[INFO] [stderr]   --> src/character/proficiencies.rs:20:12
[INFO] [stderr]    |
[INFO] [stderr] 19 | impl ProficiencyType {
[INFO] [stderr]    | -------------------- methods in this implementation
[INFO] [stderr] 20 |     pub fn modifier_for_bonus(&self, class_proficiency_bonus: isize) -> isize {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 27 |     pub fn modifier(&self, class: Classes) -> isize {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `name` and `proficiency_type` are never used
[INFO] [stderr]   --> src/character/proficiencies.rs:43:12
[INFO] [stderr]    |
[INFO] [stderr] 42 | impl Proficiency {
[INFO] [stderr]    | ---------------- methods in this implementation
[INFO] [stderr] 43 |     pub fn name(&self) -> String {
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 46 |     pub fn proficiency_type(&self) -> ProficiencyType {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `default` and `with` are never used
[INFO] [stderr]   --> src/core/ability_score.rs:66:12
[INFO] [stderr]    |
[INFO] [stderr] 54 | impl AbilityScores {
[INFO] [stderr]    | ------------------ associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 66 |     pub fn default() -> AbilityScores {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 88 |     pub fn with(&self, ability: Ability, score: AbilityScore) -> AbilityScores {
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `get` is never used
[INFO] [stderr]    --> src/core/ability_score.rs:103:12
[INFO] [stderr]     |
[INFO] [stderr] 102 | impl ModifiedAbilityScores {
[INFO] [stderr]     | -------------------------- method in this implementation
[INFO] [stderr] 103 |     pub fn get(&self, ability: Ability) -> ModifiedAbilityScore {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `roll` and `score` are never used
[INFO] [stderr]    --> src/core/ability_score.rs:283:12
[INFO] [stderr]     |
[INFO] [stderr] 282 | impl ModifiedAbilityScore {
[INFO] [stderr]     | ------------------------- methods in this implementation
[INFO] [stderr] 283 |     pub fn roll(&self) -> Rollable {
[INFO] [stderr]     |            ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 286 |     pub fn score(&self) -> AbilityScore {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `persistable` is never used
[INFO] [stderr]   --> src/core/effect.rs:29:12
[INFO] [stderr]    |
[INFO] [stderr] 13 | impl EffectsState {
[INFO] [stderr]    | ----------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 29 |     pub fn persistable(&self) -> Vec<Effect> {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `persistable` is never used
[INFO] [stderr]   --> src/core/effect.rs:64:12
[INFO] [stderr]    |
[INFO] [stderr] 59 | impl EffectState {
[INFO] [stderr]    | ---------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 64 |     pub fn persistable(&self) -> Effect {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `is_empty` is never used
[INFO] [stderr]    --> src/core/feature.rs:154:12
[INFO] [stderr]     |
[INFO] [stderr] 138 | impl FeaturesState {
[INFO] [stderr]     | ------------------ method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 154 |     pub fn is_empty(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `apply` is never used
[INFO] [stderr]    --> src/core/feature.rs:403:8
[INFO] [stderr]     |
[INFO] [stderr] 210 | impl FeatureState {
[INFO] [stderr]     | ----------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 403 |     fn apply<F>(&mut self, path: &FeaturePath, f: &F) -> IsDirty
[INFO] [stderr]     |        ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `emptyFeature` is never used
[INFO] [stderr]    --> src/core/feature.rs:575:8
[INFO] [stderr]     |
[INFO] [stderr] 575 |     fn emptyFeature() -> Feature {
[INFO] [stderr]     |        ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `of` and `with_include_children` are never used
[INFO] [stderr]   --> src/core/feature_path.rs:22:12
[INFO] [stderr]    |
[INFO] [stderr] 18 | impl FeaturePath {
[INFO] [stderr]    | ---------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 22 |     pub fn of(path: Vec<String>) -> FeaturePath {
[INFO] [stderr]    |            ^^
[INFO] [stderr] ...
[INFO] [stderr] 75 |     pub fn with_include_children(&self, include: bool) -> FeaturePath {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `path` is never used
[INFO] [stderr]    --> src/core/roll/mod.rs:228:12
[INFO] [stderr]     |
[INFO] [stderr] 205 | impl RollScope {
[INFO] [stderr]     | -------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 228 |     pub fn path(&mut self, path: FeaturePath) {
[INFO] [stderr]     |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `persistable` is never used
[INFO] [stderr]    --> src/core/roll/mod.rs:383:12
[INFO] [stderr]     |
[INFO] [stderr] 382 | impl RollState {
[INFO] [stderr]     | -------------- method in this implementation
[INFO] [stderr] 383 |     pub fn persistable(&self) -> Roll {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/core/slot.rs:13:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | impl Slot {
[INFO] [stderr]    | --------- associated function in this implementation
[INFO] [stderr] 13 |     pub fn new(current: isize, max: Option<isize>) -> Slot {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `FromSlotCommand` is never used
[INFO] [stderr]    --> src/core/slot.rs:111:11
[INFO] [stderr]     |
[INFO] [stderr] 111 | pub trait FromSlotCommand<T> {
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/dimensions.rs:13:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | impl Weight {
[INFO] [stderr]    | ----------- associated function in this implementation
[INFO] [stderr] 13 |     pub fn new(lbs: isize, oz: isize) -> Weight {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from` is never used
[INFO] [stderr]   --> src/resources/persistence.rs:22:12
[INFO] [stderr]    |
[INFO] [stderr] 21 | impl ResourcePersistence {
[INFO] [stderr]    | ------------------------ associated function in this implementation
[INFO] [stderr] 22 |     pub fn from(templates: Templates) -> ResourcePersistence {
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/resources/template.rs:12:12
[INFO] [stderr]    |
[INFO] [stderr] 11 | impl Templates {
[INFO] [stderr]    | -------------- associated function in this implementation
[INFO] [stderr] 12 |     pub fn new(features: HashMap<String, Feature>) -> Templates {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `two_element_row` is never used
[INFO] [stderr]   --> src/util.rs:32:8
[INFO] [stderr]    |
[INFO] [stderr] 32 | pub fn two_element_row<'a, T: Debug + Clone + 'a>(
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `three_column_row` is never used
[INFO] [stderr]   --> src/util.rs:41:8
[INFO] [stderr]    |
[INFO] [stderr] 41 | pub fn three_column_row<'a>(left: Text, middle: Text, right: Text) -> Row<'a, Message> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `three_element_row` is never used
[INFO] [stderr]   --> src/util.rs:62:8
[INFO] [stderr]    |
[INFO] [stderr] 62 | pub fn three_element_row<'a, T: Debug + Clone + 'a>(
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/character/class.rs:19:17
[INFO] [stderr]    |
[INFO] [stderr] 19 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stderr]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 19 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stderr]    |                                      +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/character/class.rs:99:13
[INFO] [stderr]    |
[INFO] [stderr] 99 |     fn view(&mut self) -> Row<Message> {
[INFO] [stderr]    |             ^^^^^^^^^     ^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |             |
[INFO] [stderr]    |             the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 99 |     fn view(&mut self) -> Row<'_, Message> {
[INFO] [stderr]    |                               +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/character/description.rs:74:17
[INFO] [stderr]    |
[INFO] [stderr] 74 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stderr]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 74 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stderr]    |                                      +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/character/hitpoints.rs:98:17
[INFO] [stderr]    |
[INFO] [stderr] 98 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stderr]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 98 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stderr]    |                                      +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/character/hitpoints.rs:132:13
[INFO] [stderr]     |
[INFO] [stderr] 132 |     fn view(&mut self) -> Row<Message> {
[INFO] [stderr]     |             ^^^^^^^^^     ^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |             |
[INFO] [stderr]     |             the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 132 |     fn view(&mut self) -> Row<'_, Message> {
[INFO] [stderr]     |                               +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/character/name.rs:10:17
[INFO] [stderr]    |
[INFO] [stderr] 10 |     pub fn view(&mut self) -> Row<Message> {
[INFO] [stderr]    |                 ^^^^^^^^^     ^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 10 |     pub fn view(&mut self) -> Row<'_, Message> {
[INFO] [stderr]    |                                   +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/character/proficiencies.rs:65:17
[INFO] [stderr]    |
[INFO] [stderr] 65 |     pub fn view(&mut self) -> Column<Message> {
[INFO] [stderr]    |                 ^^^^^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 65 |     pub fn view(&mut self) -> Column<'_, Message> {
[INFO] [stderr]    |                                      +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/core/ability_score.rs:212:35
[INFO] [stderr]     |
[INFO] [stderr] 212 |     pub fn view<T: Debug + Clone>(&mut self, name: &str) -> Row<T> {
[INFO] [stderr]     |                                   ^^^^^^^^^                 ^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                                   |
[INFO] [stderr]     |                                   the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 212 |     pub fn view<T: Debug + Clone>(&mut self, name: &str) -> Row<'_, T> {
[INFO] [stderr]     |                                                                 +++
[INFO] [stderr] 
[INFO] [stderr] warning: function `emptyFeature` should have a snake case name
[INFO] [stderr]    --> src/core/feature.rs:575:8
[INFO] [stderr]     |
[INFO] [stderr] 575 |     fn emptyFeature() -> Feature {
[INFO] [stderr]     |        ^^^^^^^^^^^^ help: convert the identifier to snake case: `empty_feature`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable `skillProficiencies` should have a snake case name
[INFO] [stderr]    --> src/core/feature.rs:727:13
[INFO] [stderr]     |
[INFO] [stderr] 727 |         let skillProficiencies = skills
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `skill_proficiencies`
[INFO] [stderr] 
[INFO] [stderr] warning: function `isNoneOr` should have a snake case name
[INFO] [stderr]    --> src/core/roll/mod.rs:154:4
[INFO] [stderr]     |
[INFO] [stderr] 154 | fn isNoneOr<'a, 'b, T>(option: &'a Option<T>, compare_to: &'b T) -> bool
[INFO] [stderr]     |    ^^^^^^^^ help: convert the identifier to snake case: `is_none_or`
[INFO] [stderr] 
[INFO] [stderr] warning: function `isNoneOrOpt` should have a snake case name
[INFO] [stderr]    --> src/core/roll/mod.rs:164:4
[INFO] [stderr]     |
[INFO] [stderr] 164 | fn isNoneOrOpt<'a, 'b, T>(option: &'a Option<T>, compare_to: &'b Option<T>) -> bool
[INFO] [stderr]     |    ^^^^^^^^^^^ help: convert the identifier to snake case: `is_none_or_opt`
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> src/store.rs:101:9
[INFO] [stderr]     |
[INFO] [stderr] 101 |         std::fs::remove_dir_all(test_directory);
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 101 |         let _ = std::fs::remove_dir_all(test_directory);
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `dnd-character` (bin "dnd-character" test) generated 120 warnings (run `cargo fix --bin "dnd-character" -p dnd-character --tests` to apply 89 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.31s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: nom v6.0.1, wgpu-core v0.6.5
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/dnd_character-085aa0c2a8788f52)
[INFO] [stdout] 
[INFO] [stdout] running 5 tests
[INFO] [stdout] test core::ability_score::test::test_modifier ... ok
[INFO] [stdout] test core::feature::test::generate_saving_throws ... ok
[INFO] [stdout] test core::effect::test::wand_of_the_war_mage ... ok
[INFO] [stdout] test store::test::file_persistence ... FAILED
[INFO] [stdout] test character::class::test::test_proficiency ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- store::test::file_persistence stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'store::test::file_persistence' (21) panicked at src/store.rs:92:56:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileError("Read-only file system (os error 30)")
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5f596e28855a - std[b80a194dd3c418bb]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5f596e28855a - std[b80a194dd3c418bb]::backtrace_rs::backtrace::trace_unsynchronized::<std[b80a194dd3c418bb]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5f596e28855a - std[b80a194dd3c418bb]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5f596e28855a - <<std[b80a194dd3c418bb]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[10b6fa85044e1869]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5f596e29cc9a - <core[10b6fa85044e1869]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5f596e29cc9a - core[10b6fa85044e1869]::fmt::write
[INFO] [stdout]    6:     0x5f596e28d072 - std[b80a194dd3c418bb]::io::default_write_fmt::<alloc[dd269455e567d8e9]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5f596e28d072 - <alloc[dd269455e567d8e9]::vec::Vec<u8> as std[b80a194dd3c418bb]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5f596e265b9f - <std[b80a194dd3c418bb]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5f596e265b9f - std[b80a194dd3c418bb]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5f596e27fff9 - std[b80a194dd3c418bb]::panicking::default_hook
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5f596e1701ac - <alloc[dd269455e567d8e9]::boxed::Box<dyn for<'a, 'b> core[10b6fa85044e1869]::ops::function::Fn<(&'a std[b80a194dd3c418bb]::panic::PanicHookInfo<'b>,), Output = ()> + core[10b6fa85044e1869]::marker::Sync + core[10b6fa85044e1869]::marker::Send> as core[10b6fa85044e1869]::ops::function::Fn<(&std[b80a194dd3c418bb]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/alloc/src/boxed.rs:2254:9
[INFO] [stdout]   12:     0x5f596e1701ac - test[826cbc6ef54ab466]::test_main_with_exit_callback::<test[826cbc6ef54ab466]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5f596e2801b2 - <alloc[dd269455e567d8e9]::boxed::Box<dyn for<'a, 'b> core[10b6fa85044e1869]::ops::function::Fn<(&'a std[b80a194dd3c418bb]::panic::PanicHookInfo<'b>,), Output = ()> + core[10b6fa85044e1869]::marker::Sync + core[10b6fa85044e1869]::marker::Send> as core[10b6fa85044e1869]::ops::function::Fn<(&std[b80a194dd3c418bb]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/alloc/src/boxed.rs:2254:9
[INFO] [stdout]   14:     0x5f596e2801b2 - std[b80a194dd3c418bb]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5f596e265c58 - std[b80a194dd3c418bb]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x5f596e25d399 - std[b80a194dd3c418bb]::sys::backtrace::__rust_end_short_backtrace::<std[b80a194dd3c418bb]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5f596e26696d - __rustc[9698a3e60dd14283]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5f596e29d5ac - core[10b6fa85044e1869]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5f596e29d2f2 - core[10b6fa85044e1869]::result::unwrap_failed
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/result.rs:1867:5
[INFO] [stdout]   20:     0x5f596e0e2d80 - core::result::Result<T,E>::unwrap::hebff6b9a730f0386
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/result.rs:1233:23
[INFO] [stdout]   21:     0x5f596e0e2d80 - dnd_character::store::test::file_persistence::{{closure}}::hd7f9e874ade2fd6d
[INFO] [stdout]                                at /opt/rustwide/workdir/src/store.rs:92:56
[INFO] [stdout]   22:     0x5f596e0feca6 - <tokio::task::local::RunUntil<T> as core::future::future::Future>::poll::{{closure}}::{{closure}}::h1c855d20875fa537
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/task/local.rs:528:67
[INFO] [stdout]   23:     0x5f596e1025a0 - tokio::coop::with_budget::{{closure}}::had9f282a8fa25bc1
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/coop.rs:127:9
[INFO] [stdout]   24:     0x5f596e0eb245 - std::thread::local::LocalKey<T>::try_with::h6bef668d49bada4f
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/thread/local.rs:513:12
[INFO] [stdout]   25:     0x5f596e0ea9ae - std::thread::local::LocalKey<T>::with::hb2a207b5a62b9fd6
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/thread/local.rs:477:20
[INFO] [stdout]   26:     0x5f596e0feb92 - tokio::coop::with_budget::hd3a5e4ab231f5a30
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/coop.rs:120:13
[INFO] [stdout]   27:     0x5f596e0feb92 - tokio::coop::budget::hd47aa03468753509
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/coop.rs:96:5
[INFO] [stdout]   28:     0x5f596e0feb92 - <tokio::task::local::RunUntil<T> as core::future::future::Future>::poll::{{closure}}::h7c45a18808ab494f
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/task/local.rs:528:42
[INFO] [stdout]   29:     0x5f596e0dc4fd - tokio::macros::scoped_tls::ScopedKey<T>::set::h1babeec328401059
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/macros/scoped_tls.rs:63:9
[INFO] [stdout]   30:     0x5f596e0fcf9a - tokio::task::local::LocalSet::with::h0d9bf8e0243cf3bc
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/task/local.rs:442:17
[INFO] [stdout]   31:     0x5f596e0fea5b - <tokio::task::local::RunUntil<T> as core::future::future::Future>::poll::ha00a341b390740fa
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/task/local.rs:518:22
[INFO] [stdout]   32:     0x5f596e0fd225 - tokio::task::local::LocalSet::run_until::{{closure}}::he12677d82a6b894c
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/task/local.rs:392:19
[INFO] [stdout]   33:     0x5f596e0d504d - tokio::runtime::basic_scheduler::BasicScheduler<P>::block_on::{{closure}}::{{closure}}::h8d0e1a59bade4a19
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/runtime/basic_scheduler.rs:131:74
[INFO] [stdout]   34:     0x5f596e102470 - tokio::coop::with_budget::{{closure}}::h7ab99cf1528fda61
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/coop.rs:127:9
[INFO] [stdout]   35:     0x5f596e0eace5 - std::thread::local::LocalKey<T>::try_with::h1eebece3b30e0268
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/thread/local.rs:513:12
[INFO] [stdout]   36:     0x5f596e0eaace - std::thread::local::LocalKey<T>::with::hfbf1f5de39307060
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/thread/local.rs:477:20
[INFO] [stdout]   37:     0x5f596e0d4b63 - tokio::coop::with_budget::hf7d1894ab9370db6
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/coop.rs:120:13
[INFO] [stdout]   38:     0x5f596e0d4b63 - tokio::coop::budget::h052293c154832bd9
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/coop.rs:96:5
[INFO] [stdout]   39:     0x5f596e0d4b63 - tokio::runtime::basic_scheduler::BasicScheduler<P>::block_on::{{closure}}::h9cc7a2e2e9ff4e47
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/runtime/basic_scheduler.rs:131:35
[INFO] [stdout]   40:     0x5f596e0d551e - tokio::runtime::basic_scheduler::enter::{{closure}}::he59f2178f35618e4
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/runtime/basic_scheduler.rs:213:29
[INFO] [stdout]   41:     0x5f596e0dc617 - tokio::macros::scoped_tls::ScopedKey<T>::set::hd01f3d8c89891db0
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/macros/scoped_tls.rs:63:9
[INFO] [stdout]   42:     0x5f596e0d5488 - tokio::runtime::basic_scheduler::enter::h2f188948cf06f92f
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/runtime/basic_scheduler.rs:213:13
[INFO] [stdout]   43:     0x5f596e0d48b0 - tokio::runtime::basic_scheduler::BasicScheduler<P>::block_on::hafffae553ced674b
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/runtime/basic_scheduler.rs:123:9
[INFO] [stdout]   44:     0x5f596e0fd382 - tokio::runtime::Runtime::block_on::{{closure}}::hb035dd54c80a64a2
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/runtime/mod.rs:444:39
[INFO] [stdout]   45:     0x5f596e0cd3fb - tokio::runtime::context::enter::hdbddf56eb4767151
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/runtime/context.rs:72:5
[INFO] [stdout]   46:     0x5f596e0f16da - tokio::runtime::handle::Handle::enter::h2561e6addc5ea36b
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/runtime/handle.rs:76:9
[INFO] [stdout]   47:     0x5f596e0fd2fa - tokio::runtime::Runtime::block_on::h37c0a714137444b2
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/runtime/mod.rs:441:21
[INFO] [stdout]   48:     0x5f596e0fd016 - tokio::task::local::LocalSet::block_on::h9102c5299d55487b
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-0.2.24/src/task/local.rs:353:12
[INFO] [stdout]   49:     0x5f596e0fecee - actix_rt::runtime::Runtime::block_on::h48a51ef926e6e661
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/actix-rt-1.1.1/src/runtime.rs:89:20
[INFO] [stdout]   50:     0x5f596e0d613e - actix_rt::builder::SystemRunner::block_on::hcc535fb5609228bd
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/actix-rt-1.1.1/src/builder.rs:187:27
[INFO] [stdout]   51:     0x5f596e0e2a8c - dnd_character::store::test::file_persistence::ha21bd520bca7cf44
[INFO] [stdout]                                at /opt/rustwide/workdir/src/store.rs:87:5
[INFO] [stdout]   52:     0x5f596e0e3637 - dnd_character::store::test::file_persistence::{{closure}}::hf81c07cfea103fae
[INFO] [stdout]                                at /opt/rustwide/workdir/src/store.rs:88:32
[INFO] [stdout]   53:     0x5f596e0ed396 - core::ops::function::FnOnce::call_once::h50f76bdb056b292e
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   54:     0x5f596e16428b - <fn() -> core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String> as core[10b6fa85044e1869]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   55:     0x5f596e16428b - test[826cbc6ef54ab466]::__rust_begin_short_backtrace::<core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String>, fn() -> core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:663:18
[INFO] [stdout]   56:     0x5f596e170c7b - test[826cbc6ef54ab466]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:686:74
[INFO] [stdout]   57:     0x5f596e170c7b - <core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<test[826cbc6ef54ab466]::run_test_in_process::{closure#0}> as core[10b6fa85044e1869]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   58:     0x5f596e170c7b - std[b80a194dd3c418bb]::panicking::catch_unwind::do_call::<core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<test[826cbc6ef54ab466]::run_test_in_process::{closure#0}>, core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:581:40
[INFO] [stdout]   59:     0x5f596e170c7b - std[b80a194dd3c418bb]::panicking::catch_unwind::<core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String>, core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<test[826cbc6ef54ab466]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:544:19
[INFO] [stdout]   60:     0x5f596e170c7b - std[b80a194dd3c418bb]::panic::catch_unwind::<core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<test[826cbc6ef54ab466]::run_test_in_process::{closure#0}>, core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panic.rs:359:14
[INFO] [stdout]   61:     0x5f596e170c7b - test[826cbc6ef54ab466]::run_test_in_process
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:686:27
[INFO] [stdout]   62:     0x5f596e170c7b - test[826cbc6ef54ab466]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:607:43
[INFO] [stdout]   63:     0x5f596e16c394 - test[826cbc6ef54ab466]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:637:41
[INFO] [stdout]   64:     0x5f596e16c394 - std[b80a194dd3c418bb]::sys::backtrace::__rust_begin_short_backtrace::<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   65:     0x5f596e173882 - std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked::<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   66:     0x5f596e173882 - <core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[10b6fa85044e1869]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   67:     0x5f596e173882 - std[b80a194dd3c418bb]::panicking::catch_unwind::do_call::<core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:581:40
[INFO] [stdout]   68:     0x5f596e173882 - std[b80a194dd3c418bb]::panicking::catch_unwind::<(), core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:544:19
[INFO] [stdout]   69:     0x5f596e173882 - std[b80a194dd3c418bb]::panic::catch_unwind::<core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panic.rs:359:14
[INFO] [stdout]   70:     0x5f596e173882 - std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked::<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   71:     0x5f596e173882 - <std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1} as core[10b6fa85044e1869]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   72:     0x5f596e287adf - <alloc[dd269455e567d8e9]::boxed::Box<dyn core[10b6fa85044e1869]::ops::function::FnOnce<(), Output = ()> + core[10b6fa85044e1869]::marker::Send> as core[10b6fa85044e1869]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/alloc/src/boxed.rs:2240:9
[INFO] [stdout]   73:     0x5f596e287adf - <std[b80a194dd3c418bb]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   74:     0x731757606aa4 - <unknown>
[INFO] [stdout]   75:     0x731757693a64 - clone
[INFO] [stdout]   76:                0x0 - <unknown>
[INFO] [stdout] Panic in Arbiter thread.
[INFO] [stdout] 
[INFO] [stdout] ---- character::class::test::test_proficiency stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'character::class::test::test_proficiency' (17) panicked at src/character/class.rs:118:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: 4
[INFO] [stdout]  right: 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5f596e28855a - std[b80a194dd3c418bb]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5f596e28855a - std[b80a194dd3c418bb]::backtrace_rs::backtrace::trace_unsynchronized::<std[b80a194dd3c418bb]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5f596e28855a - std[b80a194dd3c418bb]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5f596e28855a - <<std[b80a194dd3c418bb]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[10b6fa85044e1869]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5f596e29cc9a - <core[10b6fa85044e1869]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5f596e29cc9a - core[10b6fa85044e1869]::fmt::write
[INFO] [stdout]    6:     0x5f596e28d072 - std[b80a194dd3c418bb]::io::default_write_fmt::<alloc[dd269455e567d8e9]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5f596e28d072 - <alloc[dd269455e567d8e9]::vec::Vec<u8> as std[b80a194dd3c418bb]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5f596e265b9f - <std[b80a194dd3c418bb]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5f596e265b9f - std[b80a194dd3c418bb]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5f596e27fff9 - std[b80a194dd3c418bb]::panicking::default_hook
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5f596e1701ac - <alloc[dd269455e567d8e9]::boxed::Box<dyn for<'a, 'b> core[10b6fa85044e1869]::ops::function::Fn<(&'a std[b80a194dd3c418bb]::panic::PanicHookInfo<'b>,), Output = ()> + core[10b6fa85044e1869]::marker::Sync + core[10b6fa85044e1869]::marker::Send> as core[10b6fa85044e1869]::ops::function::Fn<(&std[b80a194dd3c418bb]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/alloc/src/boxed.rs:2254:9
[INFO] [stdout]   12:     0x5f596e1701ac - test[826cbc6ef54ab466]::test_main_with_exit_callback::<test[826cbc6ef54ab466]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5f596e2801b2 - <alloc[dd269455e567d8e9]::boxed::Box<dyn for<'a, 'b> core[10b6fa85044e1869]::ops::function::Fn<(&'a std[b80a194dd3c418bb]::panic::PanicHookInfo<'b>,), Output = ()> + core[10b6fa85044e1869]::marker::Sync + core[10b6fa85044e1869]::marker::Send> as core[10b6fa85044e1869]::ops::function::Fn<(&std[b80a194dd3c418bb]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/alloc/src/boxed.rs:2254:9
[INFO] [stdout]   14:     0x5f596e2801b2 - std[b80a194dd3c418bb]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5f596e265c58 - std[b80a194dd3c418bb]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x5f596e25d399 - std[b80a194dd3c418bb]::sys::backtrace::__rust_end_short_backtrace::<std[b80a194dd3c418bb]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5f596e26696d - __rustc[9698a3e60dd14283]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5f596e29d5ac - core[10b6fa85044e1869]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5f596e29d433 - core[10b6fa85044e1869]::panicking::assert_failed_inner
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/panicking.rs:439:17
[INFO] [stdout]   20:     0x5f596e0fb285 - core::panicking::assert_failed::hcbd9862da9affc76
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x5f596e0cc1d0 - dnd_character::character::class::test::assert_proficiency::h302b2189595d6762
[INFO] [stdout]                                at /opt/rustwide/workdir/src/character/class.rs:118:9
[INFO] [stdout]   22:     0x5f596e0ecfe3 - core::ops::function::FnMut::call_mut::h1cdd05cf928cabad
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/ops/function.rs:166:5
[INFO] [stdout]   23:     0x5f596e0f0826 - core::iter::traits::iterator::Iterator::for_each::call::{{closure}}::hf32283266248936a
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/iter/traits/iterator.rs:842:29
[INFO] [stdout]   24:     0x5f596e0c7caf - <alloc::vec::into_iter::IntoIter<T,A> as core::iter::traits::iterator::Iterator>::fold::h75877109b3e0f172
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/alloc/src/vec/into_iter.rs:328:25
[INFO] [stdout]   25:     0x5f596e0c8b26 - core::iter::traits::iterator::Iterator::for_each::hf7ca9d07c1a7684e
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/iter/traits/iterator.rs:845:14
[INFO] [stdout]   26:     0x5f596e0cc058 - dnd_character::character::class::test::test_proficiency::h9f14ad0ca8704a5f
[INFO] [stdout]                                at /opt/rustwide/workdir/src/character/class.rs:145:10
[INFO] [stdout]   27:     0x5f596e0cc097 - dnd_character::character::class::test::test_proficiency::{{closure}}::h35c2f74745ed9896
[INFO] [stdout]                                at /opt/rustwide/workdir/src/character/class.rs:121:26
[INFO] [stdout]   28:     0x5f596e0ed586 - core::ops::function::FnOnce::call_once::ha7af9f3e553a405c
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   29:     0x5f596e16428b - <fn() -> core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String> as core[10b6fa85044e1869]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   30:     0x5f596e16428b - test[826cbc6ef54ab466]::__rust_begin_short_backtrace::<core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String>, fn() -> core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:663:18
[INFO] [stdout]   31:     0x5f596e170c7b - test[826cbc6ef54ab466]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:686:74
[INFO] [stdout]   32:     0x5f596e170c7b - <core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<test[826cbc6ef54ab466]::run_test_in_process::{closure#0}> as core[10b6fa85044e1869]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   33:     0x5f596e170c7b - std[b80a194dd3c418bb]::panicking::catch_unwind::do_call::<core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<test[826cbc6ef54ab466]::run_test_in_process::{closure#0}>, core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:581:40
[INFO] [stdout]   34:     0x5f596e170c7b - std[b80a194dd3c418bb]::panicking::catch_unwind::<core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String>, core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<test[826cbc6ef54ab466]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:544:19
[INFO] [stdout]   35:     0x5f596e170c7b - std[b80a194dd3c418bb]::panic::catch_unwind::<core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<test[826cbc6ef54ab466]::run_test_in_process::{closure#0}>, core[10b6fa85044e1869]::result::Result<(), alloc[dd269455e567d8e9]::string::String>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panic.rs:359:14
[INFO] [stdout]   36:     0x5f596e170c7b - test[826cbc6ef54ab466]::run_test_in_process
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:686:27
[INFO] [stdout]   37:     0x5f596e170c7b - test[826cbc6ef54ab466]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:607:43
[INFO] [stdout]   38:     0x5f596e16c394 - test[826cbc6ef54ab466]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/test/src/lib.rs:637:41
[INFO] [stdout]   39:     0x5f596e16c394 - std[b80a194dd3c418bb]::sys::backtrace::__rust_begin_short_backtrace::<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   40:     0x5f596e173882 - std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked::<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   41:     0x5f596e173882 - <core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[10b6fa85044e1869]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   42:     0x5f596e173882 - std[b80a194dd3c418bb]::panicking::catch_unwind::do_call::<core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:581:40
[INFO] [stdout]   43:     0x5f596e173882 - std[b80a194dd3c418bb]::panicking::catch_unwind::<(), core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panicking.rs:544:19
[INFO] [stdout]   44:     0x5f596e173882 - std[b80a194dd3c418bb]::panic::catch_unwind::<core[10b6fa85044e1869]::panic::unwind_safe::AssertUnwindSafe<std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/panic.rs:359:14
[INFO] [stdout]   45:     0x5f596e173882 - std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked::<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   46:     0x5f596e173882 - <std[b80a194dd3c418bb]::thread::lifecycle::spawn_unchecked<test[826cbc6ef54ab466]::run_test::{closure#1}, ()>::{closure#1} as core[10b6fa85044e1869]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x5f596e287adf - <alloc[dd269455e567d8e9]::boxed::Box<dyn core[10b6fa85044e1869]::ops::function::FnOnce<(), Output = ()> + core[10b6fa85044e1869]::marker::Send> as core[10b6fa85044e1869]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/alloc/src/boxed.rs:2240:9
[INFO] [stdout]   48:     0x5f596e287adf - <std[b80a194dd3c418bb]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/ad726b5063362ec9897ef3d67452fc5606ee70fa/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   49:     0x731757606aa4 - <unknown>
[INFO] [stdout]   50:     0x731757693a64 - clone
[INFO] [stdout]   51:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     character::class::test::test_proficiency
[INFO] [stdout]     store::test::file_persistence
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 3 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.27s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin dnd-character`
[INFO] running `Command { std: "docker" "inspect" "a50d0ea0aecf3d751864caac070a331daf08ddcbd7826201941ca662c9d512ec", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a50d0ea0aecf3d751864caac070a331daf08ddcbd7826201941ca662c9d512ec", kill_on_drop: false }`
[INFO] [stdout] a50d0ea0aecf3d751864caac070a331daf08ddcbd7826201941ca662c9d512ec
