[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-2025-09-21 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdgoetsch%2Fdnd-character" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-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-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/dgoetsch/dnd-character on toolchain beta-2025-09-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "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-2025-09-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 3d2152d240c1ccbe2279dfe84d3926f30d75eb63f8f1c636ba13e4718b3f0e7b
[INFO] running `Command { std: "docker" "start" "-a" "3d2152d240c1ccbe2279dfe84d3926f30d75eb63f8f1c636ba13e4718b3f0e7b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "3d2152d240c1ccbe2279dfe84d3926f30d75eb63f8f1c636ba13e4718b3f0e7b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3d2152d240c1ccbe2279dfe84d3926f30d75eb63f8f1c636ba13e4718b3f0e7b", kill_on_drop: false }`
[INFO] [stdout] 3d2152d240c1ccbe2279dfe84d3926f30d75eb63f8f1c636ba13e4718b3f0e7b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c80cb684e778f660f1767a538a5c0847252cc2db494ddd5672353170b44f664d
[INFO] running `Command { std: "docker" "start" "-a" "c80cb684e778f660f1767a538a5c0847252cc2db494ddd5672353170b44f664d", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.81
[INFO] [stderr]    Compiling cfg-if v0.1.10
[INFO] [stderr]    Compiling proc-macro2 v1.0.24
[INFO] [stderr]    Compiling unicode-xid v0.2.1
[INFO] [stderr]    Compiling log v0.4.11
[INFO] [stderr]    Compiling pkg-config v0.3.19
[INFO] [stderr]    Compiling lazy_static v1.4.0
[INFO] [stderr]    Compiling autocfg v1.0.1
[INFO] [stderr]    Compiling bitflags v1.2.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 byteorder v1.3.4
[INFO] [stderr]    Compiling futures-core v0.3.8
[INFO] [stderr]    Compiling libloading v0.6.6
[INFO] [stderr]    Compiling smallvec v1.5.1
[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 proc-macro-hack v0.5.19
[INFO] [stderr]    Compiling getrandom v0.1.15
[INFO] [stderr]    Compiling dlib v0.4.2
[INFO] [stderr]    Compiling proc-macro-nested v0.1.6
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]    Compiling wayland-sys v0.28.2
[INFO] [stderr]    Compiling futures-sink v0.3.8
[INFO] [stderr]    Compiling walkdir v2.3.1
[INFO] [stderr]    Compiling num-traits v0.2.14
[INFO] [stderr]    Compiling crossbeam-utils v0.8.1
[INFO] [stderr]    Compiling memoffset v0.6.1
[INFO] [stderr]    Compiling futures-task v0.3.8
[INFO] [stderr]    Compiling futures-channel v0.3.8
[INFO] [stderr]    Compiling nom v6.0.1
[INFO] [stderr]    Compiling ppv-lite86 v0.2.10
[INFO] [stderr]    Compiling scoped-tls v1.0.0
[INFO] [stderr]    Compiling const_fn v0.4.4
[INFO] [stderr]    Compiling downcast-rs v1.2.0
[INFO] [stderr]    Compiling ttf-parser v0.6.2
[INFO] [stderr]    Compiling khronos_api v3.1.0
[INFO] [stderr]    Compiling pin-project-lite v0.2.0
[INFO] [stderr]    Compiling quote v1.0.8
[INFO] [stderr]    Compiling instant v0.1.9
[INFO] [stderr]    Compiling rayon-core v1.9.0
[INFO] [stderr]    Compiling wayland-scanner v0.28.2
[INFO] [stderr]    Compiling static_assertions v1.1.0
[INFO] [stderr]    Compiling pathfinder_simd v0.5.0
[INFO] [stderr]    Compiling servo-fontconfig-sys v4.0.9
[INFO] [stderr]    Compiling lock_api v0.4.2
[INFO] [stderr]    Compiling ttf-parser v0.9.0
[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 parking_lot_core v0.8.2
[INFO] [stderr]    Compiling xdg v2.2.0
[INFO] [stderr]    Compiling gfx-hal v0.6.0
[INFO] [stderr]    Compiling rand_core v0.5.1
[INFO] [stderr]    Compiling cc v1.0.66
[INFO] [stderr]    Compiling parking_lot v0.11.1
[INFO] [stderr]    Compiling crossbeam-channel v0.5.0
[INFO] [stderr]    Compiling rand_chacha v0.2.2
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.1
[INFO] [stderr]    Compiling memmap2 v0.1.0
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]    Compiling rand v0.7.3
[INFO] [stderr]    Compiling crossbeam-deque v0.8.0
[INFO] [stderr]    Compiling rayon v1.5.0
[INFO] [stderr]    Compiling cmake v0.1.45
[INFO] [stderr]    Compiling maybe-uninit v2.0.0
[INFO] [stderr]    Compiling owned_ttf_parser v0.6.0
[INFO] [stderr]    Compiling rusttype v0.9.2
[INFO] [stderr]    Compiling wayland-client v0.28.2
[INFO] [stderr]    Compiling wayland-protocols v0.28.2
[INFO] [stderr]    Compiling dirs-sys v0.3.5
[INFO] [stderr]    Compiling fxhash v0.2.1
[INFO] [stderr]    Compiling xcursor v0.3.3
[INFO] [stderr]    Compiling twox-hash v1.6.0
[INFO] [stderr]    Compiling andrew v0.3.1
[INFO] [stderr]    Compiling glam v0.10.2
[INFO] [stderr]    Compiling servo-freetype-sys v4.0.5
[INFO] [stderr]    Compiling expat-sys v2.1.6
[INFO] [stderr]    Compiling owned_ttf_parser v0.9.0
[INFO] [stderr]    Compiling x11-dl v2.18.5
[INFO] [stderr]    Compiling x11 v2.18.2
[INFO] [stderr]    Compiling ab_glyph v0.2.7
[INFO] [stderr]    Compiling either v1.6.1
[INFO] [stderr]    Compiling iced_core v0.3.0
[INFO] [stderr]    Compiling freetype v0.4.1
[INFO] [stderr]    Compiling servo-fontconfig v0.4.0
[INFO] [stderr]    Compiling pathfinder_geometry v0.5.1
[INFO] [stderr]    Compiling dirs v2.0.2
[INFO] [stderr]    Compiling approx v0.4.0
[INFO] [stderr]    Compiling xcb v0.9.0
[INFO] [stderr]    Compiling net2 v0.2.37
[INFO] [stderr]    Compiling iovec v0.1.4
[INFO] [stderr]    Compiling xi-unicode v0.3.0
[INFO] [stderr]    Compiling unicode-segmentation v1.7.1
[INFO] [stderr]    Compiling cache-padded v1.1.1
[INFO] [stderr]    Compiling float-ord v0.2.0
[INFO] [stderr]    Compiling linked-hash-map v0.5.3
[INFO] [stderr]    Compiling arrayvec v0.5.2
[INFO] [stderr]    Compiling bit-vec v0.6.3
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling font-kit v0.8.0
[INFO] [stderr]    Compiling mio v0.6.23
[INFO] [stderr]    Compiling concurrent-queue v1.2.2
[INFO] [stderr]    Compiling glyph_brush_layout v0.2.1
[INFO] [stderr]    Compiling bit-set v0.5.2
[INFO] [stderr]    Compiling iced_style v0.2.0
[INFO] [stderr]    Compiling ordered-float v2.0.1
[INFO] [stderr]    Compiling spirv_headers v1.5.0
[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 winit v0.23.0
[INFO] [stderr]    Compiling parking v2.0.0
[INFO] [stderr]    Compiling waker-fn v1.1.0
[INFO] [stderr]    Compiling inplace_it v0.3.2
[INFO] [stderr]    Compiling fastrand v1.4.0
[INFO] [stderr]    Compiling gfx-memory v0.2.2
[INFO] [stderr]    Compiling wayland-commons v0.28.2
[INFO] [stderr]    Compiling calloop v0.6.5
[INFO] [stderr]    Compiling futures-lite v1.11.3
[INFO] [stderr]    Compiling gfx-backend-empty v0.6.0
[INFO] [stderr]    Compiling gfx-descriptor v0.2.0
[INFO] [stderr]    Compiling tracing v0.1.22
[INFO] [stderr]    Compiling mio-extras v2.0.6
[INFO] [stderr]    Compiling glutin_glx_sys v0.1.7
[INFO] [stderr]    Compiling glutin_egl_sys v0.1.5
[INFO] [stderr]    Compiling wgpu-types v0.6.1
[INFO] [stderr]    Compiling glyph_brush_draw_cache v0.1.3
[INFO] [stderr]    Compiling synstructure v0.12.4
[INFO] [stderr]    Compiling percent-encoding v2.1.0
[INFO] [stderr]    Compiling copyless v0.1.5
[INFO] [stderr]    Compiling glyph_brush v0.7.1
[INFO] [stderr]    Compiling euclid v0.22.1
[INFO] [stderr]    Compiling shared_library v0.1.9
[INFO] [stderr]    Compiling async-task v4.0.3
[INFO] [stderr]    Compiling serde_derive v1.0.118
[INFO] [stderr]    Compiling vec-arena v1.0.0
[INFO] [stderr]    Compiling event-listener v2.5.1
[INFO] [stderr]    Compiling typed-arena v2.0.1
[INFO] [stderr]    Compiling osmesa-sys v0.1.2
[INFO] [stderr]    Compiling nb-connect v1.0.2
[INFO] [stderr]    Compiling polling v2.0.2
[INFO] [stderr]    Compiling serde v1.0.118
[INFO] [stderr]    Compiling svg_fmt v0.4.1
[INFO] [stderr]    Compiling glow v0.6.1
[INFO] [stderr]    Compiling ryu v1.0.5
[INFO] [stderr]    Compiling async-executor v1.4.0
[INFO] [stderr]    Compiling async-channel v1.5.1
[INFO] [stderr]    Compiling guillotiere v0.6.0
[INFO] [stderr]    Compiling async-io v1.3.1
[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-mutex v1.4.0
[INFO] [stderr]    Compiling kv-log-macro v1.0.7
[INFO] [stderr]    Compiling itoa v0.4.7
[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 zerocopy-derive v0.2.0
[INFO] [stderr]    Compiling async-global-executor v1.4.3
[INFO] [stderr]    Compiling async-std v1.8.0
[INFO] [stderr]    Compiling bytemuck v1.4.1
[INFO] [stderr]    Compiling glow_glyph v0.4.0
[INFO] [stderr]    Compiling thiserror v1.0.23
[INFO] [stderr]    Compiling naga v0.2.0
[INFO] [stderr]    Compiling wayland-cursor v0.28.2
[INFO] [stderr]    Compiling wayland-egl v0.28.2
[INFO] [stderr]    Compiling pin-project v1.0.2
[INFO] [stderr]    Compiling zerocopy v0.3.0
[INFO] [stderr]    Compiling futures-util v0.3.8
[INFO] [stderr]    Compiling gfx-backend-vulkan v0.6.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 iced_native v0.3.0
[INFO] [stderr]    Compiling wgpu-core v0.6.5
[INFO] [stderr]    Compiling iced_graphics v0.1.0
[INFO] [stderr]    Compiling iced_glow v0.1.0
[INFO] [stderr]    Compiling clipboard_x11 v0.1.0
[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: `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: 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: `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: 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: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: 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: 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: `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: 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: 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: `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 2m 14s
[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 1`
[INFO] running `Command { std: "docker" "inspect" "c80cb684e778f660f1767a538a5c0847252cc2db494ddd5672353170b44f664d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c80cb684e778f660f1767a538a5c0847252cc2db494ddd5672353170b44f664d", kill_on_drop: false }`
[INFO] [stdout] c80cb684e778f660f1767a538a5c0847252cc2db494ddd5672353170b44f664d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a14b970d2e47c7a523b4f08ed0348e15f558a83abc0470650d35bf837ed9764e
[INFO] running `Command { std: "docker" "start" "-a" "a14b970d2e47c7a523b4f08ed0348e15f558a83abc0470650d35bf837ed9764e", kill_on_drop: false }`
[INFO] [stderr]    Compiling mio-uds v0.6.8
[INFO] [stderr]    Compiling derive_more v0.99.11
[INFO] [stderr]    Compiling threadpool v1.8.1
[INFO] [stderr]    Compiling signal-hook-registry v1.3.0
[INFO] [stderr]    Compiling pin-project-lite v0.1.11
[INFO] [stderr]    Compiling bytes v0.5.6
[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: `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: 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: `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: 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: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: 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: 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: `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: 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: 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: `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 8.54s
[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 1`
[INFO] running `Command { std: "docker" "inspect" "a14b970d2e47c7a523b4f08ed0348e15f558a83abc0470650d35bf837ed9764e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a14b970d2e47c7a523b4f08ed0348e15f558a83abc0470650d35bf837ed9764e", kill_on_drop: false }`
[INFO] [stdout] a14b970d2e47c7a523b4f08ed0348e15f558a83abc0470650d35bf837ed9764e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 7c9e2af3ac8d7182fe8300ad41b798cb597fe382a31b01bb81f3f1f9f4e7852f
[INFO] running `Command { std: "docker" "start" "-a" "7c9e2af3ac8d7182fe8300ad41b798cb597fe382a31b01bb81f3f1f9f4e7852f", 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: `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: 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: `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: 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: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: 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: 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: `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: 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: 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: `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" --tests` to apply 48 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.34s
[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 1`
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/dnd_character-3952afd7c8f16586)
[INFO] [stdout] 
[INFO] [stdout] running 5 tests
[INFO] [stdout] test core::effect::test::wand_of_the_war_mage ... ok
[INFO] [stdout] test core::feature::test::generate_saving_throws ... ok
[INFO] [stdout] test core::ability_score::test::test_modifier ... ok
[INFO] [stdout] test character::class::test::test_proficiency ... FAILED
[INFO] [stdout] test store::test::file_persistence ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- character::class::test::test_proficiency stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'character::class::test::test_proficiency' (24) 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:     0x622498f21792 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x622498f21792 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x622498f21792 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x622498f21792 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h67edf0e4d33c343c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x622498f31dff - core::fmt::rt::Argument::fmt::hef94184842aeafdd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x622498f31dff - core::fmt::write::hcf0c66b48a8fa606
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x622498eeda71 - std::io::default_write_fmt::h69967ac0ba93195f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x622498eeda71 - std::io::Write::write_fmt::h8db9396209deaa1c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x622498efa4b2 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x622498eff42f - std::panicking::default_hook::{{closure}}::h91001850288db5f7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x622498eff2c1 - std::panicking::default_hook::h2346dbb704ef5512
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x622498e00c3e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h18383b2e29377420
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   12:     0x622498e00c3e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x622498effaef - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h6dba6e441651a0d1
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   14:     0x622498effaef - std::panicking::panic_with_hook::hd2b063a6090d23a4
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x622498eff94a - std::panicking::panic_handler::{{closure}}::he666d95f139a333e
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13
[INFO] [stdout]   16:     0x622498efa5e9 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x622498ee128d - __rustc[1d67440d6e82e4f]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x622498f3a170 - core::panicking::panic_fmt::h420ddb7fd73daf53
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x622498f39f23 - core::panicking::assert_failed_inner::h448e1d534f4c3d4b
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:439:17
[INFO] [stdout]   20:     0x622498d77856 - core::panicking::assert_failed::hf8530d5d68b2a517
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x622498d4de15 - dnd_character::character::class::test::assert_proficiency::had50014b5a3f41a1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/character/class.rs:118:9
[INFO] [stdout]   22:     0x622498d50c53 - core::ops::function::FnMut::call_mut::h0e2ed3dff30604de
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:166:5
[INFO] [stdout]   23:     0x622498d77246 - core::iter::traits::iterator::Iterator::for_each::call::{{closure}}::h5ca292bd52e5568f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/iter/traits/iterator.rs:824:29
[INFO] [stdout]   24:     0x622498d3d86e - <alloc::vec::into_iter::IntoIter<T,A> as core::iter::traits::iterator::Iterator>::fold::hdac0993887d46d57
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/vec/into_iter.rs:323:25
[INFO] [stdout]   25:     0x622498d3e986 - core::iter::traits::iterator::Iterator::for_each::hf0d210322f004565
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/iter/traits/iterator.rs:827:14
[INFO] [stdout]   26:     0x622498d4dc9b - dnd_character::character::class::test::test_proficiency::h5afb86e835571dd2
[INFO] [stdout]                                at /opt/rustwide/workdir/src/character/class.rs:145:10
[INFO] [stdout]   27:     0x622498d4dce7 - dnd_character::character::class::test::test_proficiency::{{closure}}::ha98f6052dad939b6
[INFO] [stdout]                                at /opt/rustwide/workdir/src/character/class.rs:121:26
[INFO] [stdout]   28:     0x622498d512e6 - core::ops::function::FnOnce::call_once::h9cfece58bd2aad06
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   29:     0x622498e009fb - core::ops::function::FnOnce::call_once::h70887edf07a630ba
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   30:     0x622498e009fb - test::__rust_begin_short_backtrace::h27763c4cbbdb8601
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18
[INFO] [stdout]   31:     0x622498e16665 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74
[INFO] [stdout]   32:     0x622498e16665 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   33:     0x622498e16665 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   34:     0x622498e16665 - std::panicking::catch_unwind::hae1ec7bf94407afa
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   35:     0x622498e16665 - std::panic::catch_unwind::h0f4ff4773d84d3cd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   36:     0x622498e16665 - test::run_test_in_process::h03fbc77ae48b3f10
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27
[INFO] [stdout]   37:     0x622498e16665 - test::run_test::{{closure}}::h83476a9c453dc4d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43
[INFO] [stdout]   38:     0x622498dece54 - test::run_test::{{closure}}::h515482ad1e7fe7de
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41
[INFO] [stdout]   39:     0x622498dece54 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   40:     0x622498df071a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   41:     0x622498df071a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   42:     0x622498df071a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   43:     0x622498df071a - std::panicking::catch_unwind::h9e402d6a96fef41c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   44:     0x622498df071a - std::panic::catch_unwind::h9213c0c54aec70e0
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   45:     0x622498df071a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   46:     0x622498df071a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x622498ef574f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h2044e71c41d3958a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   48:     0x622498ef574f - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17
[INFO] [stdout]   49:     0x7f1477b76aa4 - <unknown>
[INFO] [stdout]   50:     0x7f1477c03a34 - clone
[INFO] [stdout]   51:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- store::test::file_persistence stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'store::test::file_persistence' (28) 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:     0x622498f21792 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x622498f21792 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x622498f21792 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x622498f21792 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h67edf0e4d33c343c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x622498f31dff - core::fmt::rt::Argument::fmt::hef94184842aeafdd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x622498f31dff - core::fmt::write::hcf0c66b48a8fa606
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x622498eeda71 - std::io::default_write_fmt::h69967ac0ba93195f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x622498eeda71 - std::io::Write::write_fmt::h8db9396209deaa1c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x622498efa4b2 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x622498eff42f - std::panicking::default_hook::{{closure}}::h91001850288db5f7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x622498eff2c1 - std::panicking::default_hook::h2346dbb704ef5512
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x622498e00c3e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h18383b2e29377420
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   12:     0x622498e00c3e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x622498effaef - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h6dba6e441651a0d1
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   14:     0x622498effaef - std::panicking::panic_with_hook::hd2b063a6090d23a4
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x622498eff94a - std::panicking::panic_handler::{{closure}}::he666d95f139a333e
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13
[INFO] [stdout]   16:     0x622498efa5e9 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x622498ee128d - __rustc[1d67440d6e82e4f]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x622498f3a170 - core::panicking::panic_fmt::h420ddb7fd73daf53
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x622498f39646 - core::result::unwrap_failed::hdde076be853d034f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5
[INFO] [stdout]   20:     0x622498d589ae - core::result::Result<T,E>::unwrap::hcd11be826f448168
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23
[INFO] [stdout]   21:     0x622498d589ae - dnd_character::store::test::file_persistence::{{closure}}::h28a121b9329fa333
[INFO] [stdout]                                at /opt/rustwide/workdir/src/store.rs:92:56
[INFO] [stdout]   22:     0x622498d475d6 - <tokio::task::local::RunUntil<T> as core::future::future::Future>::poll::{{closure}}::{{closure}}::ha5f2cf34263c890b
[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:     0x622498d5e770 - tokio::coop::with_budget::{{closure}}::hab558bc6f8e319cb
[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:     0x622498d76b95 - std::thread::local::LocalKey<T>::try_with::hb8859e7967989d2e
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/local.rs:315:12
[INFO] [stdout]   25:     0x622498d75f1e - std::thread::local::LocalKey<T>::with::h19db44750a1404b6
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/local.rs:279:20
[INFO] [stdout]   26:     0x622498d474c2 - tokio::coop::with_budget::hafa75f46a40af2e5
[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:     0x622498d474c2 - tokio::coop::budget::h9530f78b8263acb1
[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:     0x622498d474c2 - <tokio::task::local::RunUntil<T> as core::future::future::Future>::poll::{{closure}}::hce0e2676610b7b22
[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:     0x622498d548cd - tokio::macros::scoped_tls::ScopedKey<T>::set::hbe58855a13dd353b
[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:     0x622498d43d17 - tokio::task::local::LocalSet::with::h80f75060897012d0
[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:     0x622498d4738b - <tokio::task::local::RunUntil<T> as core::future::future::Future>::poll::hb143d056d4db705a
[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:     0x622498d43f6d - tokio::task::local::LocalSet::run_until::{{closure}}::h0b9d93c2f83dc1f2
[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:     0x622498d552dd - tokio::runtime::basic_scheduler::BasicScheduler<P>::block_on::{{closure}}::{{closure}}::h5174817d573b9c08
[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:     0x622498d5e8a0 - tokio::coop::with_budget::{{closure}}::hdaa9fb10dc8f0fce
[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:     0x622498d76545 - std::thread::local::LocalKey<T>::try_with::h79268d4aebefd6b7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/local.rs:315:12
[INFO] [stdout]   36:     0x622498d75ece - std::thread::local::LocalKey<T>::with::h0b45e19b8d201cbd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/local.rs:279:20
[INFO] [stdout]   37:     0x622498d54df3 - tokio::coop::with_budget::hf220e4974eab0f31
[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:     0x622498d54df3 - tokio::coop::budget::hcd65dbc329bdb42a
[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:     0x622498d54df3 - tokio::runtime::basic_scheduler::BasicScheduler<P>::block_on::{{closure}}::h28d0830e0a56abde
[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:     0x622498d557ae - tokio::runtime::basic_scheduler::enter::{{closure}}::h64548dc1a70053ae
[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:     0x622498d549e7 - tokio::macros::scoped_tls::ScopedKey<T>::set::hc388ff666753d0a6
[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:     0x622498d55718 - tokio::runtime::basic_scheduler::enter::hccb218f1cfd07b83
[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:     0x622498d54b40 - tokio::runtime::basic_scheduler::BasicScheduler<P>::block_on::h820b10018eb94193
[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:     0x622498d6a802 - tokio::runtime::Runtime::block_on::{{closure}}::h615a90b792de06b1
[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:     0x622498d77afb - tokio::runtime::context::enter::h7724f557d35889ec
[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:     0x622498d5eaba - tokio::runtime::handle::Handle::enter::hd54ef4677ee50baa
[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:     0x622498d6a77a - tokio::runtime::Runtime::block_on::h496eea277c42ed29
[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:     0x622498d43d5b - tokio::task::local::LocalSet::block_on::h4fef87a8eff77365
[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:     0x622498d4761a - actix_rt::runtime::Runtime::block_on::h70c527045854016f
[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:     0x622498d5bc9e - actix_rt::builder::SystemRunner::block_on::hdfce7243cbe085d2
[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:     0x622498d586ac - dnd_character::store::test::file_persistence::h8533d90d129d1d95
[INFO] [stdout]                                at /opt/rustwide/workdir/src/store.rs:87:5
[INFO] [stdout]   52:     0x622498d592a7 - dnd_character::store::test::file_persistence::{{closure}}::h3e210a6a9a2830e0
[INFO] [stdout]                                at /opt/rustwide/workdir/src/store.rs:88:32
[INFO] [stdout]   53:     0x622498d51256 - core::ops::function::FnOnce::call_once::h8e418dbc68a999fd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   54:     0x622498e009fb - core::ops::function::FnOnce::call_once::h70887edf07a630ba
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   55:     0x622498e009fb - test::__rust_begin_short_backtrace::h27763c4cbbdb8601
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18
[INFO] [stdout]   56:     0x622498e16665 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74
[INFO] [stdout]   57:     0x622498e16665 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   58:     0x622498e16665 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   59:     0x622498e16665 - std::panicking::catch_unwind::hae1ec7bf94407afa
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   60:     0x622498e16665 - std::panic::catch_unwind::h0f4ff4773d84d3cd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   61:     0x622498e16665 - test::run_test_in_process::h03fbc77ae48b3f10
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27
[INFO] [stdout]   62:     0x622498e16665 - test::run_test::{{closure}}::h83476a9c453dc4d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43
[INFO] [stdout]   63:     0x622498dece54 - test::run_test::{{closure}}::h515482ad1e7fe7de
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41
[INFO] [stdout]   64:     0x622498dece54 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   65:     0x622498df071a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   66:     0x622498df071a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   67:     0x622498df071a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   68:     0x622498df071a - std::panicking::catch_unwind::h9e402d6a96fef41c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   69:     0x622498df071a - std::panic::catch_unwind::h9213c0c54aec70e0
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   70:     0x622498df071a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   71:     0x622498df071a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   72:     0x622498ef574f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h2044e71c41d3958a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   73:     0x622498ef574f - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17
[INFO] [stdout]   74:     0x7f1477b76aa4 - <unknown>
[INFO] [stdout]   75:     0x7f1477c03a34 - clone
[INFO] [stdout]   76:                0x0 - <unknown>
[INFO] [stdout] Panic in Arbiter thread.
[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.15s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin dnd-character`
[INFO] running `Command { std: "docker" "inspect" "7c9e2af3ac8d7182fe8300ad41b798cb597fe382a31b01bb81f3f1f9f4e7852f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7c9e2af3ac8d7182fe8300ad41b798cb597fe382a31b01bb81f3f1f9f4e7852f", kill_on_drop: false }`
[INFO] [stdout] 7c9e2af3ac8d7182fe8300ad41b798cb597fe382a31b01bb81f3f1f9f4e7852f
