[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 1.90.0 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-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/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-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/dgoetsch/dnd-character on toolchain 1.90.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "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" "+1.90.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded quote v1.0.8
[INFO] [stderr]   Downloaded thiserror-impl v1.0.23
[INFO] [stderr]   Downloaded proc-macro-nested v0.1.6
[INFO] [stderr]   Downloaded itoa v0.4.7
[INFO] [stderr]   Downloaded thiserror v1.0.23
[INFO] [stderr]   Downloaded derivative v2.1.1
[INFO] [stderr]   Downloaded iced_core v0.3.0
[INFO] [stderr]   Downloaded futures-core v0.3.8
[INFO] [stderr]   Downloaded async-task v4.0.3
[INFO] [stderr]   Downloaded atomic-waker v1.0.0
[INFO] [stderr]   Downloaded blocking v1.0.2
[INFO] [stderr]   Downloaded pathfinder_simd v0.5.0
[INFO] [stderr]   Downloaded actix-threadpool v0.3.3
[INFO] [stderr]   Downloaded actix-macros v0.1.3
[INFO] [stderr]   Downloaded iced_graphics v0.1.0
[INFO] [stderr]   Downloaded glutin_emscripten_sys v0.1.1
[INFO] [stderr]   Downloaded iced_web v0.3.0
[INFO] [stderr]   Downloaded mio-uds v0.6.8
[INFO] [stderr]   Downloaded glutin v0.25.1
[INFO] [stderr]   Downloaded bytes v0.5.6
[INFO] [stderr]   Downloaded rayon-core v1.9.0
[INFO] [stderr]   Downloaded tokio v0.2.24
[INFO] [stderr]   Downloaded bumpalo v2.6.0
[INFO] [stderr]   Downloaded rayon v1.5.0
[INFO] [stderr]   Downloaded gfx-backend-metal v0.6.5
[INFO] [stderr]   Downloaded ttf-parser v0.9.0
[INFO] [stderr]   Downloaded xi-unicode v0.3.0
[INFO] [stderr]   Downloaded wgpu-core v0.6.5
[INFO] [stderr]   Downloaded wgpu v0.6.2
[INFO] [stderr]   Downloaded idna v0.2.0
[INFO] [stderr]   Downloaded ash v0.31.0
[INFO] [stderr]   Downloaded unicode-normalization v0.1.16
[INFO] [stderr]   Downloaded crossbeam-channel v0.5.0
[INFO] [stderr]   Downloaded naga v0.2.0
[INFO] [stderr]   Downloaded glyph_brush v0.7.1
[INFO] [stderr]   Downloaded gfx-backend-dx11 v0.6.17
[INFO] [stderr]   Downloaded gfx-backend-dx12 v0.6.13
[INFO] [stderr]   Downloaded x11 v2.18.2
[INFO] [stderr]   Downloaded wgpu_glyph v0.10.0
[INFO] [stderr]   Downloaded euclid v0.22.1
[INFO] [stderr]   Downloaded gfx-backend-vulkan v0.6.5
[INFO] [stderr]   Downloaded spirv_cross v0.22.2
[INFO] [stderr]   Downloaded zerocopy-derive v0.2.0
[INFO] [stderr]   Downloaded expat-sys v2.1.6
[INFO] [stderr]   Downloaded gfx-hal v0.6.0
[INFO] [stderr]   Downloaded tracing v0.1.22
[INFO] [stderr]   Downloaded iced_glow v0.1.0
[INFO] [stderr]   Downloaded metal v0.20.0
[INFO] [stderr]   Downloaded dodrio v0.2.0
[INFO] [stderr]   Downloaded ordered-float v2.0.1
[INFO] [stderr]   Downloaded tracing-core v0.1.17
[INFO] [stderr]   Downloaded crossbeam-utils v0.8.1
[INFO] [stderr]   Downloaded rust-argon2 v0.8.3
[INFO] [stderr]   Downloaded freetype v0.4.1
[INFO] [stderr]   Downloaded form_urlencoded v1.0.0
[INFO] [stderr]   Downloaded tinyvec v1.1.0
[INFO] [stderr]   Downloaded url v2.2.0
[INFO] [stderr]   Downloaded guillotiere v0.6.0
[INFO] [stderr]   Downloaded crossbeam-epoch v0.9.1
[INFO] [stderr]   Downloaded glyph_brush_draw_cache v0.1.3
[INFO] [stderr]   Downloaded copyless v0.1.5
[INFO] [stderr]   Downloaded blake2b_simd v0.5.11
[INFO] [stderr]   Downloaded dirs-sys v0.3.5
[INFO] [stderr]   Downloaded linked-hash-map v0.5.3
[INFO] [stderr]   Downloaded const_fn v0.4.4
[INFO] [stderr]   Downloaded ab_glyph v0.2.7
[INFO] [stderr]   Downloaded glyph_brush_layout v0.2.1
[INFO] [stderr]   Downloaded thunderdome v0.3.0
[INFO] [stderr]   Downloaded storage-map v0.3.0
[INFO] [stderr]   Downloaded spirv_headers v1.5.0
[INFO] [stderr]   Downloaded pin-project-lite v0.2.0
[INFO] [stderr]   Downloaded zerocopy v0.3.0
[INFO] [stderr]   Downloaded iced_wgpu v0.3.0
[INFO] [stderr]   Downloaded bytemuck_derive v1.0.1
[INFO] [stderr]   Downloaded bytemuck v1.4.1
[INFO] [stderr]   Downloaded core-text v15.0.0
[INFO] [stderr]   Downloaded arrayref v0.3.6
[INFO] [stderr]   Downloaded redox_users v0.3.5
[INFO] [stderr]   Downloaded dirs v2.0.2
[INFO] [stderr]   Downloaded wio v0.2.2
[INFO] [stderr]   Downloaded dwrote v0.11.0
[INFO] [stderr]   Downloaded pathfinder_geometry v0.5.1
[INFO] [stderr]   Downloaded cmake v0.1.45
[INFO] [stderr]   Downloaded font-kit v0.8.0
[INFO] [stderr]   Downloaded glutin_gles2_sys v0.1.5
[INFO] [stderr]   Downloaded futures-util v0.3.8
[INFO] [stderr]   Downloaded glutin_glx_sys v0.1.7
[INFO] [stderr]   Downloaded glutin_wgl_sys v0.1.5
[INFO] [stderr]   Downloaded servo-fontconfig-sys v4.0.9
[INFO] [stderr]   Downloaded wayland-egl v0.28.2
[INFO] [stderr]   Downloaded iced_glutin v0.1.0
[INFO] [stderr]   Downloaded wgpu-types v0.6.1
[INFO] [stderr]   Downloaded servo-freetype-sys v4.0.5
[INFO] [stderr]   Downloaded longest-increasing-subsequence v0.1.0
[INFO] [stderr]   Downloaded svg_fmt v0.4.1
[INFO] [stderr]   Downloaded memoffset v0.6.1
[INFO] [stderr]   Downloaded crossbeam-deque v0.8.0
[INFO] [stderr]   Downloaded owned_ttf_parser v0.9.0
[INFO] [stderr]   Downloaded typed-arena v2.0.1
[INFO] [stderr]   Downloaded d3d12 v0.3.2
[INFO] [stderr]   Downloaded gfx-backend-empty v0.6.0
[INFO] [stderr]   Downloaded gfx-auxil v0.7.0
[INFO] [stderr]   Downloaded range-alloc v0.1.1
[INFO] [stderr]   Downloaded inplace_it v0.3.2
[INFO] [stderr]   Downloaded bit-set v0.5.2
[INFO] [stderr]   Downloaded gfx-memory v0.2.2
[INFO] [stderr]   Downloaded synstructure v0.12.4
[INFO] [stderr]   Downloaded float-ord v0.2.0
[INFO] [stderr]   Downloaded derive_more v0.99.11
[INFO] [stderr]   Downloaded pin-project-lite v0.1.11
[INFO] [stderr]   Downloaded async-executor v1.4.0
[INFO] [stderr]   Downloaded async-global-executor v1.4.3
[INFO] [stderr]   Downloaded wepoll-sys v3.0.1
[INFO] [stderr]   Downloaded polling v2.0.2
[INFO] [stderr]   Downloaded vec-arena v1.0.0
[INFO] [stderr]   Downloaded async-mutex v1.4.0
[INFO] [stderr]   Downloaded approx v0.4.0
[INFO] [stderr]   Downloaded gfx-descriptor v0.2.0
[INFO] [stderr]   Downloaded constant_time_eq v0.1.5
[INFO] [stderr]   Downloaded signal-hook-registry v1.3.0
[INFO] [stderr]   Downloaded actix-rt v1.1.1
[INFO] [stderr]   Downloaded nb-connect v1.0.2
[INFO] [stderr]   Downloaded async-io v1.3.1
[INFO] [stderr]   Downloaded cache-padded v1.1.1
[INFO] [stderr]   Downloaded concurrent-queue v1.2.2
[INFO] [stderr]   Downloaded event-listener v2.5.1
[INFO] [stderr]   Downloaded async-channel v1.5.1
[INFO] [stderr]   Downloaded async-std v1.8.0
[INFO] [stderr]   Downloaded glow v0.6.1
[INFO] [stderr]   Downloaded glow_glyph v0.4.0
[INFO] [stderr]   Downloaded glam v0.10.2
[INFO] [stderr]   Downloaded futures-channel v0.3.8
[INFO] [stderr]   Downloaded xcb v0.9.0
[INFO] [stderr]   Downloaded smithay-client-toolkit v0.12.1
[INFO] [stderr]   Downloaded libc v0.2.81
[INFO] [stderr]   Downloaded bumpalo v3.4.0
[INFO] [stderr]   Downloaded wayland-client v0.28.2
[INFO] [stderr]   Downloaded winit v0.23.0
[INFO] [stderr]   Downloaded iced_style v0.2.0
[INFO] [stderr]   Downloaded web-sys v0.3.46
[INFO] [stderr]   Downloaded fastrand v1.4.0
[INFO] [stderr]   Downloaded parking v2.0.0
[INFO] [stderr]   Downloaded futures-lite v1.11.3
[INFO] [stderr]   Downloaded gloo-timers v0.2.1
[INFO] [stderr]   Downloaded cgl v0.3.2
[INFO] [stderr]   Downloaded servo-fontconfig v0.4.0
[INFO] [stderr]   Downloaded wayland-protocols v0.28.2
[INFO] [stderr]   Downloaded nix v0.18.0
[INFO] [stderr]   Downloaded waker-fn v1.1.0
[INFO] [stderr]   Downloaded glutin_egl_sys v0.1.5
[INFO] [stderr]   Downloaded js-sys v0.3.46
[INFO] [stderr]   Downloaded wasm-bindgen v0.2.69
[INFO] [stderr]   Downloaded twox-hash v1.6.0
[INFO] [stderr]   Downloaded iced_native v0.3.0
[INFO] [stderr]   Downloaded objc-foundation v0.1.1
[INFO] [stderr]   Downloaded cocoa v0.23.0
[INFO] [stderr]   Downloaded core-foundation-sys v0.8.2
[INFO] [stderr]   Downloaded core-foundation v0.9.1
[INFO] [stderr]   Downloaded dispatch v0.2.0
[INFO] [stderr]   Downloaded ndk-sys v0.2.1
[INFO] [stderr]   Downloaded ttf-parser v0.6.2
[INFO] [stderr]   Downloaded nom v6.0.1
[INFO] [stderr]   Downloaded cc v1.0.66
[INFO] [stderr]   Downloaded once_cell v1.5.2
[INFO] [stderr]   Downloaded smallvec v1.5.1
[INFO] [stderr]   Downloaded wayland-commons v0.28.2
[INFO] [stderr]   Downloaded x11-dl v2.18.5
[INFO] [stderr]   Downloaded iced_winit v0.2.0
[INFO] [stderr]   Downloaded futures-io v0.3.8
[INFO] [stderr]   Downloaded futures-sink v0.3.8
[INFO] [stderr]   Downloaded futures-task v0.3.8
[INFO] [stderr]   Downloaded pin-project-internal v1.0.2
[INFO] [stderr]   Downloaded futures v0.3.8
[INFO] [stderr]   Downloaded wasm-bindgen-backend v0.2.69
[INFO] [stderr]   Downloaded wasm-bindgen-shared v0.2.69
[INFO] [stderr]   Downloaded wasm-bindgen-macro-support v0.2.69
[INFO] [stderr]   Downloaded wasm-bindgen-macro v0.2.69
[INFO] [stderr]   Downloaded wasm-bindgen-futures v0.4.19
[INFO] [stderr]   Downloaded iced_futures v0.2.0
[INFO] [stderr]   Downloaded ppv-lite86 v0.2.10
[INFO] [stderr]   Downloaded getrandom v0.1.15
[INFO] [stderr]   Downloaded error-code v2.0.2
[INFO] [stderr]   Downloaded str-buf v1.0.5
[INFO] [stderr]   Downloaded clipboard-win v4.0.3
[INFO] [stderr]   Downloaded objc_id v0.1.1
[INFO] [stderr]   Downloaded clipboard_macos v0.1.0
[INFO] [stderr]   Downloaded smithay-clipboard v0.6.2
[INFO] [stderr]   Downloaded clipboard_wayland v0.1.2
[INFO] [stderr]   Downloaded window_clipboard v0.1.3
[INFO] [stderr]   Downloaded cocoa-foundation v0.1.0
[INFO] [stderr]   Downloaded core-graphics-types v0.1.1
[INFO] [stderr]   Downloaded core-graphics v0.22.2
[INFO] [stderr]   Downloaded core-graphics v0.19.2
[INFO] [stderr]   Downloaded core-video-sys v0.1.4
[INFO] [stderr]   Downloaded jni-sys v0.3.0
[INFO] [stderr]   Downloaded num_enum v0.4.3
[INFO] [stderr]   Downloaded strsim v0.9.3
[INFO] [stderr]   Downloaded darling_core v0.10.2
[INFO] [stderr]   Downloaded objc_exception v0.1.2
[INFO] [stderr]   Downloaded lock_api v0.4.2
[INFO] [stderr]   Downloaded redox_syscall v0.1.57
[INFO] [stderr]   Downloaded parking_lot v0.11.1
[INFO] [stderr]   Downloaded owned_ttf_parser v0.6.0
[INFO] [stderr]   Downloaded downcast-rs v1.2.0
[INFO] [stderr]   Downloaded xml-rs v0.8.3
[INFO] [stderr]   Downloaded wayland-scanner v0.28.2
[INFO] [stderr]   Downloaded libloading v0.6.6
[INFO] [stderr]   Downloaded dlib v0.4.2
[INFO] [stderr]   Downloaded iced v0.2.0
[INFO] [stderr]   Downloaded syn v1.0.56
[INFO] [stderr]   Downloaded futures-executor v0.3.8
[INFO] [stderr]   Downloaded futures-macro v0.3.8
[INFO] [stderr]   Downloaded pin-project v1.0.2
[INFO] [stderr]   Downloaded num_enum_derive v0.4.3
[INFO] [stderr]   Downloaded ndk v0.2.1
[INFO] [stderr]   Downloaded ndk-macro v0.2.0
[INFO] [stderr]   Downloaded instant v0.1.9
[INFO] [stderr]   Downloaded parking_lot_core v0.8.2
[INFO] [stderr]   Downloaded raw-window-handle v0.3.3
[INFO] [stderr]   Downloaded ab_glyph_rasterizer v0.1.4
[INFO] [stderr]   Downloaded andrew v0.3.1
[INFO] [stderr]   Downloaded calloop v0.6.5
[INFO] [stderr]   Downloaded memmap2 v0.1.0
[INFO] [stderr]   Downloaded version_check v0.9.2
[INFO] [stderr]   Downloaded wayland-cursor v0.28.2
[INFO] [stderr]   Downloaded serde v1.0.118
[INFO] [stderr]   Downloaded serde_json v1.0.61
[INFO] [stderr]   Downloaded darling_macro v0.10.2
[INFO] [stderr]   Downloaded darling v0.10.2
[INFO] [stderr]   Downloaded ndk-glue v0.2.1
[INFO] [stderr]   Downloaded rusttype v0.9.2
[INFO] [stderr]   Downloaded xcursor v0.3.3
[INFO] [stderr]   Downloaded serde_derive v1.0.118
[INFO] [stderr]   Downloaded clipboard_x11 v0.1.0
[INFO] [stderr]   Downloaded wayland-sys v0.28.2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] f008ec14f63f1e44713a77f9e21bb6bb3d971dcb1e7ba563e810a87cea040a41
[INFO] running `Command { std: "docker" "start" "-a" "f008ec14f63f1e44713a77f9e21bb6bb3d971dcb1e7ba563e810a87cea040a41", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "f008ec14f63f1e44713a77f9e21bb6bb3d971dcb1e7ba563e810a87cea040a41", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f008ec14f63f1e44713a77f9e21bb6bb3d971dcb1e7ba563e810a87cea040a41", kill_on_drop: false }`
[INFO] [stdout] f008ec14f63f1e44713a77f9e21bb6bb3d971dcb1e7ba563e810a87cea040a41
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+1.90.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 65a435151f6480147e55f8881a6f7057e867b02d7532436db61bebd63295ebee
[INFO] running `Command { std: "docker" "start" "-a" "65a435151f6480147e55f8881a6f7057e867b02d7532436db61bebd63295ebee", 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 smallvec v1.5.1
[INFO] [stderr]    Compiling libloading v0.6.6
[INFO] [stderr]    Compiling futures-core v0.3.8
[INFO] [stderr]    Compiling version_check v0.9.2
[INFO] [stderr]    Compiling slab v0.4.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 futures-sink v0.3.8
[INFO] [stderr]    Compiling nom v6.0.1
[INFO] [stderr]    Compiling futures-task v0.3.8
[INFO] [stderr]    Compiling futures-channel v0.3.8
[INFO] [stderr]    Compiling walkdir v2.3.1
[INFO] [stderr]    Compiling scoped-tls v1.0.0
[INFO] [stderr]    Compiling downcast-rs v1.2.0
[INFO] [stderr]    Compiling ppv-lite86 v0.2.10
[INFO] [stderr]    Compiling const_fn v0.4.4
[INFO] [stderr]    Compiling ttf-parser v0.6.2
[INFO] [stderr]    Compiling pin-project-lite v0.2.0
[INFO] [stderr]    Compiling khronos_api v3.1.0
[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 instant v0.1.9
[INFO] [stderr]    Compiling wayland-sys v0.28.2
[INFO] [stderr]    Compiling quote v1.0.8
[INFO] [stderr]    Compiling static_assertions v1.1.0
[INFO] [stderr]    Compiling rayon-core v1.9.0
[INFO] [stderr]    Compiling servo-fontconfig-sys v4.0.9
[INFO] [stderr]    Compiling pathfinder_simd v0.5.0
[INFO] [stderr]    Compiling lock_api v0.4.2
[INFO] [stderr]    Compiling ttf-parser v0.9.0
[INFO] [stderr]    Compiling xdg v2.2.0
[INFO] [stderr]    Compiling rayon v1.5.0
[INFO] [stderr]    Compiling maybe-uninit v2.0.0
[INFO] [stderr]    Compiling x11 v2.18.2
[INFO] [stderr]    Compiling wayland-scanner v0.28.2
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]    Compiling x11-dl v2.18.5
[INFO] [stderr]    Compiling fxhash v0.2.1
[INFO] [stderr]    Compiling glam v0.10.2
[INFO] [stderr]    Compiling iced_core v0.3.0
[INFO] [stderr]    Compiling owned_ttf_parser v0.6.0
[INFO] [stderr]    Compiling either v1.6.1
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.1
[INFO] [stderr]    Compiling crossbeam-channel v0.5.0
[INFO] [stderr]    Compiling rusttype v0.9.2
[INFO] [stderr]    Compiling approx v0.4.0
[INFO] [stderr]    Compiling crossbeam-deque v0.8.0
[INFO] [stderr]    Compiling linked-hash-map v0.5.3
[INFO] [stderr]    Compiling unicode-segmentation v1.7.1
[INFO] [stderr]    Compiling andrew v0.3.1
[INFO] [stderr]    Compiling jobserver v0.1.21
[INFO] [stderr]    Compiling num_cpus v1.13.0
[INFO] [stderr]    Compiling raw-window-handle v0.3.3
[INFO] [stderr]    Compiling parking_lot_core v0.8.2
[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 rand_chacha v0.2.2
[INFO] [stderr]    Compiling parking_lot v0.11.1
[INFO] [stderr]    Compiling owned_ttf_parser v0.9.0
[INFO] [stderr]    Compiling wayland-client v0.28.2
[INFO] [stderr]    Compiling wayland-protocols v0.28.2
[INFO] [stderr]    Compiling memmap2 v0.1.0
[INFO] [stderr]    Compiling ab_glyph v0.2.7
[INFO] [stderr]    Compiling dirs-sys v0.3.5
[INFO] [stderr]    Compiling pathfinder_geometry v0.5.1
[INFO] [stderr]    Compiling xcb v0.9.0
[INFO] [stderr]    Compiling dirs v2.0.2
[INFO] [stderr]    Compiling cmake v0.1.45
[INFO] [stderr]    Compiling rand v0.7.3
[INFO] [stderr]    Compiling xcursor v0.3.3
[INFO] [stderr]    Compiling net2 v0.2.37
[INFO] [stderr]    Compiling iovec v0.1.4
[INFO] [stderr]    Compiling cache-padded v1.1.1
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling float-ord v0.2.0
[INFO] [stderr]    Compiling bit-vec v0.6.3
[INFO] [stderr]    Compiling arrayvec v0.5.2
[INFO] [stderr]    Compiling xi-unicode v0.3.0
[INFO] [stderr]    Compiling mio v0.6.23
[INFO] [stderr]    Compiling concurrent-queue v1.2.2
[INFO] [stderr]    Compiling bit-set v0.5.2
[INFO] [stderr]    Compiling glyph_brush_layout v0.2.1
[INFO] [stderr]    Compiling servo-freetype-sys v4.0.5
[INFO] [stderr]    Compiling expat-sys v2.1.6
[INFO] [stderr]    Compiling twox-hash v1.6.0
[INFO] [stderr]    Compiling iced_style v0.2.0
[INFO] [stderr]    Compiling freetype v0.4.1
[INFO] [stderr]    Compiling ordered-float v2.0.1
[INFO] [stderr]    Compiling spirv_headers v1.5.0
[INFO] [stderr]    Compiling tracing-core v0.1.17
[INFO] [stderr]    Compiling servo-fontconfig v0.4.0
[INFO] [stderr]    Compiling ash v0.31.0
[INFO] [stderr]    Compiling font-kit v0.8.0
[INFO] [stderr]    Compiling parking v2.0.0
[INFO] [stderr]    Compiling winit v0.23.0
[INFO] [stderr]    Compiling lazycell v1.3.0
[INFO] [stderr]    Compiling waker-fn v1.1.0
[INFO] [stderr]    Compiling fastrand v1.4.0
[INFO] [stderr]    Compiling inplace_it v0.3.2
[INFO] [stderr]    Compiling mio-extras v2.0.6
[INFO] [stderr]    Compiling gfx-descriptor v0.2.0
[INFO] [stderr]    Compiling tracing v0.1.22
[INFO] [stderr]    Compiling gfx-memory v0.2.2
[INFO] [stderr]    Compiling futures-lite v1.11.3
[INFO] [stderr]    Compiling gfx-backend-empty v0.6.0
[INFO] [stderr]    Compiling glutin_glx_sys v0.1.7
[INFO] [stderr]    Compiling glutin_egl_sys v0.1.5
[INFO] [stderr]    Compiling glyph_brush_draw_cache v0.1.3
[INFO] [stderr]    Compiling wgpu-types v0.6.1
[INFO] [stderr]    Compiling percent-encoding v2.1.0
[INFO] [stderr]    Compiling synstructure v0.12.4
[INFO] [stderr]    Compiling glyph_brush v0.7.1
[INFO] [stderr]    Compiling copyless v0.1.5
[INFO] [stderr]    Compiling shared_library v0.1.9
[INFO] [stderr]    Compiling euclid v0.22.1
[INFO] [stderr]    Compiling event-listener v2.5.1
[INFO] [stderr]    Compiling vec-arena v1.0.0
[INFO] [stderr]    Compiling serde_derive v1.0.118
[INFO] [stderr]    Compiling typed-arena v2.0.1
[INFO] [stderr]    Compiling async-task v4.0.3
[INFO] [stderr]    Compiling wayland-commons v0.28.2
[INFO] [stderr]    Compiling calloop v0.6.5
[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 svg_fmt v0.4.1
[INFO] [stderr]    Compiling glow v0.6.1
[INFO] [stderr]    Compiling serde v1.0.118
[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 atomic-waker v1.0.0
[INFO] [stderr]    Compiling serde_json v1.0.61
[INFO] [stderr]    Compiling async-io v1.3.1
[INFO] [stderr]    Compiling guillotiere v0.6.0
[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 async-global-executor v1.4.3
[INFO] [stderr]    Compiling async-std v1.8.0
[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 bytemuck v1.4.1
[INFO] [stderr]    Compiling glow_glyph v0.4.0
[INFO] [stderr]    Compiling zerocopy v0.3.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 futures-util v0.3.8
[INFO] [stderr]    Compiling thiserror v1.0.23
[INFO] [stderr]    Compiling naga v0.2.0
[INFO] [stderr]    Compiling futures-executor v0.3.8
[INFO] [stderr]    Compiling futures v0.3.8
[INFO] [stderr]    Compiling gfx-backend-vulkan v0.6.5
[INFO] [stderr]    Compiling iced_futures v0.2.0
[INFO] [stderr]    Compiling iced_native v0.3.0
[INFO] [stderr]    Compiling iced_graphics v0.1.0
[INFO] [stderr]    Compiling clipboard_x11 v0.1.0
[INFO] [stderr]    Compiling iced_glow v0.1.0
[INFO] [stderr]    Compiling wgpu-core v0.6.5
[INFO] [stderr]    Compiling wgpu v0.6.2
[INFO] [stderr]    Compiling wgpu_glyph v0.10.0
[INFO] [stderr]    Compiling iced_wgpu v0.3.0
[INFO] [stderr]    Compiling smithay-client-toolkit v0.12.1
[INFO] [stderr]    Compiling smithay-clipboard v0.6.2
[INFO] [stderr]    Compiling clipboard_wayland v0.1.2
[INFO] [stderr]    Compiling window_clipboard v0.1.3
[INFO] [stderr]    Compiling iced_winit v0.2.0
[INFO] [stderr]    Compiling glutin v0.25.1
[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)]` 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)]` 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)]` 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)]` 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)]` 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)]` 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 10s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: nom v6.0.1
[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" "65a435151f6480147e55f8881a6f7057e867b02d7532436db61bebd63295ebee", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "65a435151f6480147e55f8881a6f7057e867b02d7532436db61bebd63295ebee", kill_on_drop: false }`
[INFO] [stdout] 65a435151f6480147e55f8881a6f7057e867b02d7532436db61bebd63295ebee
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+1.90.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0fc4fc8923979fea75b3372281598ca5788c2103aafcee740f602896cd7a76ac
[INFO] running `Command { std: "docker" "start" "-a" "0fc4fc8923979fea75b3372281598ca5788c2103aafcee740f602896cd7a76ac", 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 bytes v0.5.6
[INFO] [stderr]    Compiling pin-project-lite v0.1.11
[INFO] [stderr]    Compiling actix-macros v0.1.3
[INFO] [stderr]    Compiling tokio v0.2.24
[INFO] [stderr]    Compiling actix-threadpool v0.3.3
[INFO] [stderr]    Compiling actix-rt v1.1.1
[INFO] [stderr]    Compiling dnd-character v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/character/class.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 |         if (self.classes.len() > 1) {
[INFO] [stdout]    |            ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` 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)]` 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)]` 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)]` 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)]` 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)]` 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)]` 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.74s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: nom v6.0.1
[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" "0fc4fc8923979fea75b3372281598ca5788c2103aafcee740f602896cd7a76ac", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0fc4fc8923979fea75b3372281598ca5788c2103aafcee740f602896cd7a76ac", kill_on_drop: false }`
[INFO] [stdout] 0fc4fc8923979fea75b3372281598ca5788c2103aafcee740f602896cd7a76ac
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+1.90.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 016c630158613668ff5c83f9bec4eec7115103817a9a5969c5e8a5e9f238af2a
[INFO] running `Command { std: "docker" "start" "-a" "016c630158613668ff5c83f9bec4eec7115103817a9a5969c5e8a5e9f238af2a", 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)]` 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)]` 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)]` 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)]` 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)]` 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)]` 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)]` 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 40 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.39s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: nom v6.0.1
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/dnd_character-9a61a6687e6cdc4e)
[INFO] [stdout] running 5 tests
[INFO] [stdout] test core::effect::test::wand_of_the_war_mage ... ok
[INFO] [stdout] test core::ability_score::test::test_modifier ... ok
[INFO] [stdout] test core::feature::test::generate_saving_throws ... ok
[INFO] [stdout] test store::test::file_persistence ... FAILED
[INFO] [stdout] test character::class::test::test_proficiency ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- store::test::file_persistence stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'store::test::file_persistence' 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:     0x64b038433842 - std::backtrace_rs::backtrace::libunwind::trace::h2d45396358f41939
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x64b038433842 - std::backtrace_rs::backtrace::trace_unsynchronized::hffcefc0b67f1d6e2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x64b038433842 - std::sys::backtrace::_print_fmt::hd72f71d23b436b92
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x64b038433842 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::hdcfcb6d4c8489523
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x64b038459c13 - core::fmt::rt::Argument::fmt::h2c56b3114963061a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x64b038459c13 - core::fmt::write::h8a494366950f23bb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x64b038430483 - std::io::default_write_fmt::h7b8824096454f323
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x64b038430483 - std::io::Write::write_fmt::h4e71294925c334d0
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x64b038433692 - std::sys::backtrace::BacktraceLock::print::hb2a626a81e06b2dc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x64b038434e69 - std::panicking::default_hook::{{closure}}::h4f78485264f12d10
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x64b038434c9e - std::panicking::default_hook::h2c66fc99e962531d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x64b03833d4d4 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hb6bd65493727d71a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x64b03833d4d4 - test::test_main_with_exit_callback::{{closure}}::h60217ec76a0ece4a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x64b03843593e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h318e4efb8c1a5689
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x64b03843593e - std::panicking::rust_panic_with_hook::h33ac55f64bbd807d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x64b03843560a - std::panicking::begin_panic_handler::{{closure}}::h30e7cb89678a57fe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:706:13
[INFO] [stdout]   16:     0x64b038433d49 - std::sys::backtrace::__rust_end_short_backtrace::hed60f27456c16ced
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x64b03843529d - __rustc[de2ca18b4c54d5b8]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x64b0384582d0 - core::panicking::panic_fmt::h62f63d096dd276af
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x64b038458786 - core::result::unwrap_failed::h95bc3f5a607b2c95
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/result.rs:1765:5
[INFO] [stdout]   20:     0x64b03828a0ee - core::result::Result<T,E>::unwrap::h55937049e534bf8c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/result.rs:1167:23
[INFO] [stdout]   21:     0x64b03828a0ee - dnd_character::store::test::file_persistence::{{closure}}::h6ed520580de78b72
[INFO] [stdout]                                at /opt/rustwide/workdir/src/store.rs:92:56
[INFO] [stdout]   22:     0x64b038287966 - <tokio::task::local::RunUntil<T> as core::future::future::Future>::poll::{{closure}}::{{closure}}::hf1f6aeca3eb5f3c6
[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:     0x64b03826dc50 - tokio::coop::with_budget::{{closure}}::hafa8d106674f4afe
[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:     0x64b0382674b5 - std::thread::local::LocalKey<T>::try_with::hfe34a041e32c2aa6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/local.rs:315:12
[INFO] [stdout]   25:     0x64b0382663fe - std::thread::local::LocalKey<T>::with::h4bf38995dcad492b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/local.rs:279:20
[INFO] [stdout]   26:     0x64b038287852 - tokio::coop::with_budget::he31d7a81799c4329
[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:     0x64b038287852 - tokio::coop::budget::h0201de214d5b9989
[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:     0x64b038287852 - <tokio::task::local::RunUntil<T> as core::future::future::Future>::poll::{{closure}}::h1f612be8d142b4a9
[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:     0x64b03827c2dd - tokio::macros::scoped_tls::ScopedKey<T>::set::h6a42d08d828a16d6
[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:     0x64b038287317 - tokio::task::local::LocalSet::with::he13aa72974338704
[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:     0x64b03828771b - <tokio::task::local::RunUntil<T> as core::future::future::Future>::poll::h2e961837f5964ee8
[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:     0x64b03828756d - tokio::task::local::LocalSet::run_until::{{closure}}::h4a9bba77af6a085b
[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:     0x64b038267efd - tokio::runtime::basic_scheduler::BasicScheduler<P>::block_on::{{closure}}::{{closure}}::h6b0cb36141227d36
[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:     0x64b03826d9f0 - tokio::coop::with_budget::{{closure}}::h6822b656c45e49a9
[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:     0x64b038266ad5 - std::thread::local::LocalKey<T>::try_with::h50aad4a9b3217237
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/local.rs:315:12
[INFO] [stdout]   36:     0x64b0382663ae - std::thread::local::LocalKey<T>::with::h05c116995ca5beef
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/local.rs:279:20
[INFO] [stdout]   37:     0x64b038267963 - tokio::coop::with_budget::h5e1ca0d534ae5be8
[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:     0x64b038267963 - tokio::coop::budget::h1c621bf7aaa1692b
[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:     0x64b038267963 - tokio::runtime::basic_scheduler::BasicScheduler<P>::block_on::{{closure}}::hdedc2ec5324fc600
[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:     0x64b03826831e - tokio::runtime::basic_scheduler::enter::{{closure}}::h8177a5a80a8a1d1a
[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:     0x64b03827c1d7 - tokio::macros::scoped_tls::ScopedKey<T>::set::h14a8f1b2fbd013a3
[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:     0x64b038268288 - tokio::runtime::basic_scheduler::enter::h860586a890dd4d54
[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:     0x64b0382676b0 - tokio::runtime::basic_scheduler::BasicScheduler<P>::block_on::hc4863109df869714
[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:     0x64b03827c4d2 - tokio::runtime::Runtime::block_on::{{closure}}::h2bd80726bf3e791b
[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:     0x64b038299beb - tokio::runtime::context::enter::hb8ee4770144160b2
[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:     0x64b03826dd3a - tokio::runtime::handle::Handle::enter::hc6ee8916bd8dd707
[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:     0x64b03827c44a - tokio::runtime::Runtime::block_on::h410ec3bf25285335
[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:     0x64b03828735b - tokio::task::local::LocalSet::block_on::hfc81472f3c9d5c3d
[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:     0x64b03827280a - actix_rt::runtime::Runtime::block_on::hb69675579be9f353
[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:     0x64b038268b9e - actix_rt::builder::SystemRunner::block_on::h71fbbc8cee438855
[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:     0x64b038289dec - dnd_character::store::test::file_persistence::h14e3c90c800246d0
[INFO] [stdout]                                at /opt/rustwide/workdir/src/store.rs:87:5
[INFO] [stdout]   52:     0x64b038289d97 - dnd_character::store::test::file_persistence::{{closure}}::h971d7229d832780b
[INFO] [stdout]                                at /opt/rustwide/workdir/src/store.rs:88:32
[INFO] [stdout]   53:     0x64b038282676 - core::ops::function::FnOnce::call_once::h90bddb67d717228e
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   54:     0x64b038342d3b - core::ops::function::FnOnce::call_once::h1f9474f1347fff52
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   55:     0x64b038342d3b - test::__rust_begin_short_backtrace::ha52ab26e77157f03
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:648:18
[INFO] [stdout]   56:     0x64b038341e75 - test::run_test_in_process::{{closure}}::h229c1a11a50b261f
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:74
[INFO] [stdout]   57:     0x64b038341e75 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h78821afbf97b39a9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   58:     0x64b038341e75 - std::panicking::catch_unwind::do_call::h53abf3ed5bd32ba3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   59:     0x64b038341e75 - std::panicking::catch_unwind::h6deb5fe1e91873c9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   60:     0x64b038341e75 - std::panic::catch_unwind::hea0829b6b565654b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   61:     0x64b038341e75 - test::run_test_in_process::hdc44dfecea3db21b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:27
[INFO] [stdout]   62:     0x64b038341e75 - test::run_test::{{closure}}::h0364ba59bf23f652
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:592:43
[INFO] [stdout]   63:     0x64b038305a74 - test::run_test::{{closure}}::h32730b304eec05da
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:622:41
[INFO] [stdout]   64:     0x64b038305a74 - std::sys::backtrace::__rust_begin_short_backtrace::h177cb952fc54ad2c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   65:     0x64b03830944a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h119d903520007597
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   66:     0x64b03830944a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hab88401d606702a6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   67:     0x64b03830944a - std::panicking::catch_unwind::do_call::h163fe12cca9901c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   68:     0x64b03830944a - std::panicking::catch_unwind::he81557d0e17cc1bc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   69:     0x64b03830944a - std::panic::catch_unwind::hc2b8e79c20593955
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   70:     0x64b03830944a - std::thread::Builder::spawn_unchecked_::{{closure}}::hfa6b4978e07815cc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   71:     0x64b03830944a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hddcd7484a13fd793
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   72:     0x64b03843894f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h5924238c754de3b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   73:     0x64b03843894f - std::sys::pal::unix::thread::Thread::new::thread_start::hb6e99e73da4d28f8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/pal/unix/thread.rs:107:17
[INFO] [stdout]   74:     0x7dae52bc6aa4 - <unknown>
[INFO] [stdout]   75:     0x7dae52c53a34 - clone
[INFO] [stdout]   76:                0x0 - <unknown>
[INFO] [stdout] Panic in Arbiter thread.
[INFO] [stdout] 
[INFO] [stdout] ---- character::class::test::test_proficiency stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'character::class::test::test_proficiency' 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:     0x64b038433842 - std::backtrace_rs::backtrace::libunwind::trace::h2d45396358f41939
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x64b038433842 - std::backtrace_rs::backtrace::trace_unsynchronized::hffcefc0b67f1d6e2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x64b038433842 - std::sys::backtrace::_print_fmt::hd72f71d23b436b92
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x64b038433842 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::hdcfcb6d4c8489523
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x64b038459c13 - core::fmt::rt::Argument::fmt::h2c56b3114963061a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x64b038459c13 - core::fmt::write::h8a494366950f23bb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x64b038430483 - std::io::default_write_fmt::h7b8824096454f323
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x64b038430483 - std::io::Write::write_fmt::h4e71294925c334d0
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x64b038433692 - std::sys::backtrace::BacktraceLock::print::hb2a626a81e06b2dc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x64b038434e69 - std::panicking::default_hook::{{closure}}::h4f78485264f12d10
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x64b038434c9e - std::panicking::default_hook::h2c66fc99e962531d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x64b03833d4d4 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hb6bd65493727d71a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x64b03833d4d4 - test::test_main_with_exit_callback::{{closure}}::h60217ec76a0ece4a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x64b03843593e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h318e4efb8c1a5689
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x64b03843593e - std::panicking::rust_panic_with_hook::h33ac55f64bbd807d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x64b03843560a - std::panicking::begin_panic_handler::{{closure}}::h30e7cb89678a57fe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:706:13
[INFO] [stdout]   16:     0x64b038433d49 - std::sys::backtrace::__rust_end_short_backtrace::hed60f27456c16ced
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x64b03843529d - __rustc[de2ca18b4c54d5b8]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x64b0384582d0 - core::panicking::panic_fmt::h62f63d096dd276af
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x64b03845867c - core::panicking::assert_failed_inner::h102b4539a88470c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:448:17
[INFO] [stdout]   20:     0x64b038291b85 - core::panicking::assert_failed::hb70790a3548fa8b9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:403:5
[INFO] [stdout]   21:     0x64b038272b05 - dnd_character::character::class::test::assert_proficiency::h0a663f1ebb97e0f8
[INFO] [stdout]                                at /opt/rustwide/workdir/src/character/class.rs:118:9
[INFO] [stdout]   22:     0x64b038282113 - core::ops::function::FnMut::call_mut::haa7cdf8399889afe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:168:5
[INFO] [stdout]   23:     0x64b03828f766 - core::iter::traits::iterator::Iterator::for_each::call::{{closure}}::ha910d749acc84cc2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/iter/traits/iterator.rs:824:29
[INFO] [stdout]   24:     0x64b0382633de - <alloc::vec::into_iter::IntoIter<T,A> as core::iter::traits::iterator::Iterator>::fold::hf66f706279382801
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/vec/into_iter.rs:323:25
[INFO] [stdout]   25:     0x64b038264466 - core::iter::traits::iterator::Iterator::for_each::h69bfc61ab94c1d19
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/iter/traits/iterator.rs:827:14
[INFO] [stdout]   26:     0x64b0382741ab - dnd_character::character::class::test::test_proficiency::hee911f2bdd5e370f
[INFO] [stdout]                                at /opt/rustwide/workdir/src/character/class.rs:145:10
[INFO] [stdout]   27:     0x64b038272bb7 - dnd_character::character::class::test::test_proficiency::{{closure}}::h9cbb51e57f17fb1b
[INFO] [stdout]                                at /opt/rustwide/workdir/src/character/class.rs:121:26
[INFO] [stdout]   28:     0x64b0382823a6 - core::ops::function::FnOnce::call_once::h326f88b3dfc48654
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   29:     0x64b038342d3b - core::ops::function::FnOnce::call_once::h1f9474f1347fff52
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   30:     0x64b038342d3b - test::__rust_begin_short_backtrace::ha52ab26e77157f03
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:648:18
[INFO] [stdout]   31:     0x64b038341e75 - test::run_test_in_process::{{closure}}::h229c1a11a50b261f
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:74
[INFO] [stdout]   32:     0x64b038341e75 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h78821afbf97b39a9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   33:     0x64b038341e75 - std::panicking::catch_unwind::do_call::h53abf3ed5bd32ba3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   34:     0x64b038341e75 - std::panicking::catch_unwind::h6deb5fe1e91873c9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   35:     0x64b038341e75 - std::panic::catch_unwind::hea0829b6b565654b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   36:     0x64b038341e75 - test::run_test_in_process::hdc44dfecea3db21b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:27
[INFO] [stdout]   37:     0x64b038341e75 - test::run_test::{{closure}}::h0364ba59bf23f652
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:592:43
[INFO] [stdout]   38:     0x64b038305a74 - test::run_test::{{closure}}::h32730b304eec05da
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:622:41
[INFO] [stdout]   39:     0x64b038305a74 - std::sys::backtrace::__rust_begin_short_backtrace::h177cb952fc54ad2c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   40:     0x64b03830944a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h119d903520007597
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   41:     0x64b03830944a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hab88401d606702a6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   42:     0x64b03830944a - std::panicking::catch_unwind::do_call::h163fe12cca9901c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   43:     0x64b03830944a - std::panicking::catch_unwind::he81557d0e17cc1bc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   44:     0x64b03830944a - std::panic::catch_unwind::hc2b8e79c20593955
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   45:     0x64b03830944a - std::thread::Builder::spawn_unchecked_::{{closure}}::hfa6b4978e07815cc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   46:     0x64b03830944a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hddcd7484a13fd793
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   47:     0x64b03843894f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h5924238c754de3b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   48:     0x64b03843894f - std::sys::pal::unix::thread::Thread::new::thread_start::hb6e99e73da4d28f8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/pal/unix/thread.rs:107:17
[INFO] [stdout]   49:     0x7dae52bc6aa4 - <unknown>
[INFO] [stdout]   50:     0x7dae52c53a34 - clone
[INFO] [stdout]   51:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     character::class::test::test_proficiency
[INFO] [stdout]     store::test::file_persistence
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 3 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.13s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin dnd-character`
[INFO] running `Command { std: "docker" "inspect" "016c630158613668ff5c83f9bec4eec7115103817a9a5969c5e8a5e9f238af2a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "016c630158613668ff5c83f9bec4eec7115103817a9a5969c5e8a5e9f238af2a", kill_on_drop: false }`
[INFO] [stdout] 016c630158613668ff5c83f9bec4eec7115103817a9a5969c5e8a5e9f238af2a
