[INFO] cloning repository https://github.com/Idonotus/hex-fight
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Idonotus/hex-fight" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FIdonotus%2Fhex-fight", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FIdonotus%2Fhex-fight'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] b6f7f693f30ae67edec56eee8b9ff95715fc2291
[INFO] checking Idonotus/hex-fight against try#5f6abd89da253a562ad85d235b9342a3ac336c28 for pr-156114
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FIdonotus%2Fhex-fight" "/workspace/builds/worker-2-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Idonotus/hex-fight
[INFO] finished tweaking git repo https://github.com/Idonotus/hex-fight
[INFO] tweaked toml for git repo https://github.com/Idonotus/hex-fight written to /workspace/builds/worker-2-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Idonotus/hex-fight on toolchain 5f6abd89da253a562ad85d235b9342a3ac336c28
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+5f6abd89da253a562ad85d235b9342a3ac336c28" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Idonotus/hex-fight 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" "+5f6abd89da253a562ad85d235b9342a3ac336c28" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+5f6abd89da253a562ad85d235b9342a3ac336c28" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 5e87eaf0a887a85b2d629e76986ad4a6bb91850cad3162870005e52d8bdb41be
[INFO] running `Command { std: "docker" "start" "-a" "5e87eaf0a887a85b2d629e76986ad4a6bb91850cad3162870005e52d8bdb41be", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "5e87eaf0a887a85b2d629e76986ad4a6bb91850cad3162870005e52d8bdb41be", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5e87eaf0a887a85b2d629e76986ad4a6bb91850cad3162870005e52d8bdb41be", kill_on_drop: false }`
[INFO] [stdout] 5e87eaf0a887a85b2d629e76986ad4a6bb91850cad3162870005e52d8bdb41be
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+5f6abd89da253a562ad85d235b9342a3ac336c28" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0aada91286e733c3de7498d86aaaa885c828f397119f7d987c106f8fa3bff973
[INFO] running `Command { std: "docker" "start" "-a" "0aada91286e733c3de7498d86aaaa885c828f397119f7d987c106f8fa3bff973", kill_on_drop: false }`
[INFO] [stderr]    Compiling zerocopy v0.8.39
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]     Checking foldhash v0.2.0
[INFO] [stderr]    Compiling toml_datetime v0.7.5+spec-1.1.0
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling syn v2.0.116
[INFO] [stderr]     Checking bitflags v2.11.0
[INFO] [stderr]     Checking getrandom v0.3.4
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling getrandom v0.4.1
[INFO] [stderr]     Checking typewit v1.14.2
[INFO] [stderr]     Checking event-listener-strategy v0.5.4
[INFO] [stderr]     Checking spin v0.10.0
[INFO] [stderr]     Checking typeid v1.0.3
[INFO] [stderr]    Compiling slotmap v1.1.1
[INFO] [stderr]    Compiling erased-serde v0.4.9
[INFO] [stderr]     Checking futures-lite v2.6.1
[INFO] [stderr]     Checking disqualified v1.0.0
[INFO] [stderr]     Checking hashbrown v0.16.1
[INFO] [stderr]     Checking rand_core v0.9.5
[INFO] [stderr]     Checking fixedbitset v0.5.7
[INFO] [stderr]     Checking async-channel v2.5.0
[INFO] [stderr]     Checking const_panic v0.2.15
[INFO] [stderr]     Checking downcast-rs v2.0.2
[INFO] [stderr]     Checking bevy_ptr v0.18.0
[INFO] [stderr]     Checking uuid v1.21.0
[INFO] [stderr]     Checking inventory v0.3.22
[INFO] [stderr]    Compiling nix v0.31.1
[INFO] [stderr]     Checking crossbeam-queue v0.3.12
[INFO] [stderr]     Checking nonmax v0.5.5
[INFO] [stderr]     Checking bumpalo v3.20.2
[INFO] [stderr]     Checking tracing-core v0.1.36
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]     Checking regex-syntax v0.8.9
[INFO] [stderr]     Checking inotify v0.11.0
[INFO] [stderr]     Checking itertools v0.14.0
[INFO] [stderr]     Checking notify-types v2.1.0
[INFO] [stderr]     Checking piper v0.2.4
[INFO] [stderr]    Compiling blake3 v1.8.3
[INFO] [stderr]     Checking mio v1.1.1
[INFO] [stderr]     Checking sysinfo v0.37.2
[INFO] [stderr]     Checking async-lock v3.4.2
[INFO] [stderr]     Checking file-id v0.2.3
[INFO] [stderr]     Checking const-fnv1a-hash v1.1.0
[INFO] [stderr]     Checking futures-task v0.3.32
[INFO] [stderr]     Checking stackfuture v0.3.1
[INFO] [stderr]     Checking async-broadcast v0.7.2
[INFO] [stderr]     Checking atomicow v1.1.0
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking notify v8.2.0
[INFO] [stderr]     Checking flate2 v1.1.9
[INFO] [stderr]     Checking async-executor v1.14.0
[INFO] [stderr]     Checking blocking v1.6.2
[INFO] [stderr]     Checking pxfm v0.1.27
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]     Checking euclid v0.22.13
[INFO] [stderr]     Checking notify-debouncer-full v0.6.0
[INFO] [stderr]     Checking async-fs v2.2.0
[INFO] [stderr]     Checking core_maths v0.1.1
[INFO] [stderr]     Checking svg_fmt v0.4.5
[INFO] [stderr]     Checking rectangle-pack v0.4.2
[INFO] [stderr]     Checking const_soft_float v0.1.4
[INFO] [stderr]     Checking dlib v0.5.2
[INFO] [stderr]    Compiling wayland-sys v0.31.8
[INFO] [stderr]     Checking ttf-parser v0.25.1
[INFO] [stderr]     Checking ctrlc v3.5.2
[INFO] [stderr]    Compiling wayland-backend v0.3.12
[INFO] [stderr]     Checking png v0.18.1
[INFO] [stderr]    Compiling naga v27.0.3
[INFO] [stderr]     Checking bit-vec v0.8.0
[INFO] [stderr]     Checking codespan-reporting v0.12.0
[INFO] [stderr]     Checking constgebra v0.1.4
[INFO] [stderr]     Checking bit-set v0.8.0
[INFO] [stderr]     Checking spirv v0.3.0+sdk-1.3.268.0
[INFO] [stderr]     Checking memmap2 v0.9.10
[INFO] [stderr]    Compiling quick-xml v0.38.4
[INFO] [stderr]    Compiling wayland-client v0.31.12
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.2.0
[INFO] [stderr]    Compiling wgpu-hal v27.0.4
[INFO] [stderr]     Checking guillotiere v0.6.2
[INFO] [stderr]     Checking ordered-float v5.1.0
[INFO] [stderr]    Compiling wgpu-core v27.0.3
[INFO] [stderr]     Checking gpu-descriptor v0.3.2
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking regex-automata v0.4.14
[INFO] [stderr]     Checking roxmltree v0.20.0
[INFO] [stderr]    Compiling wgpu v27.0.1
[INFO] [stderr]     Checking yazi v0.2.1
[INFO] [stderr]     Checking zeno v0.3.3
[INFO] [stderr]     Checking rustix v0.38.44
[INFO] [stderr]     Checking sys-locale v0.3.2
[INFO] [stderr]     Checking unicode-linebreak v0.1.5
[INFO] [stderr]     Checking unicode-bidi v0.3.18
[INFO] [stderr]    Compiling toml_parser v1.0.9+spec-1.1.0
[INFO] [stderr]     Checking rangemap v1.7.1
[INFO] [stderr]     Checking unicode-script v0.5.8
[INFO] [stderr]     Checking radsort v0.1.1
[INFO] [stderr]     Checking fontconfig-parser v0.5.8
[INFO] [stderr]     Checking offset-allocator v0.2.0
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]    Compiling nix v0.30.1
[INFO] [stderr]     Checking accesskit v0.21.1
[INFO] [stderr]     Checking alsa-sys v0.3.1
[INFO] [stderr]    Compiling winit v0.30.12
[INFO] [stderr]    Compiling cpal v0.15.3
[INFO] [stderr]     Checking moxcms v0.7.11
[INFO] [stderr]     Checking ogg v0.8.0
[INFO] [stderr]     Checking alsa v0.9.1
[INFO] [stderr]     Checking x11-dl v2.21.0
[INFO] [stderr]     Checking xkbcommon-dl v0.4.2
[INFO] [stderr]    Compiling wayland-scanner v0.31.8
[INFO] [stderr]     Checking grid v1.0.0
[INFO] [stderr]    Compiling gilrs v0.11.1
[INFO] [stderr]     Checking lewton v0.10.2
[INFO] [stderr]    Compiling toml_edit v0.23.10+spec-1.0.0
[INFO] [stderr]     Checking taffy v0.9.2
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking fontdb v0.23.0
[INFO] [stderr]     Checking owned_ttf_parser v0.25.1
[INFO] [stderr]     Checking json v0.12.4
[INFO] [stderr]    Compiling encase_derive_impl v0.12.0
[INFO] [stderr]     Checking gilrs-core v0.6.7
[INFO] [stderr]    Compiling test-case-core v3.3.1
[INFO] [stderr]     Checking ab_glyph v0.2.32
[INFO] [stderr]    Compiling bevy_macro_utils v0.18.0
[INFO] [stderr]     Checking rodio v0.20.1
[INFO] [stderr]    Compiling bytemuck_derive v1.10.2
[INFO] [stderr]    Compiling zerocopy-derive v0.8.39
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling encase_derive v0.12.0
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]    Compiling bevy_reflect_derive v0.18.0
[INFO] [stderr]    Compiling assert_type_match v0.1.1
[INFO] [stderr]    Compiling variadics_please v1.1.0
[INFO] [stderr]    Compiling bevy_ecs_macros v0.18.0
[INFO] [stderr]    Compiling bevy_derive v0.18.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling futures-macro v0.3.32
[INFO] [stderr]    Compiling bevy_asset_macros v0.18.0
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking regex v1.12.3
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling bevy_encase_derive v0.18.0
[INFO] [stderr]    Compiling bevy_render_macros v0.18.0
[INFO] [stderr]     Checking futures-util v0.3.32
[INFO] [stderr]    Compiling bevy_gizmos_macros v0.18.0
[INFO] [stderr]     Checking thiserror v2.0.18
[INFO] [stderr]     Checking encase v0.12.0
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]     Checking tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling bevy_animation_macros v0.18.0
[INFO] [stderr]    Compiling bevy_state_macros v0.18.0
[INFO] [stderr]    Compiling enum_dict_derive v0.6.0
[INFO] [stderr]    Compiling test-case-macros v3.3.1
[INFO] [stderr]     Checking polling v3.11.0
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking bytemuck v1.25.0
[INFO] [stderr]     Checking gethostname v1.1.0
[INFO] [stderr]     Checking calloop v0.13.0
[INFO] [stderr]     Checking test-case v3.3.1
[INFO] [stderr]     Checking x11rb v0.13.2
[INFO] [stderr]     Checking image v0.25.9
[INFO] [stderr]     Checking font-types v0.10.1
[INFO] [stderr]     Checking tiny-skia-path v0.11.4
[INFO] [stderr]     Checking wayland-csd-frame v0.3.0
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking read-fonts v0.35.0
[INFO] [stderr]     Checking read-fonts v0.36.0
[INFO] [stderr]     Checking derive_more v2.1.1
[INFO] [stderr]     Checking wgpu-types v27.0.1
[INFO] [stderr]     Checking smol_str v0.2.2
[INFO] [stderr]     Checking bevy_platform v0.18.0
[INFO] [stderr]     Checking petgraph v0.8.3
[INFO] [stderr]     Checking ron v0.12.0
[INFO] [stderr]     Checking enum_dict v0.7.0
[INFO] [stderr]     Checking tiny-skia v0.11.4
[INFO] [stderr]     Checking bevy_utils v0.18.0
[INFO] [stderr]     Checking bevy_tasks v0.18.0
[INFO] [stderr]     Checking wayland-protocols v0.32.10
[INFO] [stderr]     Checking calloop-wayland-source v0.3.0
[INFO] [stderr]     Checking wayland-cursor v0.31.12
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking half v2.7.1
[INFO] [stderr]     Checking ahash v0.8.12
[INFO] [stderr]     Checking rand_chacha v0.9.0
[INFO] [stderr]     Checking rand v0.9.2
[INFO] [stderr]     Checking glam v0.30.10
[INFO] [stderr]     Checking rand_distr v0.5.1
[INFO] [stderr]     Checking skrifa v0.37.0
[INFO] [stderr]     Checking skrifa v0.39.0
[INFO] [stderr]     Checking harfrust v0.4.1
[INFO] [stderr]     Checking wayland-protocols-wlr v0.3.10
[INFO] [stderr]     Checking wayland-protocols-plasma v0.3.10
[INFO] [stderr]     Checking smithay-client-toolkit v0.19.2
[INFO] [stderr]     Checking swash v0.2.6
[INFO] [stderr]     Checking sctk-adwaita v0.10.1
[INFO] [stderr]     Checking cosmic-text v0.16.0
[INFO] [stderr]     Checking bevy_reflect v0.18.0
[INFO] [stderr]     Checking hexasphere v16.0.0
[INFO] [stderr]     Checking naga_oil v0.20.0
[INFO] [stderr]     Checking accesskit_winit v0.29.2
[INFO] [stderr]     Checking wgpu-core-deps-windows-linux-android v27.0.0
[INFO] [stderr]     Checking bevy_ecs v0.18.0
[INFO] [stderr]     Checking bevy_math v0.18.0
[INFO] [stderr]     Checking bevy_color v0.18.0
[INFO] [stderr]     Checking bevy_app v0.18.0
[INFO] [stderr]     Checking bevy_time v0.18.0
[INFO] [stderr]     Checking bevy_log v0.18.0
[INFO] [stderr]     Checking bevy_input v0.18.0
[INFO] [stderr]     Checking bevy_a11y v0.18.0
[INFO] [stderr]     Checking bevy_state v0.18.0
[INFO] [stderr]     Checking bevy_transform v0.18.0
[INFO] [stderr]     Checking bevy_diagnostic v0.18.0
[INFO] [stderr]     Checking bevy_asset v0.18.0
[INFO] [stderr]     Checking bevy_gilrs v0.18.0
[INFO] [stderr]     Checking bevy_image v0.18.0
[INFO] [stderr]     Checking bevy_mesh v0.18.0
[INFO] [stderr]     Checking bevy_shader v0.18.0
[INFO] [stderr]     Checking bevy_animation v0.18.0
[INFO] [stderr]     Checking bevy_audio v0.18.0
[INFO] [stderr]     Checking bevy_window v0.18.0
[INFO] [stderr]     Checking bevy_text v0.18.0
[INFO] [stderr]     Checking bevy_camera v0.18.0
[INFO] [stderr]     Checking bevy_picking v0.18.0
[INFO] [stderr]     Checking bevy_render v0.18.0
[INFO] [stderr]     Checking bevy_gizmos v0.18.0
[INFO] [stderr]     Checking bevy_scene v0.18.0
[INFO] [stderr]     Checking bevy_sprite v0.18.0
[INFO] [stderr]     Checking bevy_input_focus v0.18.0
[INFO] [stderr]     Checking bevy_winit v0.18.0
[INFO] [stderr]     Checking bevy_ui v0.18.0
[INFO] [stderr]     Checking bevy_core_pipeline v0.18.0
[INFO] [stderr]     Checking bevy_sprite_render v0.18.0
[INFO] [stderr]     Checking bevy_post_process v0.18.0
[INFO] [stderr]     Checking bevy_ui_render v0.18.0
[INFO] [stderr]     Checking bevy_gizmos_render v0.18.0
[INFO] [stderr]     Checking bevy_internal v0.18.0
[INFO] [stderr]     Checking bevy v0.18.0
[INFO] [stderr]     Checking hex-fight v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Vec3` and `transform::components::Transform`
[INFO] [stdout]   --> src/assets/mod.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 |     math::{Vec3, primitives::Rectangle},
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 11 |     transform::components::Transform,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `asset::VisitAssetDependencies`
[INFO] [stdout]  --> src/cardmenu.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 |     asset::VisitAssetDependencies,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `system::Commands`
[INFO] [stdout]  --> src/cardmenu/origins.rs:2:69
[INFO] [stdout]   |
[INFO] [stdout] 2 |     ecs::{component::Component, entity::Entity, resource::Resource, system::Commands},
[INFO] [stdout]   |                                                                     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/cardmenu.rs:89:17
[INFO] [stdout]    |
[INFO] [stdout] 89 |         let y = (amount / self.width + 1);
[INFO] [stdout]    |                 ^                       ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 89 -         let y = (amount / self.width + 1);
[INFO] [stdout] 89 +         let y = amount / self.width + 1 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/cardmenu.rs:280:17
[INFO] [stdout]     |
[INFO] [stdout] 280 |                 (Transform::from_translation(Vec3 {
[INFO] [stdout]     |                 ^
[INFO] [stdout] ...
[INFO] [stdout] 284 |                 })),
[INFO] [stdout]     |                   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 280 ~                 Transform::from_translation(Vec3 {
[INFO] [stdout] 281 |                     x: (tleft_box.x + card_size.x / 2.0),
[INFO] [stdout] 282 |                     y: -(tleft_box.y + card_size.y / 2.0),
[INFO] [stdout] 283 |                     z: grid_coord.0 as f32 * card_size.z,
[INFO] [stdout] 284 ~                 }) ,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `replace`
[INFO] [stdout]  --> src/engine/actions.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::mem::{ replace };
[INFO] [stdout]   |                 ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BaseBand`, `DeckCapacity`, and `DeckSize`
[INFO] [stdout]   --> src/engine/prelude.rs:14:28
[INFO] [stdout]    |
[INFO] [stdout] 14 |     AssignedBand, BandSet, BaseBand, DeckCapacity, DeckId as CardId, DeckSize, Stacks,
[INFO] [stdout]    |                            ^^^^^^^^  ^^^^^^^^^^^^                    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `color::palettes::basic`
[INFO] [stdout]   --> src/orchestrator.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     color::palettes::basic, ecs::system::SystemState, input::mouse::MouseWheel, prelude::*,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Vec3` and `transform::components::Transform`
[INFO] [stdout]   --> src/assets/mod.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 |     math::{Vec3, primitives::Rectangle},
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 11 |     transform::components::Transform,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `asset::VisitAssetDependencies`
[INFO] [stdout]  --> src/cardmenu.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 |     asset::VisitAssetDependencies,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `system::Commands`
[INFO] [stdout]  --> src/cardmenu/origins.rs:2:69
[INFO] [stdout]   |
[INFO] [stdout] 2 |     ecs::{component::Component, entity::Entity, resource::Resource, system::Commands},
[INFO] [stdout]   |                                                                     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/cardmenu.rs:89:17
[INFO] [stdout]    |
[INFO] [stdout] 89 |         let y = (amount / self.width + 1);
[INFO] [stdout]    |                 ^                       ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 89 -         let y = (amount / self.width + 1);
[INFO] [stdout] 89 +         let y = amount / self.width + 1 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/cardmenu.rs:280:17
[INFO] [stdout]     |
[INFO] [stdout] 280 |                 (Transform::from_translation(Vec3 {
[INFO] [stdout]     |                 ^
[INFO] [stdout] ...
[INFO] [stdout] 284 |                 })),
[INFO] [stdout]     |                   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 280 ~                 Transform::from_translation(Vec3 {
[INFO] [stdout] 281 |                     x: (tleft_box.x + card_size.x / 2.0),
[INFO] [stdout] 282 |                     y: -(tleft_box.y + card_size.y / 2.0),
[INFO] [stdout] 283 |                     z: grid_coord.0 as f32 * card_size.z,
[INFO] [stdout] 284 ~                 }) ,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `replace`
[INFO] [stdout]  --> src/engine/actions.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::mem::{ replace };
[INFO] [stdout]   |                 ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BaseBand`, `DeckCapacity`, and `DeckSize`
[INFO] [stdout]   --> src/engine/prelude.rs:14:28
[INFO] [stdout]    |
[INFO] [stdout] 14 |     AssignedBand, BandSet, BaseBand, DeckCapacity, DeckId as CardId, DeckSize, Stacks,
[INFO] [stdout]    |                            ^^^^^^^^  ^^^^^^^^^^^^                    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `color::palettes::basic`
[INFO] [stdout]   --> src/orchestrator.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     color::palettes::basic, ecs::system::SystemState, input::mouse::MouseWheel, prelude::*,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `g`
[INFO] [stdout]    --> src/mouse.rs:172:24
[INFO] [stdout]     |
[INFO] [stdout] 172 |     for (mut t, mut m, g) in followers {
[INFO] [stdout]     |                        ^ help: if this is intentional, prefix it with an underscore: `_g`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/orchestrator.rs:146:23
[INFO] [stdout]     |
[INFO] [stdout] 146 |     let (mut origins, mut meshes, mut colors) = SystemState::<(
[INFO] [stdout]     |                       ----^^^^^^
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/orchestrator.rs:146:35
[INFO] [stdout]     |
[INFO] [stdout] 146 |     let (mut origins, mut meshes, mut colors) = SystemState::<(
[INFO] [stdout]     |                                   ----^^^^^^
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `meshes`
[INFO] [stdout]    --> src/orchestrator.rs:146:23
[INFO] [stdout]     |
[INFO] [stdout] 146 |     let (mut origins, mut meshes, mut colors) = SystemState::<(
[INFO] [stdout]     |                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_meshes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `colors`
[INFO] [stdout]    --> src/orchestrator.rs:146:35
[INFO] [stdout]     |
[INFO] [stdout] 146 |     let (mut origins, mut meshes, mut colors) = SystemState::<(
[INFO] [stdout]     |                                   ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_colors`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `elements`
[INFO] [stdout]   --> src/resizeplugin.rs:14:66
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn resize_check(mut resize_reader: MessageReader<WindowResized>, elements: Query<&mut Sprite, With<Anchors>>) {
[INFO] [stdout]    |                                                                  ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_elements`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `last_msg`
[INFO] [stdout]   --> src/resizeplugin.rs:15:11
[INFO] [stdout]    |
[INFO] [stdout] 15 |     let Some(last_msg) = resize_reader.read().last() else {return;};
[INFO] [stdout]    |              ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_last_msg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `g`
[INFO] [stdout]    --> src/mouse.rs:172:24
[INFO] [stdout]     |
[INFO] [stdout] 172 |     for (mut t, mut m, g) in followers {
[INFO] [stdout]     |                        ^ help: if this is intentional, prefix it with an underscore: `_g`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `CardGrid` is more private than the item `CardLayout::grid`
[INFO] [stdout]    --> src/cardmenu.rs:24:5
[INFO] [stdout]     |
[INFO] [stdout]  24 |     fn grid(&self, amount: usize) -> CardGrid;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `CardLayout::grid` is reachable at visibility `pub(crate)`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `CardGrid` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/cardmenu.rs:158:1
[INFO] [stdout]     |
[INFO] [stdout] 158 | struct CardGrid {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `CardGrid` is more private than the item `<WidthLayout as CardLayout>::grid`
[INFO] [stdout]    --> src/cardmenu.rs:87:5
[INFO] [stdout]     |
[INFO] [stdout]  87 |     fn grid(&self, amount: usize) -> CardGrid {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `<WidthLayout as CardLayout>::grid` is reachable at visibility `pub(crate)`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `CardGrid` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/cardmenu.rs:158:1
[INFO] [stdout]     |
[INFO] [stdout] 158 | struct CardGrid {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `scheduler::Task<'a>` is more private than the item `Scheduler::<'a>::push_player_task`
[INFO] [stdout]    --> src/engine/scheduler.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub fn push_player_task(&mut self, player: PlayerId, task: Task<'a>) {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Scheduler::<'a>::push_player_task` is reachable at visibility `pub(crate)`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `scheduler::Task<'a>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/engine/scheduler.rs:5:1
[INFO] [stdout]     |
[INFO] [stdout]   5 | struct Task<'a> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `RelativeTask<'a>` is more private than the item `Scheduler::<'a>::schedule_task`
[INFO] [stdout]    --> src/engine/scheduler.rs:174:5
[INFO] [stdout]     |
[INFO] [stdout] 174 |     pub fn schedule_task(&mut self, task: RelativeTask<'a>) {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Scheduler::<'a>::schedule_task` is reachable at visibility `pub(crate)`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `RelativeTask<'a>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/engine/scheduler.rs:41:1
[INFO] [stdout]     |
[INFO] [stdout]  41 | struct RelativeTask<'a> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `AtlasIndex` is never constructed
[INFO] [stdout]   --> src/assets/cache.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub enum AssetReference {
[INFO] [stdout]    |          -------------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 22 |     AtlasIndex(String, usize),
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `index` is never read
[INFO] [stdout]   --> src/assets/cache.rs:59:9
[INFO] [stdout]    |
[INFO] [stdout] 57 |     AtlasMember {
[INFO] [stdout]    |     ----------- field in this variant
[INFO] [stdout] 58 |         parent: String,
[INFO] [stdout] 59 |         index: usize,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `check_index` is never used
[INFO] [stdout]    --> src/assets/cache.rs:221:12
[INFO] [stdout]     |
[INFO] [stdout]  98 | impl AssetCache {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 221 |     pub fn check_index(&self, assets: &Vec<String>) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Details` is never constructed
[INFO] [stdout]   --> src/assets/cardrender.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct Details {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_details` is never used
[INFO] [stdout]   --> src/assets/cardrender.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub trait Assetable {
[INFO] [stdout]    |           --------- method in this trait
[INFO] [stdout] 25 |     fn get_details(&self) -> Details;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `name` is never read
[INFO] [stdout]   --> src/cardmenu.rs:32:9
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct CardGroup {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] 32 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `remove_at_position`, `get_size`, and `new` are never used
[INFO] [stdout]    --> src/cardmenu.rs:185:8
[INFO] [stdout]     |
[INFO] [stdout] 184 | impl CardGrid {
[INFO] [stdout]     | ------------- associated items in this implementation
[INFO] [stdout] 185 |     fn remove_at_position(&mut self, position: (usize, usize)) -> Option<Entity> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 208 |     fn get_size(&self) -> Vec2 {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     fn new(
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Deck` and `TopCard` are never constructed
[INFO] [stdout]   --> src/cardmenu/origins.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub enum CardOrigin {
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] 10 |     Hand(PlayerId, usize),
[INFO] [stdout] 11 |     Deck(CardId),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 12 |     TopCard,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CardOrigin` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Deck` is never constructed
[INFO] [stdout]   --> src/cardmenu/origins.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum MenuOrigin {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] 17 |     Hand(PlayerId),
[INFO] [stdout] 18 |     Deck,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `deregister_card`, `get_origin`, and `delete_origin` are never used
[INFO] [stdout]   --> src/cardmenu/origins.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl CardUIOrigins {
[INFO] [stdout]    | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn deregister_card(&mut self, entity: &Entity) -> Option<CardOrigin> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn get_origin(&mut self, entity: &Entity) -> Option<CardOrigin> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 78 |     pub fn delete_origin(&mut self, origin: &CardOrigin) -> Vec<Entity> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Cap` is never used
[INFO] [stdout]  --> src/cardmenu/selection.rs:6:6
[INFO] [stdout]   |
[INFO] [stdout] 6 | enum Cap {
[INFO] [stdout]   |      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_capacity` and `set_capacity` are never used
[INFO] [stdout]   --> src/cardmenu/selection.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | impl Selections {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn get_capacity(&self) -> &Option<usize> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn set_capacity(&mut self, cap: Option<usize>) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `plugin` is never read
[INFO] [stdout]   --> src/content/basic_cards.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct AllColorBand {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 11 |     numeral: u8,
[INFO] [stdout] 12 |     plugin: AllColorPlugin,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_plugin` is never used
[INFO] [stdout]   --> src/content/basic_cards.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl AllColorBand {
[INFO] [stdout]    | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn get_plugin(&self) -> AllColorPlugin {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChooseColorCard` is never constructed
[INFO] [stdout]   --> src/content/basic_cards.rs:75:12
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub struct ChooseColorCard {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PluralBand` is never constructed
[INFO] [stdout]   --> src/content/basic_cards.rs:80:12
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub struct PluralBand<'a, Band, C>(pub Band, u64, PhantomData<&'a C>)
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/content/basic_cards.rs:88:8
[INFO] [stdout]    |
[INFO] [stdout] 84 | / impl<'a, Band, C> PluralBand<'a, Band, C>
[INFO] [stdout] 85 | | where
[INFO] [stdout] 86 | |     Band: AssignedBand<'a, C>,
[INFO] [stdout]    | |______________________________- associated function in this implementation
[INFO] [stdout] 87 |   {
[INFO] [stdout] 88 |       fn new(band: Band, amount: u64) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Predicate` is never used
[INFO] [stdout]   --> src/engine/mod.rs:16:18
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub(crate) trait Predicate<T> {
[INFO] [stdout]    |                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `draw` and `play_card` are never used
[INFO] [stdout]   --> src/engine/mod.rs:81:12
[INFO] [stdout]    |
[INFO] [stdout] 40 | / impl<'a, Band, Card> Game<'a, Band, Card>
[INFO] [stdout] 41 | | where
[INFO] [stdout] 42 | |     Card: Stacks,
[INFO] [stdout] 43 | |     Band: AssignedBand<'a, Card>,
[INFO] [stdout]    | |_________________________________- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 81 |       pub fn draw(&mut self, player: PlayerId) -> bool {
[INFO] [stdout]    |              ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 93 |       pub fn play_card(&mut self, player: PlayerId, hand_number: usize) {
[INFO] [stdout]    |              ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ContextItem` is never used
[INFO] [stdout]  --> src/engine/actions.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub enum ContextItem {
[INFO] [stdout]   |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ItemReference` is never constructed
[INFO] [stdout]   --> src/engine/actions.rs:82:12
[INFO] [stdout]    |
[INFO] [stdout] 82 | pub struct ItemReference {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ContextPredicate` is never used
[INFO] [stdout]   --> src/engine/actions.rs:88:10
[INFO] [stdout]    |
[INFO] [stdout] 88 | pub enum ContextPredicate {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `predicate_legal` is never used
[INFO] [stdout]   --> src/engine/actions.rs:99:4
[INFO] [stdout]    |
[INFO] [stdout] 99 | fn predicate_legal(a: &[ContextPredicate], b: &[ContextPredicate]) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Response` is never constructed
[INFO] [stdout]    --> src/engine/actions.rs:109:8
[INFO] [stdout]     |
[INFO] [stdout] 109 | struct Response<'a> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ResponseContext` is never constructed
[INFO] [stdout]    --> src/engine/actions.rs:115:8
[INFO] [stdout]     |
[INFO] [stdout] 115 | struct ResponseContext {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_predicates`, `allocate_from_vec`, `drop_level`, `reference_item`, `borrow_item`, and `return_item` are never used
[INFO] [stdout]    --> src/engine/actions.rs:122:5
[INFO] [stdout]     |
[INFO] [stdout] 121 | impl ResponseContext {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] 122 |     fn get_predicates(&self, params: &Vec<usize>) -> Vec<ContextPredicate> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 126 |     fn allocate_from_vec(&mut self, defaults: Vec<ContextItem>) -> Vec<usize> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     fn drop_level(&mut self) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 144 |     fn reference_item(&self, reference: usize) -> &ContextItem {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 148 |     fn borrow_item(&mut self, reference: usize) -> Result<ContextItem, &str> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 155 |     fn return_item(&mut self, reference: usize, item: ContextItem) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `append`, `pop`, and `handle_action` are never used
[INFO] [stdout]    --> src/engine/actions.rs:164:5
[INFO] [stdout]     |
[INFO] [stdout] 163 | impl<'a> Response<'a> {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] 164 |     fn append(&mut self, mut actions: Vec<Interaction<'a>>) {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     fn pop(&mut self) -> Interaction<'a> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 183 |     fn handle_action<'b>(&mut self, action: Box<dyn Action<'a> + 'b>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ActionResult` is never constructed
[INFO] [stdout]    --> src/engine/actions.rs:215:12
[INFO] [stdout]     |
[INFO] [stdout] 215 | pub struct ActionResult<'a> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Interaction` is never used
[INFO] [stdout]    --> src/engine/actions.rs:221:6
[INFO] [stdout]     |
[INFO] [stdout] 221 | enum Interaction<'a> {
[INFO] [stdout]     |      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Action` is never used
[INFO] [stdout]    --> src/engine/actions.rs:235:11
[INFO] [stdout]     |
[INFO] [stdout] 235 | pub trait Action<'a> {
[INFO] [stdout]     |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Display` is never used
[INFO] [stdout]    --> src/engine/actions.rs:241:10
[INFO] [stdout]     |
[INFO] [stdout] 241 | pub enum Display {
[INFO] [stdout]     |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Prompt` is never used
[INFO] [stdout]    --> src/engine/actions.rs:246:10
[INFO] [stdout]     |
[INFO] [stdout] 246 | pub enum Prompt {
[INFO] [stdout]     |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_max_size` is never used
[INFO] [stdout]    --> src/engine/cards.rs:103:8
[INFO] [stdout]     |
[INFO] [stdout]  99 | pub trait IdDeck {
[INFO] [stdout]     |           ------ method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 103 |     fn get_max_size(&self) -> DeckCapacity;
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `attempt_collapse` is never used
[INFO] [stdout]    --> src/engine/cards.rs:142:8
[INFO] [stdout]     |
[INFO] [stdout] 131 | impl RLEDeck {
[INFO] [stdout]     | ------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 142 |     fn attempt_collapse(&mut self, idx: usize) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Special` is never constructed
[INFO] [stdout]    --> src/engine/cards.rs:289:5
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub enum CardValue {
[INFO] [stdout]     |          --------- variant in this enum
[INFO] [stdout] 289 |     Special(usize),
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `CardValue` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_min_val` is never used
[INFO] [stdout]   --> src/engine/colors.rs:14:4
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn get_min_val(vals: &[f32; 3]) -> f32 {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_saturation` and `get_hue` are never used
[INFO] [stdout]   --> src/engine/colors.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl Color {
[INFO] [stdout]    | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn get_saturation(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn get_hue(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `exact_color_eq` is never used
[INFO] [stdout]   --> src/engine/colors.rs:68:8
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub fn exact_color_eq() -> ColorComparison<'static> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `phase` and `callback` are never read
[INFO] [stdout]  --> src/engine/scheduler.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | struct Task<'a> {
[INFO] [stdout]   |        ---- fields in this struct
[INFO] [stdout] 6 |     phase: TurnPhase,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 7 |     callback: Box<dyn Fn() -> () + 'a>,
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `TimerTask` is never used
[INFO] [stdout]   --> src/engine/scheduler.rs:10:7
[INFO] [stdout]    |
[INFO] [stdout] 10 | trait TimerTask<'a> {
[INFO] [stdout]    |       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `tracker` and `task` are never read
[INFO] [stdout]   --> src/engine/scheduler.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | struct PlayTask<'a> {
[INFO] [stdout]    |        -------- fields in this struct
[INFO] [stdout] 18 |     tracker: Tracker,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 19 |
[INFO] [stdout] 20 |     task: Task<'a>,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `tracker`, `pinpoint`, and `task` are never read
[INFO] [stdout]   --> src/engine/scheduler.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 41 | struct RelativeTask<'a> {
[INFO] [stdout]    |        ------------ fields in this struct
[INFO] [stdout] 42 |     tracker: Tracker,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 43 |     pinpoint: bool,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 44 |
[INFO] [stdout] 45 |     task: Task<'a>,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `is_done`, and `is_overdue` are never used
[INFO] [stdout]   --> src/engine/scheduler.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 85 | impl Tracker {
[INFO] [stdout]    | ------------ associated items in this implementation
[INFO] [stdout] 86 |     pub fn new(turns: isize) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 90 |     fn is_done(&self) -> bool {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 94 |     fn is_overdue(&self) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `plays` and `turns` are never read
[INFO] [stdout]    --> src/engine/scheduler.rs:100:5
[INFO] [stdout]     |
[INFO] [stdout]  99 | struct TurnCounter {
[INFO] [stdout]     |        ----------- fields in this struct
[INFO] [stdout] 100 |     plays: usize,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 101 |     turns: usize,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `tracker`, `direction`, `queue`, `play_queue`, and `playerqueue` are never read
[INFO] [stdout]    --> src/engine/scheduler.rs:112:5
[INFO] [stdout]     |
[INFO] [stdout] 110 | pub struct Scheduler<'a> {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 111 |     order: Vec<usize>,
[INFO] [stdout] 112 |     tracker: TurnCounter,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 113 |     cur_turn: usize,
[INFO] [stdout] 114 |     direction: isize,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout] 115 |
[INFO] [stdout] 116 |     queue: Vec<RelativeTask<'a>>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 117 |     play_queue: Vec<PlayTask<'a>>,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] 118 |     playerqueue: Vec<Vec<Task<'a>>>,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `reverse`, `go`, `tick`, `push_player_task`, `schedule_task`, and `pop_current_turn` are never used
[INFO] [stdout]    --> src/engine/scheduler.rs:138:12
[INFO] [stdout]     |
[INFO] [stdout] 121 | impl<'a> Scheduler<'a> {
[INFO] [stdout]     | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 138 |     pub fn reverse(&mut self) {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn go(&mut self, amount: usize) {
[INFO] [stdout]     |            ^^
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub fn tick(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 170 |     pub fn push_player_task(&mut self, player: PlayerId, task: Task<'a>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 174 |     pub fn schedule_task(&mut self, task: RelativeTask<'a>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 178 |     pub fn pop_current_turn(&mut self) -> ActionQueue<'a> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fetch_and_prune` is never used
[INFO] [stdout]    --> src/engine/scheduler.rs:193:4
[INFO] [stdout]     |
[INFO] [stdout] 193 | fn fetch_and_prune<'a>(tasks: &mut Vec<impl TimerTask<'a>>, queue: &mut ActionQueue<'a>) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ActionQueue` is never constructed
[INFO] [stdout]    --> src/engine/scheduler.rs:207:12
[INFO] [stdout]     |
[INFO] [stdout] 207 | pub struct ActionQueue<'a>(RequiredDict<TurnPhase, Vec<Box<dyn FnOnce() -> () + 'a>>>);
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `run` and `push` are never used
[INFO] [stdout]    --> src/engine/scheduler.rs:210:12
[INFO] [stdout]     |
[INFO] [stdout] 209 | impl<'a> ActionQueue<'a> {
[INFO] [stdout]     | ------------------------ methods in this implementation
[INFO] [stdout] 210 |     pub fn run(&mut self, phase: TurnPhase) {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 216 |     pub fn push(&mut self, phase: TurnPhase, callback: Box<dyn FnOnce() -> () + 'a>) -> () {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Hand` is never constructed
[INFO] [stdout]    --> src/orchestrator.rs:267:8
[INFO] [stdout]     |
[INFO] [stdout] 267 | struct Hand {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `NotInGame` is never constructed
[INFO] [stdout]    --> src/orchestrator.rs:300:5
[INFO] [stdout]     |
[INFO] [stdout] 299 | enum GameState {
[INFO] [stdout]     |      --------- variant in this enum
[INFO] [stdout] 300 |     NotInGame,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `GameState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `poses` and `reference` are never read
[INFO] [stdout]  --> src/resizeplugin.rs:8:6
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct Anchors {
[INFO] [stdout]   |            ------- fields in this struct
[INFO] [stdout] 8 |     pub poses: Rect,
[INFO] [stdout]   |         ^^^^^
[INFO] [stdout] 9 |     pub reference: Rect
[INFO] [stdout]   |         ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Resize` is never constructed
[INFO] [stdout]   --> src/resizeplugin.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | struct Resize(Vec2);
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/orchestrator.rs:146:23
[INFO] [stdout]     |
[INFO] [stdout] 146 |     let (mut origins, mut meshes, mut colors) = SystemState::<(
[INFO] [stdout]     |                       ----^^^^^^
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/orchestrator.rs:146:35
[INFO] [stdout]     |
[INFO] [stdout] 146 |     let (mut origins, mut meshes, mut colors) = SystemState::<(
[INFO] [stdout]     |                                   ----^^^^^^
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `meshes`
[INFO] [stdout]    --> src/orchestrator.rs:146:23
[INFO] [stdout]     |
[INFO] [stdout] 146 |     let (mut origins, mut meshes, mut colors) = SystemState::<(
[INFO] [stdout]     |                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_meshes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `colors`
[INFO] [stdout]    --> src/orchestrator.rs:146:35
[INFO] [stdout]     |
[INFO] [stdout] 146 |     let (mut origins, mut meshes, mut colors) = SystemState::<(
[INFO] [stdout]     |                                   ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_colors`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `std::result::Result` that must be used
[INFO] [stdout]    --> src/orchestrator.rs:106:5
[INFO] [stdout]     |
[INFO] [stdout] 106 |     images.insert(&img, BasePalette::gen_image(PALETTE_SIZE));
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 106 |     let _ = images.insert(&img, BasePalette::gen_image(PALETTE_SIZE));
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `elements`
[INFO] [stdout]   --> src/resizeplugin.rs:14:66
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn resize_check(mut resize_reader: MessageReader<WindowResized>, elements: Query<&mut Sprite, With<Anchors>>) {
[INFO] [stdout]    |                                                                  ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_elements`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `last_msg`
[INFO] [stdout]   --> src/resizeplugin.rs:15:11
[INFO] [stdout]    |
[INFO] [stdout] 15 |     let Some(last_msg) = resize_reader.read().last() else {return;};
[INFO] [stdout]    |              ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_last_msg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `CardGrid` is more private than the item `CardLayout::grid`
[INFO] [stdout]    --> src/cardmenu.rs:24:5
[INFO] [stdout]     |
[INFO] [stdout]  24 |     fn grid(&self, amount: usize) -> CardGrid;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `CardLayout::grid` is reachable at visibility `pub(crate)`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `CardGrid` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/cardmenu.rs:158:1
[INFO] [stdout]     |
[INFO] [stdout] 158 | struct CardGrid {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `CardGrid` is more private than the item `<WidthLayout as CardLayout>::grid`
[INFO] [stdout]    --> src/cardmenu.rs:87:5
[INFO] [stdout]     |
[INFO] [stdout]  87 |     fn grid(&self, amount: usize) -> CardGrid {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `<WidthLayout as CardLayout>::grid` is reachable at visibility `pub(crate)`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `CardGrid` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/cardmenu.rs:158:1
[INFO] [stdout]     |
[INFO] [stdout] 158 | struct CardGrid {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `scheduler::Task<'a>` is more private than the item `Scheduler::<'a>::push_player_task`
[INFO] [stdout]    --> src/engine/scheduler.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub fn push_player_task(&mut self, player: PlayerId, task: Task<'a>) {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Scheduler::<'a>::push_player_task` is reachable at visibility `pub(crate)`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `scheduler::Task<'a>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/engine/scheduler.rs:5:1
[INFO] [stdout]     |
[INFO] [stdout]   5 | struct Task<'a> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `RelativeTask<'a>` is more private than the item `Scheduler::<'a>::schedule_task`
[INFO] [stdout]    --> src/engine/scheduler.rs:174:5
[INFO] [stdout]     |
[INFO] [stdout] 174 |     pub fn schedule_task(&mut self, task: RelativeTask<'a>) {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ method `Scheduler::<'a>::schedule_task` is reachable at visibility `pub(crate)`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `RelativeTask<'a>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/engine/scheduler.rs:41:1
[INFO] [stdout]     |
[INFO] [stdout]  41 | struct RelativeTask<'a> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `AtlasIndex` is never constructed
[INFO] [stdout]   --> src/assets/cache.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub enum AssetReference {
[INFO] [stdout]    |          -------------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 22 |     AtlasIndex(String, usize),
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `index` is never read
[INFO] [stdout]   --> src/assets/cache.rs:59:9
[INFO] [stdout]    |
[INFO] [stdout] 57 |     AtlasMember {
[INFO] [stdout]    |     ----------- field in this variant
[INFO] [stdout] 58 |         parent: String,
[INFO] [stdout] 59 |         index: usize,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `check_index` is never used
[INFO] [stdout]    --> src/assets/cache.rs:221:12
[INFO] [stdout]     |
[INFO] [stdout]  98 | impl AssetCache {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 221 |     pub fn check_index(&self, assets: &Vec<String>) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Details` is never constructed
[INFO] [stdout]   --> src/assets/cardrender.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct Details {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_details` is never used
[INFO] [stdout]   --> src/assets/cardrender.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub trait Assetable {
[INFO] [stdout]    |           --------- method in this trait
[INFO] [stdout] 25 |     fn get_details(&self) -> Details;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `name` is never read
[INFO] [stdout]   --> src/cardmenu.rs:32:9
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct CardGroup {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] 32 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `remove_at_position`, `get_size`, and `new` are never used
[INFO] [stdout]    --> src/cardmenu.rs:185:8
[INFO] [stdout]     |
[INFO] [stdout] 184 | impl CardGrid {
[INFO] [stdout]     | ------------- associated items in this implementation
[INFO] [stdout] 185 |     fn remove_at_position(&mut self, position: (usize, usize)) -> Option<Entity> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 208 |     fn get_size(&self) -> Vec2 {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     fn new(
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Deck` and `TopCard` are never constructed
[INFO] [stdout]   --> src/cardmenu/origins.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub enum CardOrigin {
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] 10 |     Hand(PlayerId, usize),
[INFO] [stdout] 11 |     Deck(CardId),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 12 |     TopCard,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CardOrigin` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Deck` is never constructed
[INFO] [stdout]   --> src/cardmenu/origins.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum MenuOrigin {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] 17 |     Hand(PlayerId),
[INFO] [stdout] 18 |     Deck,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `deregister_card`, `get_origin`, and `delete_origin` are never used
[INFO] [stdout]   --> src/cardmenu/origins.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl CardUIOrigins {
[INFO] [stdout]    | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn deregister_card(&mut self, entity: &Entity) -> Option<CardOrigin> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn get_origin(&mut self, entity: &Entity) -> Option<CardOrigin> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 78 |     pub fn delete_origin(&mut self, origin: &CardOrigin) -> Vec<Entity> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Cap` is never used
[INFO] [stdout]  --> src/cardmenu/selection.rs:6:6
[INFO] [stdout]   |
[INFO] [stdout] 6 | enum Cap {
[INFO] [stdout]   |      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_capacity` and `set_capacity` are never used
[INFO] [stdout]   --> src/cardmenu/selection.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | impl Selections {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn get_capacity(&self) -> &Option<usize> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn set_capacity(&mut self, cap: Option<usize>) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `plugin` is never read
[INFO] [stdout]   --> src/content/basic_cards.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct AllColorBand {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 11 |     numeral: u8,
[INFO] [stdout] 12 |     plugin: AllColorPlugin,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_plugin` is never used
[INFO] [stdout]   --> src/content/basic_cards.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl AllColorBand {
[INFO] [stdout]    | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn get_plugin(&self) -> AllColorPlugin {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChooseColorCard` is never constructed
[INFO] [stdout]   --> src/content/basic_cards.rs:75:12
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub struct ChooseColorCard {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PluralBand` is never constructed
[INFO] [stdout]   --> src/content/basic_cards.rs:80:12
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub struct PluralBand<'a, Band, C>(pub Band, u64, PhantomData<&'a C>)
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/content/basic_cards.rs:88:8
[INFO] [stdout]    |
[INFO] [stdout] 84 | / impl<'a, Band, C> PluralBand<'a, Band, C>
[INFO] [stdout] 85 | | where
[INFO] [stdout] 86 | |     Band: AssignedBand<'a, C>,
[INFO] [stdout]    | |______________________________- associated function in this implementation
[INFO] [stdout] 87 |   {
[INFO] [stdout] 88 |       fn new(band: Band, amount: u64) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Predicate` is never used
[INFO] [stdout]   --> src/engine/mod.rs:16:18
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub(crate) trait Predicate<T> {
[INFO] [stdout]    |                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `draw` and `play_card` are never used
[INFO] [stdout]   --> src/engine/mod.rs:81:12
[INFO] [stdout]    |
[INFO] [stdout] 40 | / impl<'a, Band, Card> Game<'a, Band, Card>
[INFO] [stdout] 41 | | where
[INFO] [stdout] 42 | |     Card: Stacks,
[INFO] [stdout] 43 | |     Band: AssignedBand<'a, Card>,
[INFO] [stdout]    | |_________________________________- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 81 |       pub fn draw(&mut self, player: PlayerId) -> bool {
[INFO] [stdout]    |              ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 93 |       pub fn play_card(&mut self, player: PlayerId, hand_number: usize) {
[INFO] [stdout]    |              ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ContextItem` is never used
[INFO] [stdout]  --> src/engine/actions.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub enum ContextItem {
[INFO] [stdout]   |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ItemReference` is never constructed
[INFO] [stdout]   --> src/engine/actions.rs:82:12
[INFO] [stdout]    |
[INFO] [stdout] 82 | pub struct ItemReference {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ContextPredicate` is never used
[INFO] [stdout]   --> src/engine/actions.rs:88:10
[INFO] [stdout]    |
[INFO] [stdout] 88 | pub enum ContextPredicate {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `predicate_legal` is never used
[INFO] [stdout]   --> src/engine/actions.rs:99:4
[INFO] [stdout]    |
[INFO] [stdout] 99 | fn predicate_legal(a: &[ContextPredicate], b: &[ContextPredicate]) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Response` is never constructed
[INFO] [stdout]    --> src/engine/actions.rs:109:8
[INFO] [stdout]     |
[INFO] [stdout] 109 | struct Response<'a> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ResponseContext` is never constructed
[INFO] [stdout]    --> src/engine/actions.rs:115:8
[INFO] [stdout]     |
[INFO] [stdout] 115 | struct ResponseContext {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_predicates`, `allocate_from_vec`, `drop_level`, `reference_item`, `borrow_item`, and `return_item` are never used
[INFO] [stdout]    --> src/engine/actions.rs:122:5
[INFO] [stdout]     |
[INFO] [stdout] 121 | impl ResponseContext {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] 122 |     fn get_predicates(&self, params: &Vec<usize>) -> Vec<ContextPredicate> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 126 |     fn allocate_from_vec(&mut self, defaults: Vec<ContextItem>) -> Vec<usize> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     fn drop_level(&mut self) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 144 |     fn reference_item(&self, reference: usize) -> &ContextItem {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 148 |     fn borrow_item(&mut self, reference: usize) -> Result<ContextItem, &str> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 155 |     fn return_item(&mut self, reference: usize, item: ContextItem) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `append`, `pop`, and `handle_action` are never used
[INFO] [stdout]    --> src/engine/actions.rs:164:5
[INFO] [stdout]     |
[INFO] [stdout] 163 | impl<'a> Response<'a> {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] 164 |     fn append(&mut self, mut actions: Vec<Interaction<'a>>) {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     fn pop(&mut self) -> Interaction<'a> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 183 |     fn handle_action<'b>(&mut self, action: Box<dyn Action<'a> + 'b>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ActionResult` is never constructed
[INFO] [stdout]    --> src/engine/actions.rs:215:12
[INFO] [stdout]     |
[INFO] [stdout] 215 | pub struct ActionResult<'a> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Interaction` is never used
[INFO] [stdout]    --> src/engine/actions.rs:221:6
[INFO] [stdout]     |
[INFO] [stdout] 221 | enum Interaction<'a> {
[INFO] [stdout]     |      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Action` is never used
[INFO] [stdout]    --> src/engine/actions.rs:235:11
[INFO] [stdout]     |
[INFO] [stdout] 235 | pub trait Action<'a> {
[INFO] [stdout]     |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Display` is never used
[INFO] [stdout]    --> src/engine/actions.rs:241:10
[INFO] [stdout]     |
[INFO] [stdout] 241 | pub enum Display {
[INFO] [stdout]     |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Prompt` is never used
[INFO] [stdout]    --> src/engine/actions.rs:246:10
[INFO] [stdout]     |
[INFO] [stdout] 246 | pub enum Prompt {
[INFO] [stdout]     |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `put_card` and `get_max_size` are never used
[INFO] [stdout]    --> src/engine/cards.rs:100:8
[INFO] [stdout]     |
[INFO] [stdout]  99 | pub trait IdDeck {
[INFO] [stdout]     |           ------ methods in this trait
[INFO] [stdout] 100 |     fn put_card(&mut self, card_id: DeckId) -> bool;
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     fn get_max_size(&self) -> DeckCapacity;
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `attempt_collapse` is never used
[INFO] [stdout]    --> src/engine/cards.rs:142:8
[INFO] [stdout]     |
[INFO] [stdout] 131 | impl RLEDeck {
[INFO] [stdout]     | ------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 142 |     fn attempt_collapse(&mut self, idx: usize) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Special` is never constructed
[INFO] [stdout]    --> src/engine/cards.rs:289:5
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub enum CardValue {
[INFO] [stdout]     |          --------- variant in this enum
[INFO] [stdout] 289 |     Special(usize),
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `CardValue` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_min_val` is never used
[INFO] [stdout]   --> src/engine/colors.rs:14:4
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn get_min_val(vals: &[f32; 3]) -> f32 {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_saturation` and `get_hue` are never used
[INFO] [stdout]   --> src/engine/colors.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl Color {
[INFO] [stdout]    | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn get_saturation(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn get_hue(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `exact_color_eq` is never used
[INFO] [stdout]   --> src/engine/colors.rs:68:8
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub fn exact_color_eq() -> ColorComparison<'static> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `phase` and `callback` are never read
[INFO] [stdout]  --> src/engine/scheduler.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | struct Task<'a> {
[INFO] [stdout]   |        ---- fields in this struct
[INFO] [stdout] 6 |     phase: TurnPhase,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 7 |     callback: Box<dyn Fn() -> () + 'a>,
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `TimerTask` is never used
[INFO] [stdout]   --> src/engine/scheduler.rs:10:7
[INFO] [stdout]    |
[INFO] [stdout] 10 | trait TimerTask<'a> {
[INFO] [stdout]    |       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `tracker` and `task` are never read
[INFO] [stdout]   --> src/engine/scheduler.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | struct PlayTask<'a> {
[INFO] [stdout]    |        -------- fields in this struct
[INFO] [stdout] 18 |     tracker: Tracker,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 19 |
[INFO] [stdout] 20 |     task: Task<'a>,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `tracker`, `pinpoint`, and `task` are never read
[INFO] [stdout]   --> src/engine/scheduler.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 41 | struct RelativeTask<'a> {
[INFO] [stdout]    |        ------------ fields in this struct
[INFO] [stdout] 42 |     tracker: Tracker,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 43 |     pinpoint: bool,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 44 |
[INFO] [stdout] 45 |     task: Task<'a>,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `is_done`, and `is_overdue` are never used
[INFO] [stdout]   --> src/engine/scheduler.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 85 | impl Tracker {
[INFO] [stdout]    | ------------ associated items in this implementation
[INFO] [stdout] 86 |     pub fn new(turns: isize) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 90 |     fn is_done(&self) -> bool {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 94 |     fn is_overdue(&self) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `plays` and `turns` are never read
[INFO] [stdout]    --> src/engine/scheduler.rs:100:5
[INFO] [stdout]     |
[INFO] [stdout]  99 | struct TurnCounter {
[INFO] [stdout]     |        ----------- fields in this struct
[INFO] [stdout] 100 |     plays: usize,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 101 |     turns: usize,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `tracker`, `direction`, `queue`, `play_queue`, and `playerqueue` are never read
[INFO] [stdout]    --> src/engine/scheduler.rs:112:5
[INFO] [stdout]     |
[INFO] [stdout] 110 | pub struct Scheduler<'a> {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 111 |     order: Vec<usize>,
[INFO] [stdout] 112 |     tracker: TurnCounter,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 113 |     cur_turn: usize,
[INFO] [stdout] 114 |     direction: isize,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout] 115 |
[INFO] [stdout] 116 |     queue: Vec<RelativeTask<'a>>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 117 |     play_queue: Vec<PlayTask<'a>>,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] 118 |     playerqueue: Vec<Vec<Task<'a>>>,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `reverse`, `go`, `tick`, `push_player_task`, `schedule_task`, and `pop_current_turn` are never used
[INFO] [stdout]    --> src/engine/scheduler.rs:138:12
[INFO] [stdout]     |
[INFO] [stdout] 121 | impl<'a> Scheduler<'a> {
[INFO] [stdout]     | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 138 |     pub fn reverse(&mut self) {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn go(&mut self, amount: usize) {
[INFO] [stdout]     |            ^^
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub fn tick(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 170 |     pub fn push_player_task(&mut self, player: PlayerId, task: Task<'a>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 174 |     pub fn schedule_task(&mut self, task: RelativeTask<'a>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 178 |     pub fn pop_current_turn(&mut self) -> ActionQueue<'a> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fetch_and_prune` is never used
[INFO] [stdout]    --> src/engine/scheduler.rs:193:4
[INFO] [stdout]     |
[INFO] [stdout] 193 | fn fetch_and_prune<'a>(tasks: &mut Vec<impl TimerTask<'a>>, queue: &mut ActionQueue<'a>) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ActionQueue` is never constructed
[INFO] [stdout]    --> src/engine/scheduler.rs:207:12
[INFO] [stdout]     |
[INFO] [stdout] 207 | pub struct ActionQueue<'a>(RequiredDict<TurnPhase, Vec<Box<dyn FnOnce() -> () + 'a>>>);
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `run` and `push` are never used
[INFO] [stdout]    --> src/engine/scheduler.rs:210:12
[INFO] [stdout]     |
[INFO] [stdout] 209 | impl<'a> ActionQueue<'a> {
[INFO] [stdout]     | ------------------------ methods in this implementation
[INFO] [stdout] 210 |     pub fn run(&mut self, phase: TurnPhase) {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 216 |     pub fn push(&mut self, phase: TurnPhase, callback: Box<dyn FnOnce() -> () + 'a>) -> () {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Hand` is never constructed
[INFO] [stdout]    --> src/orchestrator.rs:267:8
[INFO] [stdout]     |
[INFO] [stdout] 267 | struct Hand {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `NotInGame` is never constructed
[INFO] [stdout]    --> src/orchestrator.rs:300:5
[INFO] [stdout]     |
[INFO] [stdout] 299 | enum GameState {
[INFO] [stdout]     |      --------- variant in this enum
[INFO] [stdout] 300 |     NotInGame,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `GameState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `poses` and `reference` are never read
[INFO] [stdout]  --> src/resizeplugin.rs:8:6
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct Anchors {
[INFO] [stdout]   |            ------- fields in this struct
[INFO] [stdout] 8 |     pub poses: Rect,
[INFO] [stdout]   |         ^^^^^
[INFO] [stdout] 9 |     pub reference: Rect
[INFO] [stdout]   |         ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Resize` is never constructed
[INFO] [stdout]   --> src/resizeplugin.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | struct Resize(Vec2);
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `std::result::Result` that must be used
[INFO] [stdout]    --> src/orchestrator.rs:106:5
[INFO] [stdout]     |
[INFO] [stdout] 106 |     images.insert(&img, BasePalette::gen_image(PALETTE_SIZE));
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 106 |     let _ = images.insert(&img, BasePalette::gen_image(PALETTE_SIZE));
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 22s
[INFO] running `Command { std: "docker" "inspect" "0aada91286e733c3de7498d86aaaa885c828f397119f7d987c106f8fa3bff973", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0aada91286e733c3de7498d86aaaa885c828f397119f7d987c106f8fa3bff973", kill_on_drop: false }`
[INFO] [stdout] 0aada91286e733c3de7498d86aaaa885c828f397119f7d987c106f8fa3bff973
