[INFO] cloning repository https://github.com/arsmilitaris/amserver
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/arsmilitaris/amserver" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Farsmilitaris%2Famserver", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Farsmilitaris%2Famserver'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] ca8503560757cf6731d535c526b88beef853621e
[INFO] checking arsmilitaris/amserver against 1.95.0 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Farsmilitaris%2Famserver" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/arsmilitaris/amserver
[INFO] finished tweaking git repo https://github.com/arsmilitaris/amserver
[INFO] tweaked toml for git repo https://github.com/arsmilitaris/amserver written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/arsmilitaris/amserver on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/arsmilitaris/amserver 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.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded itertools v0.8.2
[INFO] [stderr]   Downloaded log v0.4.19
[INFO] [stderr]   Downloaded gpu-descriptor v0.2.3
[INFO] [stderr]   Downloaded proc-macro2 v1.0.63
[INFO] [stderr]   Downloaded quote v1.0.29
[INFO] [stderr]   Downloaded windows-targets v0.48.1
[INFO] [stderr]   Downloaded gridly_grids v0.5.0
[INFO] [stderr]   Downloaded crc-catalog v1.1.1
[INFO] [stderr]   Downloaded ruzstd v0.4.0
[INFO] [stderr]   Downloaded thiserror-core-impl v1.0.38
[INFO] [stderr]   Downloaded termcolor v1.2.0
[INFO] [stderr]   Downloaded brownstone v1.1.0
[INFO] [stderr]   Downloaded bevy_macro_utils v0.11.0
[INFO] [stderr]   Downloaded bevy_hierarchy v0.11.0
[INFO] [stderr]   Downloaded quinn-udp v0.4.0
[INFO] [stderr]   Downloaded bevy_animation v0.11.0
[INFO] [stderr]   Downloaded encase_derive_impl v0.6.1
[INFO] [stderr]   Downloaded thiserror-core v1.0.38
[INFO] [stderr]   Downloaded bevy_audio v0.11.0
[INFO] [stderr]   Downloaded coreaudio-sys v0.2.12
[INFO] [stderr]   Downloaded bevy_ptr v0.11.0
[INFO] [stderr]   Downloaded pem v2.0.1
[INFO] [stderr]   Downloaded bevy_gilrs v0.11.0
[INFO] [stderr]   Downloaded filetime v0.2.21
[INFO] [stderr]   Downloaded kqueue-sys v1.0.3
[INFO] [stderr]   Downloaded grid v0.9.0
[INFO] [stderr]   Downloaded windows-interface v0.44.0
[INFO] [stderr]   Downloaded android_log-sys v0.3.0
[INFO] [stderr]   Downloaded bevy_gizmos v0.11.0
[INFO] [stderr]   Downloaded ab_glyph v0.2.21
[INFO] [stderr]   Downloaded serde_derive v1.0.165
[INFO] [stderr]   Downloaded gltf-derive v1.2.0
[INFO] [stderr]   Downloaded widestring v1.0.2
[INFO] [stderr]   Downloaded encase v0.6.1
[INFO] [stderr]   Downloaded oboe v0.5.0
[INFO] [stderr]   Downloaded bevy_scene v0.11.0
[INFO] [stderr]   Downloaded gilrs-core v0.5.6
[INFO] [stderr]   Downloaded coreaudio-rs v0.11.2
[INFO] [stderr]   Downloaded clang-sys v1.6.1
[INFO] [stderr]   Downloaded rodio v0.17.1
[INFO] [stderr]   Downloaded alsa v0.7.0
[INFO] [stderr]   Downloaded toml_edit v0.19.11
[INFO] [stderr]   Downloaded cpal v0.15.2
[INFO] [stderr]   Downloaded naga_oil v0.8.1
[INFO] [stderr]   Downloaded oboe-sys v0.5.0
[INFO] [stderr]   Downloaded sysinfo v0.29.4
[INFO] [stderr]   Downloaded rustls-webpki v0.101.1
[INFO] [stderr]   Downloaded petgraph v0.6.3
[INFO] [stderr]   Downloaded bindgen v0.64.0
[INFO] [stderr]   Downloaded syn v2.0.23
[INFO] [stderr]   Downloaded bevy_ecs v0.11.0
[INFO] [stderr]   Downloaded glam v0.24.1
[INFO] [stderr]   Downloaded android-activity v0.4.2
[INFO] [stderr]   Downloaded rustls v0.21.5
[INFO] [stderr]   Downloaded openssl v0.10.55
[INFO] [stderr]   Downloaded quinn-proto v0.10.1
[INFO] [stderr]   Downloaded bevy v0.11.0
[INFO] [stderr]   Downloaded bevy_render v0.11.0
[INFO] [stderr]   Downloaded ttf-parser v0.19.1
[INFO] [stderr]   Downloaded winit v0.28.6
[INFO] [stderr]   Downloaded owned_ttf_parser v0.19.0
[INFO] [stderr]   Downloaded winnow v0.4.7
[INFO] [stderr]   Downloaded gilrs v0.10.2
[INFO] [stderr]   Downloaded serde_json v1.0.99
[INFO] [stderr]   Downloaded bevy_pbr v0.11.0
[INFO] [stderr]   Downloaded wgpu v0.16.2
[INFO] [stderr]   Downloaded time v0.3.22
[INFO] [stderr]   Downloaded glow v0.12.2
[INFO] [stderr]   Downloaded taffy v0.3.12
[INFO] [stderr]   Downloaded kafka v0.9.0
[INFO] [stderr]   Downloaded bevy_core_pipeline v0.11.0
[INFO] [stderr]   Downloaded bevy_ui v0.11.0
[INFO] [stderr]   Downloaded bevy_reflect v0.11.0
[INFO] [stderr]   Downloaded bevy_quinnet v0.5.0
[INFO] [stderr]   Downloaded flate2 v1.0.26
[INFO] [stderr]   Downloaded openssl-sys v0.9.90
[INFO] [stderr]   Downloaded pathfinding v1.1.12
[INFO] [stderr]   Downloaded tokio v1.29.1
[INFO] [stderr]   Downloaded futures v0.3.28
[INFO] [stderr]   Downloaded quinn v0.10.1
[INFO] [stderr]   Downloaded security-framework v2.9.1
[INFO] [stderr]   Downloaded ron v0.8.0
[INFO] [stderr]   Downloaded bevy_asset v0.11.0
[INFO] [stderr]   Downloaded gltf v1.2.0
[INFO] [stderr]   Downloaded uuid v1.4.0
[INFO] [stderr]   Downloaded allocator-api2 v0.2.15
[INFO] [stderr]   Downloaded anyhow v1.0.71
[INFO] [stderr]   Downloaded bevy_sprite v0.11.0
[INFO] [stderr]   Downloaded xml-rs v0.8.15
[INFO] [stderr]   Downloaded csv v1.2.2
[INFO] [stderr]   Downloaded rcgen v0.11.1
[INFO] [stderr]   Downloaded snap v1.1.0
[INFO] [stderr]   Downloaded serde v1.0.165
[INFO] [stderr]   Downloaded notify v6.0.1
[INFO] [stderr]   Downloaded gridly v0.9.0
[INFO] [stderr]   Downloaded mach2 v0.4.1
[INFO] [stderr]   Downloaded io-kit-sys v0.3.0
[INFO] [stderr]   Downloaded gltf-json v1.2.0
[INFO] [stderr]   Downloaded bevy_mikktspace v0.11.0
[INFO] [stderr]   Downloaded data-encoding v2.4.0
[INFO] [stderr]   Downloaded paste v1.0.12
[INFO] [stderr]   Downloaded accesskit_windows v0.14.0
[INFO] [stderr]   Downloaded bevy_tasks v0.11.0
[INFO] [stderr]   Downloaded profiling v1.0.8
[INFO] [stderr]   Downloaded bitflags v2.3.3
[INFO] [stderr]   Downloaded bevy_text v0.11.0
[INFO] [stderr]   Downloaded orbclient v0.3.45
[INFO] [stderr]   Downloaded accesskit_consumer v0.15.0
[INFO] [stderr]   Downloaded accesskit_winit v0.14.1
[INFO] [stderr]   Downloaded bevy_app v0.11.0
[INFO] [stderr]   Downloaded async-lock v2.7.0
[INFO] [stderr]   Downloaded bevy_reflect_derive v0.11.0
[INFO] [stderr]   Downloaded erased-serde v0.3.26
[INFO] [stderr]   Downloaded bevy_utils v0.11.0
[INFO] [stderr]   Downloaded bevy_winit v0.11.0
[INFO] [stderr]   Downloaded security-framework-sys v2.9.0
[INFO] [stderr]   Downloaded constgebra v0.1.3
[INFO] [stderr]   Downloaded hexasphere v9.1.0
[INFO] [stderr]   Downloaded bevy_window v0.11.0
[INFO] [stderr]   Downloaded rustls-pemfile v1.0.3
[INFO] [stderr]   Downloaded bevy_transform v0.11.0
[INFO] [stderr]   Downloaded accesskit v0.11.0
[INFO] [stderr]   Downloaded bevy_a11y v0.11.0
[INFO] [stderr]   Downloaded bevy_input v0.11.0
[INFO] [stderr]   Downloaded bevy_math v0.11.0
[INFO] [stderr]   Downloaded crc v2.1.0
[INFO] [stderr]   Downloaded jobserver v0.1.26
[INFO] [stderr]   Downloaded pin-project-lite v0.2.10
[INFO] [stderr]   Downloaded bevy_diagnostic v0.11.0
[INFO] [stderr]   Downloaded bevy_encase_derive v0.11.0
[INFO] [stderr]   Downloaded bevy_render_macros v0.11.0
[INFO] [stderr]   Downloaded encase_derive v0.6.1
[INFO] [stderr]   Downloaded bevy_log v0.11.0
[INFO] [stderr]   Downloaded bevy_time v0.11.0
[INFO] [stderr]   Downloaded no-std-compat v0.4.1
[INFO] [stderr]   Downloaded bevy_core v0.11.0
[INFO] [stderr]   Downloaded bevy_ecs_macros v0.11.0
[INFO] [stderr]   Downloaded smol_str v0.2.0
[INFO] [stderr]   Downloaded bevy_utils_proc_macros v0.11.0
[INFO] [stderr]   Downloaded hermit-abi v0.3.1
[INFO] [stderr]   Downloaded itoa v1.0.7
[INFO] [stderr]   Downloaded bevy_internal v0.11.0
[INFO] [stderr]   Downloaded simd-adler32 v0.3.5
[INFO] [stderr]   Downloaded renderdoc-sys v1.0.0
[INFO] [stderr]   Downloaded accesskit_macos v0.7.1
[INFO] [stderr]   Downloaded bytemuck_derive v1.4.1
[INFO] [stderr]   Downloaded equivalent v1.0.0
[INFO] [stderr]   Downloaded bevy_gltf v0.11.0
[INFO] [stderr]   Downloaded kqueue v1.0.7
[INFO] [stderr]   Downloaded unicode-width v0.1.10
[INFO] [stderr]   Downloaded bevy_derive v0.11.0
[INFO] [stderr]   Downloaded async-channel v1.8.0
[INFO] [stderr]   Downloaded windows-implement v0.44.0
[INFO] [stderr]   Downloaded ref_slice v1.2.1
[INFO] [stderr]   Downloaded windows v0.46.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 5c0bb5081311b1ec29cd60ae6b1d717695faa267d4dc163d117f8d097052e87b
[INFO] running `Command { std: "docker" "start" "-a" "5c0bb5081311b1ec29cd60ae6b1d717695faa267d4dc163d117f8d097052e87b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "5c0bb5081311b1ec29cd60ae6b1d717695faa267d4dc163d117f8d097052e87b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5c0bb5081311b1ec29cd60ae6b1d717695faa267d4dc163d117f8d097052e87b", kill_on_drop: false }`
[INFO] [stdout] 5c0bb5081311b1ec29cd60ae6b1d717695faa267d4dc163d117f8d097052e87b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=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" "+1.95.0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 3de807e0c5f21cb37666f0eb5b60877906c7e0fcf4a9d146d16a4809c2c5f2cf
[INFO] running `Command { std: "docker" "start" "-a" "3de807e0c5f21cb37666f0eb5b60877906c7e0fcf4a9d146d16a4809c2c5f2cf", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.63
[INFO] [stderr]    Compiling quote v1.0.29
[INFO] [stderr]    Compiling unicode-ident v1.0.9
[INFO] [stderr]    Compiling libc v0.2.147
[INFO] [stderr]     Checking cfg-if v1.0.0
[INFO] [stderr]    Compiling autocfg v1.1.0
[INFO] [stderr]     Checking once_cell v1.18.0
[INFO] [stderr]    Compiling serde v1.0.165
[INFO] [stderr]    Compiling version_check v0.9.4
[INFO] [stderr]     Checking log v0.4.19
[INFO] [stderr]     Checking pin-project-lite v0.2.10
[INFO] [stderr]    Compiling memchr v2.5.0
[INFO] [stderr]    Compiling thiserror v1.0.40
[INFO] [stderr]     Checking tracing-core v0.1.31
[INFO] [stderr]    Compiling futures-core v0.3.28
[INFO] [stderr]    Compiling hashbrown v0.14.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.8
[INFO] [stderr]    Compiling equivalent v1.0.0
[INFO] [stderr]    Compiling toml_datetime v0.6.3
[INFO] [stderr]    Compiling crossbeam-utils v0.8.16
[INFO] [stderr]    Compiling winnow v0.4.7
[INFO] [stderr]    Compiling indexmap v2.0.0
[INFO] [stderr]     Checking scopeguard v1.1.0
[INFO] [stderr]    Compiling ahash v0.7.6
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling syn v2.0.23
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling lock_api v0.4.10
[INFO] [stderr]    Compiling slab v0.4.8
[INFO] [stderr]     Checking futures-io v0.3.28
[INFO] [stderr]     Checking getrandom v0.2.10
[INFO] [stderr]    Compiling ahash v0.8.3
[INFO] [stderr]     Checking instant v0.1.12
[INFO] [stderr]     Checking event-listener v2.5.3
[INFO] [stderr]     Checking concurrent-queue v2.2.0
[INFO] [stderr]    Compiling num-traits v0.2.15
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]     Checking fastrand v1.9.0
[INFO] [stderr]     Checking waker-fn v1.1.0
[INFO] [stderr]    Compiling bit-vec v0.6.3
[INFO] [stderr]     Checking allocator-api2 v0.2.15
[INFO] [stderr]    Compiling erased-serde v0.3.26
[INFO] [stderr]     Checking parking v2.1.0
[INFO] [stderr]     Checking fixedbitset v0.4.2
[INFO] [stderr]     Checking futures-lite v1.13.0
[INFO] [stderr]    Compiling bit-set v0.5.3
[INFO] [stderr]     Checking petgraph v0.6.3
[INFO] [stderr]     Checking async-lock v2.7.0
[INFO] [stderr]     Checking async-task v4.4.0
[INFO] [stderr]     Checking async-channel v1.8.0
[INFO] [stderr]     Checking thread_local v1.1.7
[INFO] [stderr]    Compiling pkg-config v0.3.27
[INFO] [stderr]    Compiling toml_edit v0.19.11
[INFO] [stderr]    Compiling uuid v1.4.0
[INFO] [stderr]     Checking smol_str v0.2.0
[INFO] [stderr]     Checking bevy_ptr v0.11.0
[INFO] [stderr]     Checking async-executor v1.5.1
[INFO] [stderr]     Checking downcast-rs v1.2.0
[INFO] [stderr]     Checking lazy_static v1.4.0
[INFO] [stderr]     Checking regex-syntax v0.6.29
[INFO] [stderr]     Checking aho-corasick v1.0.2
[INFO] [stderr]     Checking bevy_tasks v0.11.0
[INFO] [stderr]     Checking regex-syntax v0.7.2
[INFO] [stderr]     Checking overload v0.1.1
[INFO] [stderr]     Checking nu-ansi-term v0.46.0
[INFO] [stderr]     Checking sharded-slab v0.1.4
[INFO] [stderr]     Checking tracing-log v0.1.3
[INFO] [stderr]     Checking mio v0.8.8
[INFO] [stderr]     Checking byteorder v1.4.3
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking raw-window-handle v0.5.2
[INFO] [stderr]     Checking ppv-lite86 v0.2.17
[INFO] [stderr]     Checking crossbeam-channel v0.5.8
[INFO] [stderr]     Checking unicode-xid v0.2.4
[INFO] [stderr]     Checking termcolor v1.2.0
[INFO] [stderr]    Compiling bevy_macro_utils v0.11.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]    Compiling crc32fast v1.3.2
[INFO] [stderr]     Checking unicode-width v0.1.10
[INFO] [stderr]     Checking simd-adler32 v0.3.5
[INFO] [stderr]     Checking arrayvec v0.7.4
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking regex-automata v0.1.10
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking regex v1.8.4
[INFO] [stderr]     Checking pp-rs v0.2.1
[INFO] [stderr]     Checking spirv v0.2.0+1.5.4
[INFO] [stderr]     Checking libloading v0.7.4
[INFO] [stderr]    Compiling ash v0.37.3+1.3.251
[INFO] [stderr]     Checking adler v1.0.2
[INFO] [stderr]    Compiling cc v1.0.79
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking matchers v0.1.0
[INFO] [stderr]    Compiling khronos-egl v4.1.0
[INFO] [stderr]     Checking miniz_oxide v0.7.1
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]     Checking gpu-alloc-types v0.2.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.1.1
[INFO] [stderr]     Checking bitflags v2.3.3
[INFO] [stderr]    Compiling anyhow v1.0.71
[INFO] [stderr]     Checking same-file v1.0.6
[INFO] [stderr]     Checking wgpu-types v0.16.1
[INFO] [stderr]     Checking walkdir v2.3.3
[INFO] [stderr]     Checking flate2 v1.0.26
[INFO] [stderr]     Checking gpu-alloc v0.5.4
[INFO] [stderr]     Checking gpu-descriptor v0.2.3
[INFO] [stderr]     Checking inotify v0.9.6
[INFO] [stderr]    Compiling encase_derive_impl v0.6.1
[INFO] [stderr]     Checking filetime v0.2.21
[INFO] [stderr]     Checking sysinfo v0.29.4
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]     Checking libloading v0.8.0
[INFO] [stderr]     Checking renderdoc-sys v1.0.0
[INFO] [stderr]     Checking profiling v1.0.8
[INFO] [stderr]    Compiling thiserror-core v1.0.38
[INFO] [stderr]     Checking glow v0.12.2
[INFO] [stderr]     Checking notify v6.0.1
[INFO] [stderr]     Checking twox-hash v1.6.3
[INFO] [stderr]     Checking fdeflate v0.3.0
[INFO] [stderr]     Checking constgebra v0.1.3
[INFO] [stderr]     Checking png v0.17.9
[INFO] [stderr]     Checking const_panic v0.2.8
[INFO] [stderr]     Checking data-encoding v2.4.0
[INFO] [stderr]     Checking color_quant v1.1.0
[INFO] [stderr]     Checking ktx2 v0.3.0
[INFO] [stderr]    Compiling ring v0.16.20
[INFO] [stderr]     Checking radsort v0.1.0
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling xml-rs v0.8.15
[INFO] [stderr]     Checking tinyvec v1.6.0
[INFO] [stderr]    Compiling wayland-scanner v0.29.5
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]     Checking euclid v0.22.9
[INFO] [stderr]    Compiling serde_json v1.0.99
[INFO] [stderr]     Checking itoa v1.0.7
[INFO] [stderr]     Checking ttf-parser v0.19.1
[INFO] [stderr]     Checking spin v0.5.2
[INFO] [stderr]     Checking svg_fmt v0.4.1
[INFO] [stderr]     Checking untrusted v0.7.1
[INFO] [stderr]    Compiling cfg_aliases v0.1.1
[INFO] [stderr]     Checking ryu v1.0.13
[INFO] [stderr]     Checking guillotiere v0.6.2
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking nix v0.24.3
[INFO] [stderr]    Compiling slotmap v1.0.6
[INFO] [stderr]    Compiling winit v0.28.6
[INFO] [stderr]     Checking percent-encoding v2.3.0
[INFO] [stderr]    Compiling cpal v0.15.2
[INFO] [stderr]     Checking base64 v0.21.2
[INFO] [stderr]     Checking ab_glyph_rasterizer v0.1.8
[INFO] [stderr]     Checking accesskit v0.11.0
[INFO] [stderr]     Checking alsa v0.7.0
[INFO] [stderr]    Compiling openssl-sys v0.9.90
[INFO] [stderr]     Checking ogg v0.8.0
[INFO] [stderr]     Checking nix v0.26.2
[INFO] [stderr]     Checking owned_ttf_parser v0.19.0
[INFO] [stderr]     Checking base64 v0.13.1
[INFO] [stderr]     Checking ab_glyph v0.2.21
[INFO] [stderr]     Checking xi-unicode v0.3.0
[INFO] [stderr]    Compiling futures-task v0.3.28
[INFO] [stderr]    Compiling futures-channel v0.3.28
[INFO] [stderr]     Checking no-std-compat v0.4.1
[INFO] [stderr]    Compiling gilrs v0.10.2
[INFO] [stderr]     Checking futures-sink v0.3.28
[INFO] [stderr]     Checking grid v0.9.0
[INFO] [stderr]     Checking glyph_brush_layout v0.2.3
[INFO] [stderr]     Checking lewton v0.10.2
[INFO] [stderr]    Compiling tokio v1.29.1
[INFO] [stderr]    Compiling rustls v0.21.5
[INFO] [stderr]    Compiling futures-util v0.3.28
[INFO] [stderr]     Checking bytes v1.4.0
[INFO] [stderr]     Checking taffy v0.3.12
[INFO] [stderr]     Checking rustls-webpki v0.101.1
[INFO] [stderr]     Checking sct v0.7.0
[INFO] [stderr]     Checking rustls-pemfile v1.0.3
[INFO] [stderr]     Checking socket2 v0.4.9
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking pin-utils v0.1.0
[INFO] [stderr]     Checking openssl-probe v0.1.5
[INFO] [stderr]     Checking time-core v0.1.1
[INFO] [stderr]     Checking rustls-native-certs v0.6.3
[INFO] [stderr]     Checking time v0.3.22
[INFO] [stderr]     Checking socket2 v0.5.3
[INFO] [stderr]     Checking foreign-types-shared v0.1.1
[INFO] [stderr]    Compiling openssl v0.10.55
[INFO] [stderr]    Compiling snap v1.1.0
[INFO] [stderr]     Checking foreign-types v0.3.2
[INFO] [stderr]     Checking yasna v0.5.2
[INFO] [stderr]     Checking pem v2.0.1
[INFO] [stderr]    Compiling kafka v0.9.0
[INFO] [stderr]     Checking either v1.9.0
[INFO] [stderr]     Checking crc-catalog v1.1.1
[INFO] [stderr]     Checking itertools v0.8.2
[INFO] [stderr]     Checking crc v2.1.0
[INFO] [stderr]    Compiling thiserror-core-impl v1.0.38
[INFO] [stderr]     Checking rcgen v0.11.1
[INFO] [stderr]     Checking brownstone v1.1.0
[INFO] [stderr]     Checking csv-core v0.1.10
[INFO] [stderr]     Checking gridly v0.9.0
[INFO] [stderr]     Checking ref_slice v1.2.1
[INFO] [stderr]     Checking fixedbitset v0.1.9
[INFO] [stderr]     Checking pathfinding v1.1.12
[INFO] [stderr]     Checking accesskit_winit v0.14.1
[INFO] [stderr]     Checking gridly_grids v0.5.0
[INFO] [stderr]    Compiling serde_derive v1.0.165
[INFO] [stderr]    Compiling thiserror-impl v1.0.40
[INFO] [stderr]    Compiling tracing-attributes v0.1.26
[INFO] [stderr]    Compiling bytemuck_derive v1.4.1
[INFO] [stderr]    Compiling bevy_utils_proc_macros v0.11.0
[INFO] [stderr]    Compiling bevy_reflect_derive v0.11.0
[INFO] [stderr]    Compiling bevy_ecs_macros v0.11.0
[INFO] [stderr]    Compiling bevy_derive v0.11.0
[INFO] [stderr]    Compiling encase_derive v0.6.1
[INFO] [stderr]     Checking ruzstd v0.4.0
[INFO] [stderr]    Compiling bevy_encase_derive v0.11.0
[INFO] [stderr]     Checking bytemuck v1.13.1
[INFO] [stderr]     Checking image v0.24.6
[INFO] [stderr]    Compiling bevy_render_macros v0.11.0
[INFO] [stderr]    Compiling gltf-derive v1.2.0
[INFO] [stderr]    Compiling futures-macro v0.3.28
[INFO] [stderr]     Checking naga v0.12.3
[INFO] [stderr]    Compiling tokio-macros v2.1.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]     Checking tracing v0.1.37
[INFO] [stderr]     Checking naga_oil v0.8.1
[INFO] [stderr]     Checking quinn-proto v0.10.1
[INFO] [stderr]     Checking quinn-udp v0.4.0
[INFO] [stderr]     Checking futures-executor v0.3.28
[INFO] [stderr]     Checking smallvec v1.10.0
[INFO] [stderr]     Checking glam v0.24.1
[INFO] [stderr]     Checking ron v0.8.0
[INFO] [stderr]     Checking tracing-subscriber v0.3.17
[INFO] [stderr]     Checking gilrs-core v0.5.6
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking bevy_utils v0.11.0
[INFO] [stderr]     Checking wgpu-hal v0.16.2
[INFO] [stderr]     Checking quinn v0.10.1
[INFO] [stderr]     Checking tokio-util v0.7.8
[INFO] [stderr]     Checking rodio v0.17.1
[INFO] [stderr]     Checking gltf-json v1.2.0
[INFO] [stderr]     Checking futures v0.3.28
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking csv v1.2.2
[INFO] [stderr]     Checking bevy_math v0.11.0
[INFO] [stderr]     Checking encase v0.6.1
[INFO] [stderr]     Checking hexasphere v9.1.0
[INFO] [stderr]     Checking bevy_mikktspace v0.11.0
[INFO] [stderr]     Checking bevy_reflect v0.11.0
[INFO] [stderr]     Checking wgpu-core v0.16.1
[INFO] [stderr]     Checking gltf v1.2.0
[INFO] [stderr]     Checking bevy_ecs v0.11.0
[INFO] [stderr]     Checking wgpu v0.16.2
[INFO] [stderr]     Checking bevy_app v0.11.0
[INFO] [stderr]     Checking bevy_log v0.11.0
[INFO] [stderr]     Checking bevy_core v0.11.0
[INFO] [stderr]     Checking bevy_time v0.11.0
[INFO] [stderr]     Checking bevy_input v0.11.0
[INFO] [stderr]     Checking bevy_a11y v0.11.0
[INFO] [stderr]     Checking bevy_hierarchy v0.11.0
[INFO] [stderr]     Checking bevy_diagnostic v0.11.0
[INFO] [stderr]     Checking bevy_asset v0.11.0
[INFO] [stderr]     Checking bevy_transform v0.11.0
[INFO] [stderr]     Checking bevy_audio v0.11.0
[INFO] [stderr]     Checking bevy_window v0.11.0
[INFO] [stderr]     Checking bevy_gilrs v0.11.0
[INFO] [stderr]     Checking bevy_render v0.11.0
[INFO] [stderr]     Checking bevy_winit v0.11.0
[INFO] [stderr]     Checking bevy_core_pipeline v0.11.0
[INFO] [stderr]     Checking bevy_scene v0.11.0
[INFO] [stderr]     Checking bevy_animation v0.11.0
[INFO] [stderr]     Checking bevy_sprite v0.11.0
[INFO] [stderr]     Checking bevy_pbr v0.11.0
[INFO] [stderr]     Checking bevy_text v0.11.0
[INFO] [stderr]     Checking bevy_ui v0.11.0
[INFO] [stderr]     Checking bevy_gltf v0.11.0
[INFO] [stderr]     Checking bevy_gizmos v0.11.0
[INFO] [stderr]     Checking bevy_internal v0.11.0
[INFO] [stderr]     Checking bevy v0.11.0
[INFO] [stderr]     Checking bevy_quinnet v0.5.0
[INFO] [stderr]     Checking amserver v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `diagnostic::FrameTimeDiagnosticsPlugin`, `diagnostic::LogDiagnosticsPlugin`, `render::camera::ScalingMode`, and `window::*`
[INFO] [stdout]  --> src/main.rs:3:24
[INFO] [stdout]   |
[INFO] [stdout] 3 | ...*, render::camera::ScalingMode, log::LogPlugin, diagnostic::LogDiagnosticsPlugin, diagnostic::FrameTimeDiagnosticsPlugin, window::*};
[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: `bevy::ecs::world::World`
[INFO] [stdout]  --> src/main.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use bevy::ecs::world::World;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `gridly_grids::VecGrid`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use gridly_grids::VecGrid;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs`
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::fs;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Producer`, `Record`, and `RequiredAcks`
[INFO] [stdout]   --> src/main.rs:19:23
[INFO] [stdout]    |
[INFO] [stdout] 19 | use kafka::producer::{Producer, Record, RequiredAcks};
[INFO] [stdout]    |                       ^^^^^^^^  ^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ConnectionLostEvent` and `Endpoint`
[INFO] [stdout]   --> src/main.rs:23:48
[INFO] [stdout]    |
[INFO] [stdout] 23 |         certificate::CertificateRetrievalMode, ConnectionLostEvent, Endpoint, QuinnetServerPlugin,
[INFO] [stdout]    |                                                ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around pattern
[INFO] [stdout]     --> src/main.rs:1327:6
[INFO] [stdout]      |
[INFO] [stdout] 1327 |     for (mut move_actions) in move_actions_query.iter_mut() {
[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] 1327 -     for (mut move_actions) in move_actions_query.iter_mut() {
[INFO] [stdout] 1327 +     for mut move_actions in move_actions_query.iter_mut() {
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]     --> src/main.rs:1823:10
[INFO] [stdout]      |
[INFO] [stdout] 1823 |                         if (neighbor.0.x == start.x || neighbor.0.y == start.y) {
[INFO] [stdout]      |                            ^                                                  ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1823 -                         if (neighbor.0.x == start.x || neighbor.0.y == start.y) {
[INFO] [stdout] 1823 +                         if neighbor.0.x == start.x || neighbor.0.y == start.y {
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `diagnostic::FrameTimeDiagnosticsPlugin`, `diagnostic::LogDiagnosticsPlugin`, `render::camera::ScalingMode`, and `window::*`
[INFO] [stdout]  --> src/main.rs:3:24
[INFO] [stdout]   |
[INFO] [stdout] 3 | ...*, render::camera::ScalingMode, log::LogPlugin, diagnostic::LogDiagnosticsPlugin, diagnostic::FrameTimeDiagnosticsPlugin, window::*};
[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: `bevy::ecs::world::World`
[INFO] [stdout]  --> src/main.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use bevy::ecs::world::World;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `gridly_grids::VecGrid`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use gridly_grids::VecGrid;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs`
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::fs;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Producer`, `Record`, and `RequiredAcks`
[INFO] [stdout]   --> src/main.rs:19:23
[INFO] [stdout]    |
[INFO] [stdout] 19 | use kafka::producer::{Producer, Record, RequiredAcks};
[INFO] [stdout]    |                       ^^^^^^^^  ^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ConnectionLostEvent` and `Endpoint`
[INFO] [stdout]   --> src/main.rs:23:48
[INFO] [stdout]    |
[INFO] [stdout] 23 |         certificate::CertificateRetrievalMode, ConnectionLostEvent, Endpoint, QuinnetServerPlugin,
[INFO] [stdout]    |                                                ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around pattern
[INFO] [stdout]     --> src/main.rs:1327:6
[INFO] [stdout]      |
[INFO] [stdout] 1327 |     for (mut move_actions) in move_actions_query.iter_mut() {
[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] 1327 -     for (mut move_actions) in move_actions_query.iter_mut() {
[INFO] [stdout] 1327 +     for mut move_actions in move_actions_query.iter_mut() {
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]     --> src/main.rs:1823:10
[INFO] [stdout]      |
[INFO] [stdout] 1823 |                         if (neighbor.0.x == start.x || neighbor.0.y == start.y) {
[INFO] [stdout]      |                            ^                                                  ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1823 -                         if (neighbor.0.x == start.x || neighbor.0.y == start.y) {
[INFO] [stdout] 1823 +                         if neighbor.0.x == start.x || neighbor.0.y == start.y {
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `bevy::prelude::App::add_plugin`: Please use `add_plugins` instead.
[INFO] [stdout]    --> src/main.rs:468:4
[INFO] [stdout]     |
[INFO] [stdout] 468 |         .add_plugin(QuinnetServerPlugin::default())
[INFO] [stdout]     |          ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `bevy::prelude::App::add_plugin`: Please use `add_plugins` instead.
[INFO] [stdout]    --> src/main.rs:468:4
[INFO] [stdout]     |
[INFO] [stdout] 468 |         .add_plugin(QuinnetServerPlugin::default())
[INFO] [stdout]     |          ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable statement
[INFO] [stdout]    --> src/main.rs:971:7
[INFO] [stdout]     |
[INFO] [stdout] 967 |                         break;
[INFO] [stdout]     |                         ----- any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 971 |                         let mut wts: Vec<(UnitId, WTCurrent)> = Vec::new();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ unreachable statement
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable statement
[INFO] [stdout]    --> src/main.rs:971:7
[INFO] [stdout]     |
[INFO] [stdout] 967 |                         break;
[INFO] [stdout]     |                         ----- any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 971 |                         let mut wts: Vec<(UnitId, WTCurrent)> = Vec::new();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ unreachable statement
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `gridly::prelude`
[INFO] [stdout]   --> src/main.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use gridly::prelude::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::ecs::system::SystemParam`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use bevy::ecs::system::SystemParam;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `gridly::prelude`
[INFO] [stdout]   --> src/main.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use gridly::prelude::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::ecs::system::SystemParam`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use bevy::ecs::system::SystemParam;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `endpoint`
[INFO] [stdout]    --> src/main.rs:769:6
[INFO] [stdout]     |
[INFO] [stdout] 769 |     let endpoint = server.endpoint_mut();
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_endpoint`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wt_max`
[INFO] [stdout]    --> src/main.rs:772:31
[INFO] [stdout]     |
[INFO] [stdout] 772 |     for (entity, mut wt_current, wt_max, unit_id, unit_team) in units.iter_mut() {
[INFO] [stdout]     |                                  ^^^^^^ help: if this is intentional, prefix it with an underscore: `_wt_max`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:825:6
[INFO] [stdout]     |
[INFO] [stdout] 825 |     let mut endpoint = server.endpoint_mut();
[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/main.rs:827:6
[INFO] [stdout]     |
[INFO] [stdout] 827 |     let mut map = &mut map_query.single_mut().map;
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:846:19
[INFO] [stdout]     |
[INFO] [stdout] 846 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                  ----^^^^^^^^^^^^
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:867:37
[INFO] [stdout]     |
[INFO] [stdout] 867 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                    ----^^^^^^^^^^
[INFO] [stdout]     |                                                    |
[INFO] [stdout]     |                                                    help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:885:37
[INFO] [stdout]     |
[INFO] [stdout] 885 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                    ----^^^^^^^^^^
[INFO] [stdout]     |                                                    |
[INFO] [stdout]     |                                                    help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `unit_actions`
[INFO] [stdout]    --> src/main.rs:846:19
[INFO] [stdout]     |
[INFO] [stdout] 846 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_unit_actions`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]    --> src/main.rs:867:11
[INFO] [stdout]     |
[INFO] [stdout] 867 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wt_current`
[INFO] [stdout]    --> src/main.rs:867:37
[INFO] [stdout]     |
[INFO] [stdout] 867 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_wt_current`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wt_max`
[INFO] [stdout]    --> src/main.rs:867:53
[INFO] [stdout]     |
[INFO] [stdout] 867 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                                    ^^^^^^ help: if this is intentional, prefix it with an underscore: `_wt_max`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `attacker`
[INFO] [stdout]    --> src/main.rs:881:34
[INFO] [stdout]     |
[INFO] [stdout] 881 |                 ClientMessage::BasicAttack { attacker, target, damage } => {
[INFO] [stdout]     |                                              ^^^^^^^^ help: try ignoring the field: `attacker: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wt_current`
[INFO] [stdout]    --> src/main.rs:885:37
[INFO] [stdout]     |
[INFO] [stdout] 885 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_wt_current`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wt_max`
[INFO] [stdout]    --> src/main.rs:885:53
[INFO] [stdout]     |
[INFO] [stdout] 885 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                                    ^^^^^^ help: if this is intentional, prefix it with an underscore: `_wt_max`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:937:5
[INFO] [stdout]     |
[INFO] [stdout] 937 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:939:5
[INFO] [stdout]     |
[INFO] [stdout] 939 |     mut units: Query<(&UnitId, &WTCurrent)>,
[INFO] [stdout]     |     ----^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:943:9
[INFO] [stdout]     |
[INFO] [stdout] 943 |     let mut endpoint = server.endpoint_mut();
[INFO] [stdout]     |         ----^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/main.rs:937:5
[INFO] [stdout]     |
[INFO] [stdout] 937 |     mut commands: Commands,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `units`
[INFO] [stdout]    --> src/main.rs:939:5
[INFO] [stdout]     |
[INFO] [stdout] 939 |     mut units: Query<(&UnitId, &WTCurrent)>,
[INFO] [stdout]     |     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_units`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1004:59
[INFO] [stdout]      |
[INFO] [stdout] 1004 | fn handle_wait_client_message(mut server: ResMut<Server>, mut commands: Commands, mut next_state: ResMut<NextState<GameState>>) {
[INFO] [stdout]      |                                                           ----^^^^^^^^
[INFO] [stdout]      |                                                           |
[INFO] [stdout]      |                                                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1005:6
[INFO] [stdout]      |
[INFO] [stdout] 1005 |     let mut endpoint = server.endpoint_mut();
[INFO] [stdout]      |         ----^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]     --> src/main.rs:1004:59
[INFO] [stdout]      |
[INFO] [stdout] 1004 | fn handle_wait_client_message(mut server: ResMut<Server>, mut commands: Commands, mut next_state: ResMut<NextState<GameState>>) {
[INFO] [stdout]      |                                                           ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]     --> src/main.rs:1032:6
[INFO] [stdout]      |
[INFO] [stdout] 1032 |     for i in 0..30 {
[INFO] [stdout]      |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `j`
[INFO] [stdout]     --> src/main.rs:1034:7
[INFO] [stdout]      |
[INFO] [stdout] 1034 |         for j in 0..30 {
[INFO] [stdout]      |             ^ help: if this is intentional, prefix it with an underscore: `_j`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1063:1
[INFO] [stdout]      |
[INFO] [stdout] 1063 | mut transform_query: Query<&Transform>,
[INFO] [stdout]      | ----^^^^^^^^^^^^^^^
[INFO] [stdout]      | |
[INFO] [stdout]      | help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1086:1
[INFO] [stdout]      |
[INFO] [stdout] 1086 | mut next_state: ResMut<NextState<GameState>>,
[INFO] [stdout]      | ----^^^^^^^^^^
[INFO] [stdout]      | |
[INFO] [stdout]      | help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `next_state`
[INFO] [stdout]     --> src/main.rs:1086:1
[INFO] [stdout]      |
[INFO] [stdout] 1086 | mut next_state: ResMut<NextState<GameState>>,
[INFO] [stdout]      | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1148:6
[INFO] [stdout]      |
[INFO] [stdout] 1148 |     let mut messages = &mut player_turn_messages.messages;
[INFO] [stdout]      |         ----^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `map`
[INFO] [stdout]     --> src/main.rs:1172:6
[INFO] [stdout]      |
[INFO] [stdout] 1172 |     let map = &map_query.single_mut().map;
[INFO] [stdout]      |         ^^^ help: if this is intentional, prefix it with an underscore: `_map`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1217:1
[INFO] [stdout]      |
[INFO] [stdout] 1217 | mut commands: Commands,
[INFO] [stdout]      | ----^^^^^^^^
[INFO] [stdout]      | |
[INFO] [stdout]      | help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1224:15
[INFO] [stdout]      |
[INFO] [stdout] 1224 |     for (entity, mut unit_actions, mut pos, move_action, mut move_actions) in unit_query.iter_mut() {
[INFO] [stdout]      |                  ----^^^^^^^^^^^^
[INFO] [stdout]      |                  |
[INFO] [stdout]      |                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1224:33
[INFO] [stdout]      |
[INFO] [stdout] 1224 |     for (entity, mut unit_actions, mut pos, move_action, mut move_actions) in unit_query.iter_mut() {
[INFO] [stdout]      |                                    ----^^^
[INFO] [stdout]      |                                    |
[INFO] [stdout]      |                                    help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]     --> src/main.rs:1217:1
[INFO] [stdout]      |
[INFO] [stdout] 1217 | mut commands: Commands,
[INFO] [stdout]      | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/main.rs:1224:7
[INFO] [stdout]      |
[INFO] [stdout] 1224 |     for (entity, mut unit_actions, mut pos, move_action, mut move_actions) in unit_query.iter_mut() {
[INFO] [stdout]      |          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `unit_actions`
[INFO] [stdout]     --> src/main.rs:1224:15
[INFO] [stdout]      |
[INFO] [stdout] 1224 |     for (entity, mut unit_actions, mut pos, move_action, mut move_actions) in unit_query.iter_mut() {
[INFO] [stdout]      |                  ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_unit_actions`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pos`
[INFO] [stdout]     --> src/main.rs:1224:33
[INFO] [stdout]      |
[INFO] [stdout] 1224 |     for (entity, mut unit_actions, mut pos, move_action, mut move_actions) in unit_query.iter_mut() {
[INFO] [stdout]      |                                    ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `endpoint`
[INFO] [stdout]    --> src/main.rs:769:6
[INFO] [stdout]     |
[INFO] [stdout] 769 |     let endpoint = server.endpoint_mut();
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_endpoint`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wt_max`
[INFO] [stdout]    --> src/main.rs:772:31
[INFO] [stdout]     |
[INFO] [stdout] 772 |     for (entity, mut wt_current, wt_max, unit_id, unit_team) in units.iter_mut() {
[INFO] [stdout]     |                                  ^^^^^^ help: if this is intentional, prefix it with an underscore: `_wt_max`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1272:6
[INFO] [stdout]      |
[INFO] [stdout] 1272 |     let mut map = &mut map_component.map;
[INFO] [stdout]      |         ----^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1282:61
[INFO] [stdout]      |
[INFO] [stdout] 1282 |         for (entity, mut unit_actions, mut pos, mut move_actions, mut dir) in unit_query.iter_mut() {
[INFO] [stdout]      |                                                                   ----^^^
[INFO] [stdout]      |                                                                   |
[INFO] [stdout]      |                                                                   help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tile_transform_query`
[INFO] [stdout]     --> src/main.rs:1266:1
[INFO] [stdout]      |
[INFO] [stdout] 1266 | tile_transform_query: Query<&Transform, (With<GameText>, Without<Unit>)>,
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tile_transform_query`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game`
[INFO] [stdout]     --> src/main.rs:1268:1
[INFO] [stdout]      |
[INFO] [stdout] 1268 | game: Res<Game>,
[INFO] [stdout]      | ^^^^ help: if this is intentional, prefix it with an underscore: `_game`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `time`
[INFO] [stdout]     --> src/main.rs:1269:1
[INFO] [stdout]      |
[INFO] [stdout] 1269 | time: Res<Time>,
[INFO] [stdout]      | ^^^^ help: if this is intentional, prefix it with an underscore: `_time`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dir`
[INFO] [stdout]     --> src/main.rs:1282:61
[INFO] [stdout]      |
[INFO] [stdout] 1282 |         for (entity, mut unit_actions, mut pos, mut move_actions, mut dir) in unit_query.iter_mut() {
[INFO] [stdout]      |                                                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `do_nothing_action`
[INFO] [stdout]     --> src/main.rs:1336:33
[INFO] [stdout]      |
[INFO] [stdout] 1336 |     for (entity, mut unit_actions, do_nothing_action) in unit_query.iter_mut() {
[INFO] [stdout]      |                                    ^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout] help: you might have meant to pattern match on the similarly named struct `DoNothingAction`
[INFO] [stdout]      |
[INFO] [stdout] 1336 -     for (entity, mut unit_actions, do_nothing_action) in unit_query.iter_mut() {
[INFO] [stdout] 1336 +     for (entity, mut unit_actions, DoNothingAction) in unit_query.iter_mut() {
[INFO] [stdout]      |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]      |
[INFO] [stdout] 1336 |     for (entity, mut unit_actions, _do_nothing_action) in unit_query.iter_mut() {
[INFO] [stdout]      |                                    +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1356:6
[INFO] [stdout]      |
[INFO] [stdout] 1356 |     let mut endpoint = server.endpoint_mut();
[INFO] [stdout]      |         ----^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target`
[INFO] [stdout]     --> src/main.rs:1394:31
[INFO] [stdout]      |
[INFO] [stdout] 1394 |                 UnitAction::BasicAttack { target, is_counterattack, damage } => {
[INFO] [stdout]      |                                           ^^^^^^ help: try ignoring the field: `target: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `damage`
[INFO] [stdout]     --> src/main.rs:1394:57
[INFO] [stdout]      |
[INFO] [stdout] 1394 |                 UnitAction::BasicAttack { target, is_counterattack, damage } => {
[INFO] [stdout]      |                                                                     ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:825:6
[INFO] [stdout]     |
[INFO] [stdout] 825 |     let mut endpoint = server.endpoint_mut();
[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/main.rs:827:6
[INFO] [stdout]     |
[INFO] [stdout] 827 |     let mut map = &mut map_query.single_mut().map;
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:846:19
[INFO] [stdout]     |
[INFO] [stdout] 846 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                  ----^^^^^^^^^^^^
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target`
[INFO] [stdout]     --> src/main.rs:1432:31
[INFO] [stdout]      |
[INFO] [stdout] 1432 |                 UnitAction::BasicAttack { target, is_counterattack, damage } => {
[INFO] [stdout]      |                                           ^^^^^^ help: try ignoring the field: `target: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `damage`
[INFO] [stdout]     --> src/main.rs:1432:57
[INFO] [stdout]      |
[INFO] [stdout] 1432 |                 UnitAction::BasicAttack { target, is_counterattack, damage } => {
[INFO] [stdout]      |                                                                     ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:867:37
[INFO] [stdout]     |
[INFO] [stdout] 867 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                    ----^^^^^^^^^^
[INFO] [stdout]     |                                                    |
[INFO] [stdout]     |                                                    help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:885:37
[INFO] [stdout]     |
[INFO] [stdout] 885 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                    ----^^^^^^^^^^
[INFO] [stdout]     |                                                    |
[INFO] [stdout]     |                                                    help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `unit_actions`
[INFO] [stdout]    --> src/main.rs:846:19
[INFO] [stdout]     |
[INFO] [stdout] 846 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_unit_actions`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]    --> src/main.rs:867:11
[INFO] [stdout]     |
[INFO] [stdout] 867 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wt_current`
[INFO] [stdout]    --> src/main.rs:867:37
[INFO] [stdout]     |
[INFO] [stdout] 867 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_wt_current`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wt_max`
[INFO] [stdout]    --> src/main.rs:867:53
[INFO] [stdout]     |
[INFO] [stdout] 867 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                                    ^^^^^^ help: if this is intentional, prefix it with an underscore: `_wt_max`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `attacker`
[INFO] [stdout]    --> src/main.rs:881:34
[INFO] [stdout]     |
[INFO] [stdout] 881 |                 ClientMessage::BasicAttack { attacker, target, damage } => {
[INFO] [stdout]     |                                              ^^^^^^^^ help: try ignoring the field: `attacker: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wt_current`
[INFO] [stdout]    --> src/main.rs:885:37
[INFO] [stdout]     |
[INFO] [stdout] 885 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                    ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_wt_current`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wt_max`
[INFO] [stdout]    --> src/main.rs:885:53
[INFO] [stdout]     |
[INFO] [stdout] 885 |                     let (entity, mut unit_actions, mut wt_current, wt_max) = current_unit_query.single_mut();
[INFO] [stdout]     |                                                                    ^^^^^^ help: if this is intentional, prefix it with an underscore: `_wt_max`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1496:6
[INFO] [stdout]      |
[INFO] [stdout] 1496 |     let mut map = &mut map_query.single_mut().map;
[INFO] [stdout]      |         ----^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `asset_server`
[INFO] [stdout]     --> src/main.rs:1489:1
[INFO] [stdout]      |
[INFO] [stdout] 1489 | asset_server: Res<AssetServer>,
[INFO] [stdout]      | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_asset_server`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tile_transform_query`
[INFO] [stdout]     --> src/main.rs:1491:1
[INFO] [stdout]      |
[INFO] [stdout] 1491 | tile_transform_query: Query<&Transform, With<GameText>>,
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tile_transform_query`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1566:8
[INFO] [stdout]      |
[INFO] [stdout] 1566 |             let mut map = &mut map_query.single_mut().map;
[INFO] [stdout]      |                 ----^^^
[INFO] [stdout]      |                 |
[INFO] [stdout]      |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:937:5
[INFO] [stdout]     |
[INFO] [stdout] 937 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:939:5
[INFO] [stdout]     |
[INFO] [stdout] 939 |     mut units: Query<(&UnitId, &WTCurrent)>,
[INFO] [stdout]     |     ----^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:943:9
[INFO] [stdout]     |
[INFO] [stdout] 943 |     let mut endpoint = server.endpoint_mut();
[INFO] [stdout]     |         ----^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/main.rs:937:5
[INFO] [stdout]     |
[INFO] [stdout] 937 |     mut commands: Commands,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `units`
[INFO] [stdout]    --> src/main.rs:939:5
[INFO] [stdout]     |
[INFO] [stdout] 939 |     mut units: Query<(&UnitId, &WTCurrent)>,
[INFO] [stdout]     |     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_units`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1004:59
[INFO] [stdout]      |
[INFO] [stdout] 1004 | fn handle_wait_client_message(mut server: ResMut<Server>, mut commands: Commands, mut next_state: ResMut<NextState<GameState>>) {
[INFO] [stdout]      |                                                           ----^^^^^^^^
[INFO] [stdout]      |                                                           |
[INFO] [stdout]      |                                                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1005:6
[INFO] [stdout]      |
[INFO] [stdout] 1005 |     let mut endpoint = server.endpoint_mut();
[INFO] [stdout]      |         ----^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]     --> src/main.rs:1004:59
[INFO] [stdout]      |
[INFO] [stdout] 1004 | fn handle_wait_client_message(mut server: ResMut<Server>, mut commands: Commands, mut next_state: ResMut<NextState<GameState>>) {
[INFO] [stdout]      |                                                           ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1590:6
[INFO] [stdout]      |
[INFO] [stdout] 1590 |     let mut endpoint = server.endpoint_mut();
[INFO] [stdout]      |         ----^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/main.rs:1594:7
[INFO] [stdout]      |
[INFO] [stdout] 1594 |     for (entity, unit_team) in unit_query.iter() {
[INFO] [stdout]      |          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1638:1
[INFO] [stdout]      |
[INFO] [stdout] 1638 | mut query: Query<Entity, Without<Window>>,
[INFO] [stdout]      | ----^^^^^
[INFO] [stdout]      | |
[INFO] [stdout]      | help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]     --> src/main.rs:1032:6
[INFO] [stdout]      |
[INFO] [stdout] 1032 |     for i in 0..30 {
[INFO] [stdout]      |         ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `j`
[INFO] [stdout]     --> src/main.rs:1034:7
[INFO] [stdout]      |
[INFO] [stdout] 1034 |         for j in 0..30 {
[INFO] [stdout]      |             ^ help: if this is intentional, prefix it with an underscore: `_j`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1748:9
[INFO] [stdout]      |
[INFO] [stdout] 1748 |                 let mut recursive_possible_tiles = find_possible_movements(map.clone(), neighbor.0, movement_range);
[INFO] [stdout]      |                     ----^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                     |
[INFO] [stdout]      |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1063:1
[INFO] [stdout]      |
[INFO] [stdout] 1063 | mut transform_query: Query<&Transform>,
[INFO] [stdout]      | ----^^^^^^^^^^^^^^^
[INFO] [stdout]      | |
[INFO] [stdout]      | help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]     --> src/main.rs:1856:3
[INFO] [stdout]      |
[INFO] [stdout] 1856 |         _ => {
[INFO] [stdout]      |         ^ no value can reach this
[INFO] [stdout]      |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]     --> src/main.rs:1856:3
[INFO] [stdout]      |
[INFO] [stdout] 1806 |         AttackType::Melee => {
[INFO] [stdout]      |         ----------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 1834 |         AttackType::Ranged => {
[INFO] [stdout]      |         ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 1856 |         _ => {
[INFO] [stdout]      |         ^ collectively making this unreachable
[INFO] [stdout]      = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1845:11
[INFO] [stdout]      |
[INFO] [stdout] 1845 |                         let mut recursive_possible_tiles = find_possible_attacks(map.clone(), neighbor.0, attack_range, attack_type);
[INFO] [stdout]      |                             ----^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                             |
[INFO] [stdout]      |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]     --> src/main.rs:1814:9
[INFO] [stdout]      |
[INFO] [stdout] 1814 |                 for i in 1..attack_range {
[INFO] [stdout]      |                     ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1086:1
[INFO] [stdout]      |
[INFO] [stdout] 1086 | mut next_state: ResMut<NextState<GameState>>,
[INFO] [stdout]      | ----^^^^^^^^^^
[INFO] [stdout]      | |
[INFO] [stdout]      | help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `next_state`
[INFO] [stdout]     --> src/main.rs:1086:1
[INFO] [stdout]      |
[INFO] [stdout] 1086 | mut next_state: ResMut<NextState<GameState>>,
[INFO] [stdout]      | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NakedSwordsman` is never constructed
[INFO] [stdout]    --> src/main.rs:150:8
[INFO] [stdout]     |
[INFO] [stdout] 150 | struct NakedSwordsman {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MoveTile` is never constructed
[INFO] [stdout]    --> src/main.rs:166:8
[INFO] [stdout]     |
[INFO] [stdout] 166 | struct MoveTile {}
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MoveTiles` is never constructed
[INFO] [stdout]    --> src/main.rs:169:8
[INFO] [stdout]     |
[INFO] [stdout] 169 | struct MoveTiles {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AttackTile` is never constructed
[INFO] [stdout]    --> src/main.rs:174:8
[INFO] [stdout]     |
[INFO] [stdout] 174 | struct AttackTile {}
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AttackTiles` is never constructed
[INFO] [stdout]    --> src/main.rs:177:8
[INFO] [stdout]     |
[INFO] [stdout] 177 | struct AttackTiles {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `message` is never read
[INFO] [stdout]    --> src/main.rs:195:2
[INFO] [stdout]     |
[INFO] [stdout] 194 | struct TalkAction {
[INFO] [stdout]     |        ---------- field in this struct
[INFO] [stdout] 195 |     message: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `is_counterattack` and `damage` are never read
[INFO] [stdout]    --> src/main.rs:201:2
[INFO] [stdout]     |
[INFO] [stdout] 199 | struct BasicAttackAction {
[INFO] [stdout]     |        ----------------- fields in this struct
[INFO] [stdout] 200 |     target: Pos,
[INFO] [stdout] 201 |     is_counterattack: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 202 |     damage: usize,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Cursor` is never constructed
[INFO] [stdout]    --> src/main.rs:225:8
[INFO] [stdout]     |
[INFO] [stdout] 225 | struct Cursor {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Tile` is never constructed
[INFO] [stdout]    --> src/main.rs:236:8
[INFO] [stdout]     |
[INFO] [stdout] 236 | struct Tile;
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:271:19
[INFO] [stdout]     |
[INFO] [stdout] 271 | struct UnitName { value: String, }
[INFO] [stdout]     |        --------   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:274:20
[INFO] [stdout]     |
[INFO] [stdout] 274 | struct UnitClass { value: String, }
[INFO] [stdout]     |        ---------   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:277:15
[INFO] [stdout]     |
[INFO] [stdout] 277 | struct PosX { value: usize, }
[INFO] [stdout]     |        ----   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:280:15
[INFO] [stdout]     |
[INFO] [stdout] 280 | struct PosY { value: usize, }
[INFO] [stdout]     |        ----   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:289:16
[INFO] [stdout]     |
[INFO] [stdout] 289 | struct HPMax { value: usize, }
[INFO] [stdout]     |        -----   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:295:16
[INFO] [stdout]     |
[INFO] [stdout] 295 | struct MPMax { value: usize, }
[INFO] [stdout]     |        -----   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:298:20
[INFO] [stdout]     |
[INFO] [stdout] 298 | struct MPCurrent { value: usize, }
[INFO] [stdout]     |        ---------   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:304:14
[INFO] [stdout]     |
[INFO] [stdout] 304 | struct VIT { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:307:14
[INFO] [stdout]     |
[INFO] [stdout] 307 | struct INT { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:310:14
[INFO] [stdout]     |
[INFO] [stdout] 310 | struct MEN { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:313:14
[INFO] [stdout]     |
[INFO] [stdout] 313 | struct AGI { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:316:14
[INFO] [stdout]     |
[INFO] [stdout] 316 | struct DEX { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:319:14
[INFO] [stdout]     |
[INFO] [stdout] 319 | struct LUK { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `map` is never read
[INFO] [stdout]    --> src/main.rs:399:6
[INFO] [stdout]     |
[INFO] [stdout] 398 | struct MapReadEvent {
[INFO] [stdout]     |        ------------ field in this struct
[INFO] [stdout] 399 |     pub map: Vec<Vec<String>>,
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `units` is never read
[INFO] [stdout]    --> src/main.rs:407:6
[INFO] [stdout]     |
[INFO] [stdout] 406 | struct UnitsReadEvent {
[INFO] [stdout]     |        -------------- field in this struct
[INFO] [stdout] 407 |     pub units: Vec<StringRecord>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `current_team` and `players` are never read
[INFO] [stdout]    --> src/main.rs:418:2
[INFO] [stdout]     |
[INFO] [stdout] 416 | struct Game {
[INFO] [stdout]     |        ---- fields in this struct
[INFO] [stdout] 417 |     current_unit: usize,
[INFO] [stdout] 418 |     current_team: usize,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 419 |     has_started: bool,
[INFO] [stdout] 420 |     players: HashMap<usize, ControlledBy>,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `two_second_timer` and `six_second_timer` are never read
[INFO] [stdout]    --> src/main.rs:445:2
[INFO] [stdout]     |
[INFO] [stdout] 444 | struct Timers {
[INFO] [stdout]     |        ------ fields in this struct
[INFO] [stdout] 445 |     two_second_timer: Timer,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 446 |     six_second_timer: Timer,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `handle_wait_client_message` is never used
[INFO] [stdout]     --> src/main.rs:1004:4
[INFO] [stdout]      |
[INFO] [stdout] 1004 | fn handle_wait_client_message(mut server: ResMut<Server>, mut commands: Commands, mut next_state: ResMut<NextState<GameState>>) {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `grid_already_setup` is never used
[INFO] [stdout]     --> src/main.rs:1052:4
[INFO] [stdout]      |
[INFO] [stdout] 1052 | fn grid_already_setup(query: Query<&Map>) -> bool {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_system_2` is never used
[INFO] [stdout]     --> src/main.rs:1061:4
[INFO] [stdout]      |
[INFO] [stdout] 1061 | fn test_system_2(
[INFO] [stdout]      |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_system_3` is never used
[INFO] [stdout]     --> src/main.rs:1075:4
[INFO] [stdout]      |
[INFO] [stdout] 1075 | fn test_system_3(
[INFO] [stdout]      |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `process_do_nothing_actions` is never used
[INFO] [stdout]     --> src/main.rs:1335:4
[INFO] [stdout]      |
[INFO] [stdout] 1335 | fn process_do_nothing_actions(mut commands: Commands, mut unit_query: Query<(Entity, &mut UnitActions, &DoNothingAction)>) {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_possible_movements` is never used
[INFO] [stdout]     --> src/main.rs:1736:4
[INFO] [stdout]      |
[INFO] [stdout] 1736 | fn find_possible_movements(map: Vec<Vec<(usize, TileType, Vec<Entity>, Vec<Entity>)>>, start: Pos, mut movement_range: isize) -> V...
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1148:6
[INFO] [stdout]      |
[INFO] [stdout] 1148 |     let mut messages = &mut player_turn_messages.messages;
[INFO] [stdout]      |         ----^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `map`
[INFO] [stdout]     --> src/main.rs:1172:6
[INFO] [stdout]      |
[INFO] [stdout] 1172 |     let map = &map_query.single_mut().map;
[INFO] [stdout]      |         ^^^ help: if this is intentional, prefix it with an underscore: `_map`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1217:1
[INFO] [stdout]      |
[INFO] [stdout] 1217 | mut commands: Commands,
[INFO] [stdout]      | ----^^^^^^^^
[INFO] [stdout]      | |
[INFO] [stdout]      | help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1224:15
[INFO] [stdout]      |
[INFO] [stdout] 1224 |     for (entity, mut unit_actions, mut pos, move_action, mut move_actions) in unit_query.iter_mut() {
[INFO] [stdout]      |                  ----^^^^^^^^^^^^
[INFO] [stdout]      |                  |
[INFO] [stdout]      |                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1224:33
[INFO] [stdout]      |
[INFO] [stdout] 1224 |     for (entity, mut unit_actions, mut pos, move_action, mut move_actions) in unit_query.iter_mut() {
[INFO] [stdout]      |                                    ----^^^
[INFO] [stdout]      |                                    |
[INFO] [stdout]      |                                    help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]     --> src/main.rs:1217:1
[INFO] [stdout]      |
[INFO] [stdout] 1217 | mut commands: Commands,
[INFO] [stdout]      | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/main.rs:1224:7
[INFO] [stdout]      |
[INFO] [stdout] 1224 |     for (entity, mut unit_actions, mut pos, move_action, mut move_actions) in unit_query.iter_mut() {
[INFO] [stdout]      |          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `unit_actions`
[INFO] [stdout]     --> src/main.rs:1224:15
[INFO] [stdout]      |
[INFO] [stdout] 1224 |     for (entity, mut unit_actions, mut pos, move_action, mut move_actions) in unit_query.iter_mut() {
[INFO] [stdout]      |                  ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_unit_actions`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pos`
[INFO] [stdout]     --> src/main.rs:1224:33
[INFO] [stdout]      |
[INFO] [stdout] 1224 |     for (entity, mut unit_actions, mut pos, move_action, mut move_actions) in unit_query.iter_mut() {
[INFO] [stdout]      |                                    ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1272:6
[INFO] [stdout]      |
[INFO] [stdout] 1272 |     let mut map = &mut map_component.map;
[INFO] [stdout]      |         ----^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1282:61
[INFO] [stdout]      |
[INFO] [stdout] 1282 |         for (entity, mut unit_actions, mut pos, mut move_actions, mut dir) in unit_query.iter_mut() {
[INFO] [stdout]      |                                                                   ----^^^
[INFO] [stdout]      |                                                                   |
[INFO] [stdout]      |                                                                   help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tile_transform_query`
[INFO] [stdout]     --> src/main.rs:1266:1
[INFO] [stdout]      |
[INFO] [stdout] 1266 | tile_transform_query: Query<&Transform, (With<GameText>, Without<Unit>)>,
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tile_transform_query`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game`
[INFO] [stdout]     --> src/main.rs:1268:1
[INFO] [stdout]      |
[INFO] [stdout] 1268 | game: Res<Game>,
[INFO] [stdout]      | ^^^^ help: if this is intentional, prefix it with an underscore: `_game`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `time`
[INFO] [stdout]     --> src/main.rs:1269:1
[INFO] [stdout]      |
[INFO] [stdout] 1269 | time: Res<Time>,
[INFO] [stdout]      | ^^^^ help: if this is intentional, prefix it with an underscore: `_time`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dir`
[INFO] [stdout]     --> src/main.rs:1282:61
[INFO] [stdout]      |
[INFO] [stdout] 1282 |         for (entity, mut unit_actions, mut pos, mut move_actions, mut dir) in unit_query.iter_mut() {
[INFO] [stdout]      |                                                                   ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `do_nothing_action`
[INFO] [stdout]     --> src/main.rs:1336:33
[INFO] [stdout]      |
[INFO] [stdout] 1336 |     for (entity, mut unit_actions, do_nothing_action) in unit_query.iter_mut() {
[INFO] [stdout]      |                                    ^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout] help: you might have meant to pattern match on the similarly named struct `DoNothingAction`
[INFO] [stdout]      |
[INFO] [stdout] 1336 -     for (entity, mut unit_actions, do_nothing_action) in unit_query.iter_mut() {
[INFO] [stdout] 1336 +     for (entity, mut unit_actions, DoNothingAction) in unit_query.iter_mut() {
[INFO] [stdout]      |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]      |
[INFO] [stdout] 1336 |     for (entity, mut unit_actions, _do_nothing_action) in unit_query.iter_mut() {
[INFO] [stdout]      |                                    +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1356:6
[INFO] [stdout]      |
[INFO] [stdout] 1356 |     let mut endpoint = server.endpoint_mut();
[INFO] [stdout]      |         ----^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target`
[INFO] [stdout]     --> src/main.rs:1394:31
[INFO] [stdout]      |
[INFO] [stdout] 1394 |                 UnitAction::BasicAttack { target, is_counterattack, damage } => {
[INFO] [stdout]      |                                           ^^^^^^ help: try ignoring the field: `target: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `damage`
[INFO] [stdout]     --> src/main.rs:1394:57
[INFO] [stdout]      |
[INFO] [stdout] 1394 |                 UnitAction::BasicAttack { target, is_counterattack, damage } => {
[INFO] [stdout]      |                                                                     ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target`
[INFO] [stdout]     --> src/main.rs:1432:31
[INFO] [stdout]      |
[INFO] [stdout] 1432 |                 UnitAction::BasicAttack { target, is_counterattack, damage } => {
[INFO] [stdout]      |                                           ^^^^^^ help: try ignoring the field: `target: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `damage`
[INFO] [stdout]     --> src/main.rs:1432:57
[INFO] [stdout]      |
[INFO] [stdout] 1432 |                 UnitAction::BasicAttack { target, is_counterattack, damage } => {
[INFO] [stdout]      |                                                                     ^^^^^^ help: try ignoring the field: `damage: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1496:6
[INFO] [stdout]      |
[INFO] [stdout] 1496 |     let mut map = &mut map_query.single_mut().map;
[INFO] [stdout]      |         ----^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `asset_server`
[INFO] [stdout]     --> src/main.rs:1489:1
[INFO] [stdout]      |
[INFO] [stdout] 1489 | asset_server: Res<AssetServer>,
[INFO] [stdout]      | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_asset_server`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tile_transform_query`
[INFO] [stdout]     --> src/main.rs:1491:1
[INFO] [stdout]      |
[INFO] [stdout] 1491 | tile_transform_query: Query<&Transform, With<GameText>>,
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tile_transform_query`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1566:8
[INFO] [stdout]      |
[INFO] [stdout] 1566 |             let mut map = &mut map_query.single_mut().map;
[INFO] [stdout]      |                 ----^^^
[INFO] [stdout]      |                 |
[INFO] [stdout]      |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1590:6
[INFO] [stdout]      |
[INFO] [stdout] 1590 |     let mut endpoint = server.endpoint_mut();
[INFO] [stdout]      |         ----^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]     --> src/main.rs:1594:7
[INFO] [stdout]      |
[INFO] [stdout] 1594 |     for (entity, unit_team) in unit_query.iter() {
[INFO] [stdout]      |          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1638:1
[INFO] [stdout]      |
[INFO] [stdout] 1638 | mut query: Query<Entity, Without<Window>>,
[INFO] [stdout]      | ----^^^^^
[INFO] [stdout]      | |
[INFO] [stdout]      | help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1748:9
[INFO] [stdout]      |
[INFO] [stdout] 1748 |                 let mut recursive_possible_tiles = find_possible_movements(map.clone(), neighbor.0, movement_range);
[INFO] [stdout]      |                     ----^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                     |
[INFO] [stdout]      |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]     --> src/main.rs:1856:3
[INFO] [stdout]      |
[INFO] [stdout] 1856 |         _ => {
[INFO] [stdout]      |         ^ no value can reach this
[INFO] [stdout]      |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]     --> src/main.rs:1856:3
[INFO] [stdout]      |
[INFO] [stdout] 1806 |         AttackType::Melee => {
[INFO] [stdout]      |         ----------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 1834 |         AttackType::Ranged => {
[INFO] [stdout]      |         ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 1856 |         _ => {
[INFO] [stdout]      |         ^ collectively making this unreachable
[INFO] [stdout]      = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1845:11
[INFO] [stdout]      |
[INFO] [stdout] 1845 |                         let mut recursive_possible_tiles = find_possible_attacks(map.clone(), neighbor.0, attack_range, attack_type);
[INFO] [stdout]      |                             ----^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                             |
[INFO] [stdout]      |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]     --> src/main.rs:1814:9
[INFO] [stdout]      |
[INFO] [stdout] 1814 |                 for i in 1..attack_range {
[INFO] [stdout]      |                     ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NakedSwordsman` is never constructed
[INFO] [stdout]    --> src/main.rs:150:8
[INFO] [stdout]     |
[INFO] [stdout] 150 | struct NakedSwordsman {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MoveTile` is never constructed
[INFO] [stdout]    --> src/main.rs:166:8
[INFO] [stdout]     |
[INFO] [stdout] 166 | struct MoveTile {}
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MoveTiles` is never constructed
[INFO] [stdout]    --> src/main.rs:169:8
[INFO] [stdout]     |
[INFO] [stdout] 169 | struct MoveTiles {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AttackTile` is never constructed
[INFO] [stdout]    --> src/main.rs:174:8
[INFO] [stdout]     |
[INFO] [stdout] 174 | struct AttackTile {}
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AttackTiles` is never constructed
[INFO] [stdout]    --> src/main.rs:177:8
[INFO] [stdout]     |
[INFO] [stdout] 177 | struct AttackTiles {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `message` is never read
[INFO] [stdout]    --> src/main.rs:195:2
[INFO] [stdout]     |
[INFO] [stdout] 194 | struct TalkAction {
[INFO] [stdout]     |        ---------- field in this struct
[INFO] [stdout] 195 |     message: String,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `is_counterattack` and `damage` are never read
[INFO] [stdout]    --> src/main.rs:201:2
[INFO] [stdout]     |
[INFO] [stdout] 199 | struct BasicAttackAction {
[INFO] [stdout]     |        ----------------- fields in this struct
[INFO] [stdout] 200 |     target: Pos,
[INFO] [stdout] 201 |     is_counterattack: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 202 |     damage: usize,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Cursor` is never constructed
[INFO] [stdout]    --> src/main.rs:225:8
[INFO] [stdout]     |
[INFO] [stdout] 225 | struct Cursor {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Tile` is never constructed
[INFO] [stdout]    --> src/main.rs:236:8
[INFO] [stdout]     |
[INFO] [stdout] 236 | struct Tile;
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:271:19
[INFO] [stdout]     |
[INFO] [stdout] 271 | struct UnitName { value: String, }
[INFO] [stdout]     |        --------   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:274:20
[INFO] [stdout]     |
[INFO] [stdout] 274 | struct UnitClass { value: String, }
[INFO] [stdout]     |        ---------   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:277:15
[INFO] [stdout]     |
[INFO] [stdout] 277 | struct PosX { value: usize, }
[INFO] [stdout]     |        ----   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:280:15
[INFO] [stdout]     |
[INFO] [stdout] 280 | struct PosY { value: usize, }
[INFO] [stdout]     |        ----   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:289:16
[INFO] [stdout]     |
[INFO] [stdout] 289 | struct HPMax { value: usize, }
[INFO] [stdout]     |        -----   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:295:16
[INFO] [stdout]     |
[INFO] [stdout] 295 | struct MPMax { value: usize, }
[INFO] [stdout]     |        -----   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:298:20
[INFO] [stdout]     |
[INFO] [stdout] 298 | struct MPCurrent { value: usize, }
[INFO] [stdout]     |        ---------   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:304:14
[INFO] [stdout]     |
[INFO] [stdout] 304 | struct VIT { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:307:14
[INFO] [stdout]     |
[INFO] [stdout] 307 | struct INT { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:310:14
[INFO] [stdout]     |
[INFO] [stdout] 310 | struct MEN { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:313:14
[INFO] [stdout]     |
[INFO] [stdout] 313 | struct AGI { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:316:14
[INFO] [stdout]     |
[INFO] [stdout] 316 | struct DEX { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]    --> src/main.rs:319:14
[INFO] [stdout]     |
[INFO] [stdout] 319 | struct LUK { value: usize, }
[INFO] [stdout]     |        ---   ^^^^^
[INFO] [stdout]     |        |
[INFO] [stdout]     |        field in this struct
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `map` is never read
[INFO] [stdout]    --> src/main.rs:399:6
[INFO] [stdout]     |
[INFO] [stdout] 398 | struct MapReadEvent {
[INFO] [stdout]     |        ------------ field in this struct
[INFO] [stdout] 399 |     pub map: Vec<Vec<String>>,
[INFO] [stdout]     |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `units` is never read
[INFO] [stdout]    --> src/main.rs:407:6
[INFO] [stdout]     |
[INFO] [stdout] 406 | struct UnitsReadEvent {
[INFO] [stdout]     |        -------------- field in this struct
[INFO] [stdout] 407 |     pub units: Vec<StringRecord>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `current_team` and `players` are never read
[INFO] [stdout]    --> src/main.rs:418:2
[INFO] [stdout]     |
[INFO] [stdout] 416 | struct Game {
[INFO] [stdout]     |        ---- fields in this struct
[INFO] [stdout] 417 |     current_unit: usize,
[INFO] [stdout] 418 |     current_team: usize,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 419 |     has_started: bool,
[INFO] [stdout] 420 |     players: HashMap<usize, ControlledBy>,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `two_second_timer` and `six_second_timer` are never read
[INFO] [stdout]    --> src/main.rs:445:2
[INFO] [stdout]     |
[INFO] [stdout] 444 | struct Timers {
[INFO] [stdout]     |        ------ fields in this struct
[INFO] [stdout] 445 |     two_second_timer: Timer,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 446 |     six_second_timer: Timer,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `handle_wait_client_message` is never used
[INFO] [stdout]     --> src/main.rs:1004:4
[INFO] [stdout]      |
[INFO] [stdout] 1004 | fn handle_wait_client_message(mut server: ResMut<Server>, mut commands: Commands, mut next_state: ResMut<NextState<GameState>>) {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `grid_already_setup` is never used
[INFO] [stdout]     --> src/main.rs:1052:4
[INFO] [stdout]      |
[INFO] [stdout] 1052 | fn grid_already_setup(query: Query<&Map>) -> bool {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_system_2` is never used
[INFO] [stdout]     --> src/main.rs:1061:4
[INFO] [stdout]      |
[INFO] [stdout] 1061 | fn test_system_2(
[INFO] [stdout]      |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_system_3` is never used
[INFO] [stdout]     --> src/main.rs:1075:4
[INFO] [stdout]      |
[INFO] [stdout] 1075 | fn test_system_3(
[INFO] [stdout]      |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `process_do_nothing_actions` is never used
[INFO] [stdout]     --> src/main.rs:1335:4
[INFO] [stdout]      |
[INFO] [stdout] 1335 | fn process_do_nothing_actions(mut commands: Commands, mut unit_query: Query<(Entity, &mut UnitActions, &DoNothingAction)>) {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_possible_movements` is never used
[INFO] [stdout]     --> src/main.rs:1736:4
[INFO] [stdout]      |
[INFO] [stdout] 1736 | fn find_possible_movements(map: Vec<Vec<(usize, TileType, Vec<Entity>, Vec<Entity>)>>, start: Pos, mut movement_range: isize) -> V...
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 7m 35s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: openssl v0.10.55
[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" "3de807e0c5f21cb37666f0eb5b60877906c7e0fcf4a9d146d16a4809c2c5f2cf", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3de807e0c5f21cb37666f0eb5b60877906c7e0fcf4a9d146d16a4809c2c5f2cf", kill_on_drop: false }`
[INFO] [stdout] 3de807e0c5f21cb37666f0eb5b60877906c7e0fcf4a9d146d16a4809c2c5f2cf
