[INFO] cloning repository https://github.com/lucasmerlin/towerthrower
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/lucasmerlin/towerthrower" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Flucasmerlin%2Ftowerthrower", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Flucasmerlin%2Ftowerthrower'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 85969973c3cf18e5c80bf631d5282edb2cfe4744
[INFO] checking lucasmerlin/towerthrower against master#4d1bd0db7f489b22c6d8aa2385937a95412c015b for pr-114682
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Flucasmerlin%2Ftowerthrower" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/lucasmerlin/towerthrower on toolchain 4d1bd0db7f489b22c6d8aa2385937a95412c015b
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+4d1bd0db7f489b22c6d8aa2385937a95412c015b" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] removed /workspace/builds/worker-2-tc1/source/.cargo/config.toml
[INFO] started tweaking git repo https://github.com/lucasmerlin/towerthrower
[INFO] finished tweaking git repo https://github.com/lucasmerlin/towerthrower
[INFO] tweaked toml for git repo https://github.com/lucasmerlin/towerthrower written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] crate git repo https://github.com/lucasmerlin/towerthrower 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" "+4d1bd0db7f489b22c6d8aa2385937a95412c015b" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded coreaudio-rs v0.11.3
[INFO] [stderr]   Downloaded bevy_asset_macros v0.12.1
[INFO] [stderr]   Downloaded bevy_core v0.12.1
[INFO] [stderr]   Downloaded accesskit_macos v0.10.1
[INFO] [stderr]   Downloaded bevy_encase_derive v0.12.1
[INFO] [stderr]   Downloaded thiserror-core-impl v1.0.50
[INFO] [stderr]   Downloaded symphonia v0.5.3
[INFO] [stderr]   Downloaded bevy_transform v0.12.1
[INFO] [stderr]   Downloaded coreaudio-sys v0.2.14
[INFO] [stderr]   Downloaded bevy_gizmos v0.12.1
[INFO] [stderr]   Downloaded bevy_a11y v0.12.1
[INFO] [stderr]   Downloaded bevy_internal v0.12.1
[INFO] [stderr]   Downloaded bevy_ui v0.12.1
[INFO] [stderr]   Downloaded ecolor v0.23.0
[INFO] [stderr]   Downloaded bevy_pbr v0.12.1
[INFO] [stderr]   Downloaded egui v0.23.0
[INFO] [stderr]   Downloaded bevy_core_pipeline v0.12.1
[INFO] [stderr]   Downloaded bevy_ecs v0.12.1
[INFO] [stderr]   Downloaded zerocopy-derive v0.7.28
[INFO] [stderr]   Downloaded bevy_render v0.12.1
[INFO] [stderr]   Downloaded nalgebra v0.32.3
[INFO] [stderr]   Downloaded spade v2.4.1
[INFO] [stderr]   Downloaded rapier2d v0.17.2
[INFO] [stderr]   Downloaded robust v1.1.0
[INFO] [stderr]   Downloaded epaint v0.23.0
[INFO] [stderr]   Downloaded bevy_egui v0.23.0
[INFO] [stderr]   Downloaded wide v0.7.13
[INFO] [stderr]   Downloaded accesskit_windows v0.15.1
[INFO] [stderr]   Downloaded matrixmultiply v0.3.8
[INFO] [stderr]   Downloaded bindgen v0.69.1
[INFO] [stderr]   Downloaded gilrs v0.10.3
[INFO] [stderr]   Downloaded bevy v0.12.1
[INFO] [stderr]   Downloaded parry2d v0.13.5
[INFO] [stderr]   Downloaded taffy v0.3.18
[INFO] [stderr]   Downloaded emath v0.23.0
[INFO] [stderr]   Downloaded bevy_sprite v0.12.1
[INFO] [stderr]   Downloaded bevy_input v0.12.1
[INFO] [stderr]   Downloaded io-kit-sys v0.4.0
[INFO] [stderr]   Downloaded accesskit v0.12.1
[INFO] [stderr]   Downloaded bevy_app v0.12.1
[INFO] [stderr]   Downloaded bevy_ecs_macros v0.12.1
[INFO] [stderr]   Downloaded bevy_time v0.12.1
[INFO] [stderr]   Downloaded bevy_window v0.12.1
[INFO] [stderr]   Downloaded bevy_utils_proc_macros v0.12.1
[INFO] [stderr]   Downloaded bevy_macro_utils v0.12.1
[INFO] [stderr]   Downloaded accesskit_winit v0.15.0
[INFO] [stderr]   Downloaded bevy_math v0.12.1
[INFO] [stderr]   Downloaded bevy_text v0.12.1
[INFO] [stderr]   Downloaded bevy_utils v0.12.1
[INFO] [stderr]   Downloaded bevy_reflect_derive v0.12.1
[INFO] [stderr]   Downloaded bevy_asset v0.12.1
[INFO] [stderr]   Downloaded bevy_winit v0.12.1
[INFO] [stderr]   Downloaded symphonia-core v0.5.3
[INFO] [stderr]   Downloaded bevy_scene v0.12.1
[INFO] [stderr]   Downloaded naga_oil v0.10.1
[INFO] [stderr]   Downloaded blake3 v1.5.0
[INFO] [stderr]   Downloaded bevy-inspector-egui-derive v0.21.0
[INFO] [stderr]   Downloaded zerocopy v0.7.28
[INFO] [stderr]   Downloaded rodio v0.17.3
[INFO] [stderr]   Downloaded accesskit_consumer v0.16.1
[INFO] [stderr]   Downloaded bevy_gltf v0.12.1
[INFO] [stderr]   Downloaded bevy_hierarchy v0.12.1
[INFO] [stderr]   Downloaded bevy_derive v0.12.1
[INFO] [stderr]   Downloaded bevy_ptr v0.12.1
[INFO] [stderr]   Downloaded hound v3.5.1
[INFO] [stderr]   Downloaded bevy_mikktspace v0.12.1
[INFO] [stderr]   Downloaded nalgebra-macros v0.2.1
[INFO] [stderr]   Downloaded safe_arch v0.7.1
[INFO] [stderr]   Downloaded thiserror-core v1.0.50
[INFO] [stderr]   Downloaded bevy_tasks v0.12.1
[INFO] [stderr]   Downloaded bevy_log v0.12.1
[INFO] [stderr]   Downloaded bevy_diagnostic v0.12.1
[INFO] [stderr]   Downloaded inotify v0.10.2
[INFO] [stderr]   Downloaded gilrs-core v0.5.9
[INFO] [stderr]   Downloaded bevy_animation v0.12.1
[INFO] [stderr]   Downloaded bevy_render_macros v0.12.1
[INFO] [stderr]   Downloaded bevy_gilrs v0.12.1
[INFO] [stderr]   Downloaded nonmax v0.5.5
[INFO] [stderr]   Downloaded bevy_audio v0.12.1
[INFO] [stderr]   Downloaded bevy_reflect v0.12.1
[INFO] [stderr]   Downloaded symphonia-bundle-mp3 v0.5.3
[INFO] [stderr]   Downloaded symphonia-metadata v0.5.3
[INFO] [stderr]   Downloaded bevy_rapier2d v0.23.0
[INFO] [stderr]   Downloaded bevy-inspector-egui v0.21.0
[INFO] [stderr]   Downloaded bevy_tweening v0.9.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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+4d1bd0db7f489b22c6d8aa2385937a95412c015b" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] d865026b04b4ae74c15609e9701b31d858b7c34f9470d00b85740142e481e887
[INFO] running `Command { std: "docker" "start" "-a" "d865026b04b4ae74c15609e9701b31d858b7c34f9470d00b85740142e481e887", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "d865026b04b4ae74c15609e9701b31d858b7c34f9470d00b85740142e481e887", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d865026b04b4ae74c15609e9701b31d858b7c34f9470d00b85740142e481e887", kill_on_drop: false }`
[INFO] [stdout] d865026b04b4ae74c15609e9701b31d858b7c34f9470d00b85740142e481e887
[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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+4d1bd0db7f489b22c6d8aa2385937a95412c015b" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 892c86bbf84536f30da666426a1d0a6db822f634b6fbe8ee089b9388c8ddc028
[INFO] running `Command { std: "docker" "start" "-a" "892c86bbf84536f30da666426a1d0a6db822f634b6fbe8ee089b9388c8ddc028", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.70
[INFO] [stderr]    Compiling unicode-ident v1.0.12
[INFO] [stderr]    Compiling autocfg v1.1.0
[INFO] [stderr]     Checking cfg-if v1.0.0
[INFO] [stderr]    Compiling libc v0.2.150
[INFO] [stderr]    Compiling serde v1.0.193
[INFO] [stderr]     Checking once_cell v1.18.0
[INFO] [stderr]    Compiling version_check v0.9.4
[INFO] [stderr]    Compiling crossbeam-utils v0.8.16
[INFO] [stderr]     Checking bitflags v1.3.2
[INFO] [stderr]     Checking pin-project-lite v0.2.13
[INFO] [stderr]     Checking zerocopy v0.7.28
[INFO] [stderr]    Compiling libm v0.2.8
[INFO] [stderr]     Checking log v0.4.20
[INFO] [stderr]     Checking allocator-api2 v0.2.16
[INFO] [stderr]    Compiling thiserror v1.0.50
[INFO] [stderr]    Compiling futures-core v0.3.29
[INFO] [stderr]    Compiling hashbrown v0.14.3
[INFO] [stderr]    Compiling equivalent v1.0.1
[INFO] [stderr]     Checking parking v2.2.0
[INFO] [stderr]     Checking tracing-core v0.1.32
[INFO] [stderr]    Compiling winnow v0.5.19
[INFO] [stderr]    Compiling toml_datetime v0.6.5
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]     Checking memchr v2.6.4
[INFO] [stderr]     Checking event-listener v2.5.3
[INFO] [stderr]     Checking futures-io v0.3.29
[INFO] [stderr]     Checking fastrand v2.0.1
[INFO] [stderr]     Checking futures-lite v2.1.0
[INFO] [stderr]     Checking instant v0.1.12
[INFO] [stderr]     Checking async-task v4.5.0
[INFO] [stderr]     Checking fixedbitset v0.4.2
[INFO] [stderr]     Checking downcast-rs v1.2.0
[INFO] [stderr]     Checking fastrand v1.9.0
[INFO] [stderr]     Checking waker-fn v1.1.1
[INFO] [stderr]     Checking nonmax v0.5.5
[INFO] [stderr]     Checking thread_local v1.1.7
[INFO] [stderr]     Checking scopeguard v1.2.0
[INFO] [stderr]     Checking smol_str v0.2.0
[INFO] [stderr]     Checking bevy_ptr v0.12.1
[INFO] [stderr]     Checking concurrent-queue v2.4.0
[INFO] [stderr]     Checking lazy_static v1.4.0
[INFO] [stderr]    Compiling indexmap v2.1.0
[INFO] [stderr]     Checking arrayvec v0.7.4
[INFO] [stderr]    Compiling parking_lot_core v0.9.9
[INFO] [stderr]     Checking regex-syntax v0.8.2
[INFO] [stderr]     Checking futures-lite v1.13.0
[INFO] [stderr]     Checking aho-corasick v1.1.2
[INFO] [stderr]     Checking regex-syntax v0.6.29
[INFO] [stderr]     Checking event-listener v4.0.0
[INFO] [stderr]     Checking async-channel v1.9.0
[INFO] [stderr]     Checking overload v0.1.1
[INFO] [stderr]     Checking nu-ansi-term v0.46.0
[INFO] [stderr]     Checking sharded-slab v0.1.7
[INFO] [stderr]    Compiling quote v1.0.33
[INFO] [stderr]     Checking event-listener-strategy v0.4.0
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]    Compiling lock_api v0.4.11
[INFO] [stderr]    Compiling ahash v0.8.6
[INFO] [stderr]     Checking async-lock v3.2.0
[INFO] [stderr]    Compiling syn v2.0.39
[INFO] [stderr]    Compiling getrandom v0.2.11
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]    Compiling num-bigint v0.4.4
[INFO] [stderr]    Compiling uuid v1.6.1
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]    Compiling pkg-config v0.3.27
[INFO] [stderr]     Checking async-executor v1.8.0
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]     Checking tracing-log v0.1.4
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]     Checking bevy_tasks v0.12.1
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]     Checking crossbeam-channel v0.5.8
[INFO] [stderr]     Checking raw-window-handle v0.5.2
[INFO] [stderr]     Checking bit-vec v0.6.3
[INFO] [stderr]     Checking unicode-xid v0.2.4
[INFO] [stderr]     Checking termcolor v1.4.0
[INFO] [stderr]    Compiling toml_edit v0.20.7
[INFO] [stderr]     Checking simd-adler32 v0.3.7
[INFO] [stderr]    Compiling crc32fast v1.3.2
[INFO] [stderr]     Checking unicode-width v0.1.11
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]     Checking bit-set v0.5.3
[INFO] [stderr]     Checking pp-rs v0.2.1
[INFO] [stderr]    Compiling cc v1.0.83
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking libloading v0.7.4
[INFO] [stderr]     Checking hexf-parse v0.2.1
[INFO] [stderr]    Compiling ash v0.37.3+1.3.251
[INFO] [stderr]     Checking spirv v0.2.0+1.5.4
[INFO] [stderr]     Checking atomic-waker v1.1.2
[INFO] [stderr]     Checking adler v1.0.2
[INFO] [stderr]    Compiling khronos-egl v4.1.0
[INFO] [stderr]     Checking miniz_oxide v0.7.1
[INFO] [stderr]     Checking regex-automata v0.1.10
[INFO] [stderr]     Checking piper v0.2.1
[INFO] [stderr]     Checking async-channel v2.1.1
[INFO] [stderr]    Compiling async-fs v1.6.0
[INFO] [stderr]     Checking accesskit v0.12.1
[INFO] [stderr]     Checking fdeflate v0.3.1
[INFO] [stderr]     Checking regex-automata v0.4.3
[INFO] [stderr]     Checking async-lock v2.8.0
[INFO] [stderr]     Checking flate2 v1.0.28
[INFO] [stderr]     Checking glow v0.12.3
[INFO] [stderr]    Compiling thiserror-core v1.0.50
[INFO] [stderr]     Checking renderdoc-sys v1.0.0
[INFO] [stderr]     Checking base64 v0.21.5
[INFO] [stderr]     Checking arrayref v0.3.7
[INFO] [stderr]     Checking constant_time_eq v0.3.0
[INFO] [stderr]     Checking profiling v1.0.11
[INFO] [stderr]     Checking matchers v0.1.0
[INFO] [stderr]     Checking static_assertions v1.1.0
[INFO] [stderr]     Checking async-broadcast v0.5.1
[INFO] [stderr]     Checking const_soft_float v0.1.4
[INFO] [stderr]     Checking color_quant v1.1.0
[INFO] [stderr]     Checking png v0.17.10
[INFO] [stderr]     Checking twox-hash v1.6.3
[INFO] [stderr]     Checking regex-syntax v0.7.5
[INFO] [stderr]     Checking data-encoding v2.5.0
[INFO] [stderr]     Checking const_panic v0.2.8
[INFO] [stderr]     Checking ktx2 v0.3.0
[INFO] [stderr]     Checking constgebra v0.1.3
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking tinyvec_macros v0.1.1
[INFO] [stderr]     Checking ttf-parser v0.20.0
[INFO] [stderr]     Checking percent-encoding v2.3.1
[INFO] [stderr]     Checking tinyvec v1.6.0
[INFO] [stderr]     Checking radsort v0.1.0
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling xml-rs v0.8.19
[INFO] [stderr]     Checking ab_glyph_rasterizer v0.1.8
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]     Checking euclid v0.22.9
[INFO] [stderr]     Checking encoding_rs v0.8.33
[INFO] [stderr]    Compiling serde_json v1.0.108
[INFO] [stderr]     Checking svg_fmt v0.4.1
[INFO] [stderr]    Compiling cfg_aliases v0.1.1
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]    Compiling wayland-scanner v0.29.5
[INFO] [stderr]     Checking nix v0.24.3
[INFO] [stderr]    Compiling slotmap v1.0.7
[INFO] [stderr]    Compiling inflections v1.1.1
[INFO] [stderr]     Checking guillotiere v0.6.2
[INFO] [stderr]    Compiling cpal v0.15.2
[INFO] [stderr]     Checking ryu v1.0.15
[INFO] [stderr]     Checking itoa v1.0.9
[INFO] [stderr]     Checking vec_map v0.8.2
[INFO] [stderr]     Checking rectangle-pack v0.4.2
[INFO] [stderr]     Checking alsa v0.7.1
[INFO] [stderr]     Checking inotify v0.10.2
[INFO] [stderr]     Checking mio v0.8.9
[INFO] [stderr]     Checking ogg v0.8.0
[INFO] [stderr]    Compiling gilrs v0.10.3
[INFO] [stderr]     Checking xi-unicode v0.3.0
[INFO] [stderr]     Checking dasp_sample v0.11.0
[INFO] [stderr]     Checking regex v1.10.2
[INFO] [stderr]     Checking lewton v0.10.2
[INFO] [stderr]    Compiling memoffset v0.7.1
[INFO] [stderr]    Compiling syn v1.0.65
[INFO] [stderr]     Checking fnv v1.0.7
[INFO] [stderr]     Checking hound v3.5.1
[INFO] [stderr]    Compiling bevy_macro_utils v0.12.1
[INFO] [stderr]    Compiling encase_derive_impl v0.6.1
[INFO] [stderr]     Checking grid v0.10.0
[INFO] [stderr]     Checking sysinfo v0.29.11
[INFO] [stderr]    Compiling memoffset v0.9.0
[INFO] [stderr]     Checking owned_ttf_parser v0.20.0
[INFO] [stderr]     Checking taffy v0.3.18
[INFO] [stderr]     Checking ab_glyph v0.2.23
[INFO] [stderr]     Checking base64 v0.13.1
[INFO] [stderr]    Compiling paste v1.0.14
[INFO] [stderr]     Checking glyph_brush_layout v0.2.3
[INFO] [stderr]     Checking num-complex v0.4.4
[INFO] [stderr]    Compiling matrixmultiply v0.3.8
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.15
[INFO] [stderr]    Compiling typenum v1.17.0
[INFO] [stderr]     Checking nix v0.26.4
[INFO] [stderr]     Checking unicode-normalization v0.1.22
[INFO] [stderr]     Checking unicode-bidi v0.3.14
[INFO] [stderr]    Compiling x11rb v0.12.0
[INFO] [stderr]     Checking rawpointer v0.2.1
[INFO] [stderr]    Compiling crossbeam-queue v0.3.8
[INFO] [stderr]    Compiling blake3 v1.5.0
[INFO] [stderr]     Checking idna v0.5.0
[INFO] [stderr]     Checking form_urlencoded v1.2.1
[INFO] [stderr]     Checking gethostname v0.3.0
[INFO] [stderr]     Checking robust v1.1.0
[INFO] [stderr]     Checking nohash-hasher v0.2.0
[INFO] [stderr]     Checking x11rb-protocol v0.12.0
[INFO] [stderr]     Checking crossbeam-deque v0.8.3
[INFO] [stderr]     Checking url v2.5.0
[INFO] [stderr]    Compiling num-iter v0.1.43
[INFO] [stderr]     Checking either v1.9.0
[INFO] [stderr]     Checking home v0.5.5
[INFO] [stderr]     Checking crossbeam v0.8.2
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking ppv-lite86 v0.2.17
[INFO] [stderr]     Checking interpolation v0.2.0
[INFO] [stderr]     Checking pretty-type-name v1.0.1
[INFO] [stderr]     Checking num v0.4.1
[INFO] [stderr]     Checking webbrowser v0.8.12
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]    Compiling winit v0.28.7
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking accesskit_winit v0.15.0
[INFO] [stderr]    Compiling serde_derive v1.0.193
[INFO] [stderr]    Compiling bytemuck_derive v1.5.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.50
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]    Compiling bevy_utils_proc_macros v0.12.1
[INFO] [stderr]    Compiling bevy_reflect_derive v0.12.1
[INFO] [stderr]    Compiling bevy_ecs_macros v0.12.1
[INFO] [stderr]    Compiling bevy_derive v0.12.1
[INFO] [stderr]    Compiling bevy_asset_macros v0.12.1
[INFO] [stderr]    Compiling thiserror-core-impl v1.0.50
[INFO] [stderr]    Compiling encase_derive v0.6.1
[INFO] [stderr]    Compiling bevy_render_macros v0.12.1
[INFO] [stderr]    Compiling bevy_encase_derive v0.12.1
[INFO] [stderr]    Compiling gltf-derive v1.3.0
[INFO] [stderr]    Compiling bevy-inspector-egui-derive v0.21.0
[INFO] [stderr]    Compiling nalgebra-macros v0.2.1
[INFO] [stderr]    Compiling num-derive v0.3.3
[INFO] [stderr]     Checking bytemuck v1.14.0
[INFO] [stderr]     Checking image v0.24.7
[INFO] [stderr]     Checking symphonia-core v0.5.3
[INFO] [stderr]     Checking ruzstd v0.4.0
[INFO] [stderr]     Checking safe_arch v0.7.1
[INFO] [stderr]     Checking wide v0.7.13
[INFO] [stderr]     Checking ecolor v0.23.0
[INFO] [stderr]     Checking emath v0.23.0
[INFO] [stderr]     Checking symphonia-metadata v0.5.3
[INFO] [stderr]     Checking symphonia-bundle-mp3 v0.5.3
[INFO] [stderr]     Checking symphonia v0.5.3
[INFO] [stderr]     Checking simba v0.8.1
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking blocking v1.5.1
[INFO] [stderr]     Checking smallvec v1.11.2
[INFO] [stderr]     Checking glam v0.24.2
[INFO] [stderr]     Checking bitflags v2.4.1
[INFO] [stderr]     Checking erased-serde v0.3.31
[INFO] [stderr]     Checking gpu-descriptor-types v0.1.2
[INFO] [stderr]     Checking naga v0.13.0
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking wgpu-types v0.17.0
[INFO] [stderr]     Checking ron v0.8.1
[INFO] [stderr]     Checking nix v0.27.1
[INFO] [stderr]     Checking tracing-subscriber v0.3.18
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking epaint v0.23.0
[INFO] [stderr]     Checking arboard v3.3.0
[INFO] [stderr]     Checking gilrs-core v0.5.9
[INFO] [stderr]     Checking gpu-descriptor v0.2.4
[INFO] [stderr]     Checking spade v2.4.1
[INFO] [stderr]     Checking rodio v0.17.3
[INFO] [stderr]     Checking gltf-json v1.3.0
[INFO] [stderr]     Checking petgraph v0.6.4
[INFO] [stderr]     Checking egui v0.23.0
[INFO] [stderr]     Checking bevy_utils v0.12.1
[INFO] [stderr]     Checking bevy_math v0.12.1
[INFO] [stderr]     Checking hexasphere v9.1.0
[INFO] [stderr]     Checking encase v0.6.1
[INFO] [stderr]     Checking bevy_mikktspace v0.12.1
[INFO] [stderr]     Checking nalgebra v0.32.3
[INFO] [stderr]     Checking gltf v1.3.0
[INFO] [stderr]     Checking bevy_reflect v0.12.1
[INFO] [stderr]     Checking wgpu-hal v0.17.2
[INFO] [stderr]     Checking naga_oil v0.10.1
[INFO] [stderr]     Checking bevy_ecs v0.12.1
[INFO] [stderr]     Checking wgpu-core v0.17.1
[INFO] [stderr]     Checking parry2d v0.13.5
[INFO] [stderr]     Checking bevy_app v0.12.1
[INFO] [stderr]     Checking bevy_log v0.12.1
[INFO] [stderr]     Checking bevy_core v0.12.1
[INFO] [stderr]     Checking bevy_input v0.12.1
[INFO] [stderr]     Checking bevy_a11y v0.12.1
[INFO] [stderr]     Checking bevy_time v0.12.1
[INFO] [stderr]     Checking bevy_asset v0.12.1
[INFO] [stderr]     Checking rapier2d v0.17.2
[INFO] [stderr]     Checking bevy_hierarchy v0.12.1
[INFO] [stderr]     Checking bevy_diagnostic v0.12.1
[INFO] [stderr]     Checking wgpu v0.17.2
[INFO] [stderr]     Checking bevy_transform v0.12.1
[INFO] [stderr]     Checking bevy_window v0.12.1
[INFO] [stderr]     Checking bevy_gilrs v0.12.1
[INFO] [stderr]     Checking bevy_winit v0.12.1
[INFO] [stderr]     Checking bevy_render v0.12.1
[INFO] [stderr]     Checking bevy_audio v0.12.1
[INFO] [stderr]     Checking bevy_core_pipeline v0.12.1
[INFO] [stderr]     Checking bevy_animation v0.12.1
[INFO] [stderr]     Checking bevy_scene v0.12.1
[INFO] [stderr]     Checking bevy_sprite v0.12.1
[INFO] [stderr]     Checking bevy_pbr v0.12.1
[INFO] [stderr]     Checking bevy_text v0.12.1
[INFO] [stderr]     Checking bevy_ui v0.12.1
[INFO] [stderr]     Checking bevy_gltf v0.12.1
[INFO] [stderr]     Checking bevy_gizmos v0.12.1
[INFO] [stderr]     Checking bevy_internal v0.12.1
[INFO] [stderr]     Checking bevy v0.12.1
[INFO] [stderr]     Checking bevy_egui v0.23.0
[INFO] [stderr]     Checking bevy_rapier2d v0.23.0
[INFO] [stderr]     Checking bevy_tweening v0.9.0
[INFO] [stderr]     Checking bevy-inspector-egui v0.21.0
[INFO] [stderr]     Checking towerthrower v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `bevy_rapier2d::plugin::systems::apply_scale`
[INFO] [stdout]  --> src/base.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use bevy_rapier2d::plugin::systems::apply_scale;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy_rapier2d::plugin::systems::apply_scale`
[INFO] [stdout]  --> src/base.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use bevy_rapier2d::plugin::systems::apply_scale;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::cursor_system::CursorCoords`
[INFO] [stdout]   --> src/base.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::cursor_system::CursorCoords;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::cursor_system::CursorCoords`
[INFO] [stdout]   --> src/base.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::cursor_system::CursorCoords;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/block.rs:378:9
[INFO] [stdout]     |
[INFO] [stdout] 378 |         (Entity),
[INFO] [stdout]     |         ^      ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 378 -         (Entity),
[INFO] [stdout] 378 +         Entity,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/block.rs:378:9
[INFO] [stdout]     |
[INFO] [stdout] 378 |         (Entity),
[INFO] [stdout]     |         ^      ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 378 -         (Entity),
[INFO] [stdout] 378 +         Entity,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/block.rs:454:18
[INFO] [stdout]     |
[INFO] [stdout] 454 |     query: Query<(&Children)>,
[INFO] [stdout]     |                  ^         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 454 -     query: Query<(&Children)>,
[INFO] [stdout] 454 +     query: Query<&Children>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Block`, `Falling`
[INFO] [stdout]  --> src/camera_movement.rs:1:20
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::block::{Block, Falling};
[INFO] [stdout]   |                    ^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ContactForceEvent`
[INFO] [stdout]  --> src/collision_sounds.rs:3:46
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy_rapier2d::prelude::{CollisionEvent, ContactForceEvent, Velocity};
[INFO] [stdout]   |                                              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/block.rs:454:18
[INFO] [stdout]     |
[INFO] [stdout] 454 |     query: Query<(&Children)>,
[INFO] [stdout]     |                  ^         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 454 -     query: Query<(&Children)>,
[INFO] [stdout] 454 +     query: Query<&Children>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Block`, `Falling`
[INFO] [stdout]  --> src/camera_movement.rs:1:20
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::block::{Block, Falling};
[INFO] [stdout]   |                    ^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/collision_sounds.rs:62:21
[INFO] [stdout]    |
[INFO] [stdout] 62 |                     (AudioBundle {
[INFO] [stdout]    |                     ^
[INFO] [stdout] ...
[INFO] [stdout] 68 |                     }),
[INFO] [stdout]    |                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 62 ~                     AudioBundle {
[INFO] [stdout] 63 |                         source: sound,
[INFO] [stdout]  ...
[INFO] [stdout] 67 |                         },
[INFO] [stdout] 68 ~                     },
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ContactForceEvent`
[INFO] [stdout]  --> src/collision_sounds.rs:3:46
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy_rapier2d::prelude::{CollisionEvent, ContactForceEvent, Velocity};
[INFO] [stdout]   |                                              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::floor::Floor`
[INFO] [stdout]  --> src/debris.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::floor::Floor;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/collision_sounds.rs:62:21
[INFO] [stdout]    |
[INFO] [stdout] 62 |                     (AudioBundle {
[INFO] [stdout]    |                     ^
[INFO] [stdout] ...
[INFO] [stdout] 68 |                     }),
[INFO] [stdout]    |                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 62 ~                     AudioBundle {
[INFO] [stdout] 63 |                         source: sound,
[INFO] [stdout]  ...
[INFO] [stdout] 67 |                         },
[INFO] [stdout] 68 ~                     },
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/debris.rs:14:33
[INFO] [stdout]    |
[INFO] [stdout] 14 |         app.add_systems(Update, (block_to_debris_system));
[INFO] [stdout]    |                                 ^                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 14 -         app.add_systems(Update, (block_to_debris_system));
[INFO] [stdout] 14 +         app.add_systems(Update, block_to_debris_system);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::mem`
[INFO] [stdout]  --> src/effect/glue.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::mem;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::floor::Floor`
[INFO] [stdout]  --> src/debris.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::floor::Floor;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/effect/glue.rs:56:33
[INFO] [stdout]    |
[INFO] [stdout] 56 | ...                   (SpriteBundle {
[INFO] [stdout]    |                       ^
[INFO] [stdout] ...
[INFO] [stdout] 68 | ...                   }),
[INFO] [stdout]    |                        ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 56 ~                                 SpriteBundle {
[INFO] [stdout] 57 |                                     transform: Transform::from_xyz(0.0, 0.0, 1.0),
[INFO] [stdout]  ...
[INFO] [stdout] 67 |                                     ..Default::default()
[INFO] [stdout] 68 ~                                 },
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Falling`
[INFO] [stdout]  --> src/effect/magnetic.rs:4:35
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::block::{Aiming, Block, Falling};
[INFO] [stdout]   |                                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/debris.rs:14:33
[INFO] [stdout]    |
[INFO] [stdout] 14 |         app.add_systems(Update, (block_to_debris_system));
[INFO] [stdout]    |                                 ^                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 14 -         app.add_systems(Update, (block_to_debris_system));
[INFO] [stdout] 14 +         app.add_systems(Update, block_to_debris_system);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::mem`
[INFO] [stdout]  --> src/effect/glue.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::mem;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around pattern
[INFO] [stdout]   --> src/effect/magnetic.rs:46:9
[INFO] [stdout]    |
[INFO] [stdout] 46 |     for ((mag_entity, magnet_transform, mut magnet_self_impulse, effect)) in
[INFO] [stdout]    |         ^                                                               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 46 -     for ((mag_entity, magnet_transform, mut magnet_self_impulse, effect)) in
[INFO] [stdout] 46 +     for (mag_entity, magnet_transform, mut magnet_self_impulse, effect) in
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::base::Base`
[INFO] [stdout]  --> src/effect/platform.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::base::Base;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/effect/glue.rs:56:33
[INFO] [stdout]    |
[INFO] [stdout] 56 | ...                   (SpriteBundle {
[INFO] [stdout]    |                       ^
[INFO] [stdout] ...
[INFO] [stdout] 68 | ...                   }),
[INFO] [stdout]    |                        ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 56 ~                                 SpriteBundle {
[INFO] [stdout] 57 |                                     transform: Transform::from_xyz(0.0, 0.0, 1.0),
[INFO] [stdout]  ...
[INFO] [stdout] 67 |                                     ..Default::default()
[INFO] [stdout] 68 ~                                 },
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Falling`
[INFO] [stdout]  --> src/effect/platform.rs:2:33
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::block::{CaughtBlock, Falling};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Falling`
[INFO] [stdout]  --> src/effect/magnetic.rs:4:35
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::block::{Aiming, Block, Falling};
[INFO] [stdout]   |                                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::effect::magnetic::MagneticEffect`
[INFO] [stdout]  --> src/effect/platform.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::effect::magnetic::MagneticEffect;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around pattern
[INFO] [stdout]   --> src/effect/magnetic.rs:46:9
[INFO] [stdout]    |
[INFO] [stdout] 46 |     for ((mag_entity, magnet_transform, mut magnet_self_impulse, effect)) in
[INFO] [stdout]    |         ^                                                               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 46 -     for ((mag_entity, magnet_transform, mut magnet_self_impulse, effect)) in
[INFO] [stdout] 46 +     for (mag_entity, magnet_transform, mut magnet_self_impulse, effect) in
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::base::Base`
[INFO] [stdout]  --> src/effect/platform.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::base::Base;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/environment/car.rs:232:33
[INFO] [stdout]     |
[INFO] [stdout] 232 |     mut car_sprite_query: Query<(&CarTexture)>,
[INFO] [stdout]     |                                 ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 232 -     mut car_sprite_query: Query<(&CarTexture)>,
[INFO] [stdout] 232 +     mut car_sprite_query: Query<&CarTexture>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Falling`
[INFO] [stdout]  --> src/effect/platform.rs:2:33
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::block::{CaughtBlock, Falling};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around pattern
[INFO] [stdout]    --> src/environment/car.rs:262:43
[INFO] [stdout]     |
[INFO] [stdout] 262 | ...                   if let Ok((texture)) = car_sprite_query.get_mut(*child) {
[INFO] [stdout]     |                                 ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 262 -                                 if let Ok((texture)) = car_sprite_query.get_mut(*child) {
[INFO] [stdout] 262 +                                 if let Ok(texture) = car_sprite_query.get_mut(*child) {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::effect::magnetic::MagneticEffect`
[INFO] [stdout]  --> src/effect/platform.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::effect::magnetic::MagneticEffect;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/environment/car.rs:291:21
[INFO] [stdout]     |
[INFO] [stdout] 291 |                     (CollisionGroups {
[INFO] [stdout]     |                     ^
[INFO] [stdout] ...
[INFO] [stdout] 294 |                     }),
[INFO] [stdout]     |                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 291 ~                     CollisionGroups {
[INFO] [stdout] 292 |                         filters: FLOOR_COLLISION_GROUP | BLOCK_COLLISION_GROUP,
[INFO] [stdout] 293 |                         memberships: Group::default(),
[INFO] [stdout] 294 ~                     },
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/environment/car.rs:232:33
[INFO] [stdout]     |
[INFO] [stdout] 232 |     mut car_sprite_query: Query<(&CarTexture)>,
[INFO] [stdout]     |                                 ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 232 -     mut car_sprite_query: Query<(&CarTexture)>,
[INFO] [stdout] 232 +     mut car_sprite_query: Query<&CarTexture>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/environment/debris_cleaner.rs:115:33
[INFO] [stdout]     |
[INFO] [stdout] 115 | ...                   (AudioBundle {
[INFO] [stdout]     |                       ^
[INFO] [stdout] ...
[INFO] [stdout] 121 | ...                   }),
[INFO] [stdout]     |                        ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 115 ~                                 AudioBundle {
[INFO] [stdout] 116 |                                     source: assets.load("sounds/whoosh.wav"),
[INFO] [stdout]   ...
[INFO] [stdout] 120 |                                     },
[INFO] [stdout] 121 ~                                 },
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy_rapier2d::prelude::*`
[INFO] [stdout]  --> src/environment/fees.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use bevy_rapier2d::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around pattern
[INFO] [stdout]    --> src/environment/car.rs:262:43
[INFO] [stdout]     |
[INFO] [stdout] 262 | ...                   if let Ok((texture)) = car_sprite_query.get_mut(*child) {
[INFO] [stdout]     |                                 ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 262 -                                 if let Ok((texture)) = car_sprite_query.get_mut(*child) {
[INFO] [stdout] 262 +                                 if let Ok(texture) = car_sprite_query.get_mut(*child) {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/environment/car.rs:291:21
[INFO] [stdout]     |
[INFO] [stdout] 291 |                     (CollisionGroups {
[INFO] [stdout]     |                     ^
[INFO] [stdout] ...
[INFO] [stdout] 294 |                     }),
[INFO] [stdout]     |                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 291 ~                     CollisionGroups {
[INFO] [stdout] 292 |                         filters: FLOOR_COLLISION_GROUP | BLOCK_COLLISION_GROUP,
[INFO] [stdout] 293 |                         memberships: Group::default(),
[INFO] [stdout] 294 ~                     },
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/environment/rain.rs:114:23
[INFO] [stdout]     |
[INFO] [stdout] 114 |     rain_query: Query<(&Transform), With<Rain>>,
[INFO] [stdout]     |                       ^          ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 114 -     rain_query: Query<(&Transform), With<Rain>>,
[INFO] [stdout] 114 +     rain_query: Query<&Transform, With<Rain>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/environment/debris_cleaner.rs:115:33
[INFO] [stdout]     |
[INFO] [stdout] 115 | ...                   (AudioBundle {
[INFO] [stdout]     |                       ^
[INFO] [stdout] ...
[INFO] [stdout] 121 | ...                   }),
[INFO] [stdout]     |                        ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 115 ~                                 AudioBundle {
[INFO] [stdout] 116 |                                     source: assets.load("sounds/whoosh.wav"),
[INFO] [stdout]   ...
[INFO] [stdout] 120 |                                     },
[INFO] [stdout] 121 ~                                 },
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/environment/rain.rs:115:25
[INFO] [stdout]     |
[INFO] [stdout] 115 |     splash_query: Query<(&Transform), With<Splash>>,
[INFO] [stdout]     |                         ^          ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 115 -     splash_query: Query<(&Transform), With<Splash>>,
[INFO] [stdout] 115 +     splash_query: Query<&Transform, With<Splash>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TransformRotateXLens`, `TransformScaleLens`
[INFO] [stdout]  --> src/launch_platform.rs:4:27
[INFO] [stdout]   |
[INFO] [stdout] 4 | use bevy_tweening::lens::{TransformRotateXLens, TransformRotationLens, TransformScaleLens};
[INFO] [stdout]   |                           ^^^^^^^^^^^^^^^^^^^^                         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy_rapier2d::prelude::*`
[INFO] [stdout]  --> src/environment/fees.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use bevy_rapier2d::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `RepeatCount`, `RepeatStrategy`
[INFO] [stdout]  --> src/launch_platform.rs:5:45
[INFO] [stdout]   |
[INFO] [stdout] 5 | use bevy_tweening::{Animator, EaseFunction, RepeatCount, RepeatStrategy, Tween};
[INFO] [stdout]   |                                             ^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/environment/rain.rs:114:23
[INFO] [stdout]     |
[INFO] [stdout] 114 |     rain_query: Query<(&Transform), With<Rain>>,
[INFO] [stdout]     |                       ^          ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 114 -     rain_query: Query<(&Transform), With<Rain>>,
[INFO] [stdout] 114 +     rain_query: Query<&Transform, With<Rain>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/launch_platform.rs:17:55
[INFO] [stdout]    |
[INFO] [stdout] 17 |         app.add_systems(OnEnter(LevelState::Playing), (spawn_launch_platform_system))
[INFO] [stdout]    |                                                       ^                            ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 17 -         app.add_systems(OnEnter(LevelState::Playing), (spawn_launch_platform_system))
[INFO] [stdout] 17 +         app.add_systems(OnEnter(LevelState::Playing), spawn_launch_platform_system)
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/environment/rain.rs:115:25
[INFO] [stdout]     |
[INFO] [stdout] 115 |     splash_query: Query<(&Transform), With<Splash>>,
[INFO] [stdout]     |                         ^          ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 115 -     splash_query: Query<(&Transform), With<Splash>>,
[INFO] [stdout] 115 +     splash_query: Query<&Transform, With<Splash>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/launch_platform.rs:151:9
[INFO] [stdout]     |
[INFO] [stdout] 151 |           /// WASD for launch platform
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 152 | /         if key_code.pressed(KeyCode::A) {
[INFO] [stdout] 153 | |             velocity.linvel.x -= increment;
[INFO] [stdout] 154 | |             if velocity.linvel.x < -max_velocity {
[INFO] [stdout] 155 | |                 velocity.linvel.x = -max_velocity;
[INFO] [stdout] ...   |
[INFO] [stdout] 171 | |             }
[INFO] [stdout] 172 | |         }
[INFO] [stdout]     | |_________- rustdoc does not generate documentation for expressions
[INFO] [stdout]     |
[INFO] [stdout]     = help: use `//` for a plain comment
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TransformRotateXLens`, `TransformScaleLens`
[INFO] [stdout]  --> src/launch_platform.rs:4:27
[INFO] [stdout]   |
[INFO] [stdout] 4 | use bevy_tweening::lens::{TransformRotateXLens, TransformRotationLens, TransformScaleLens};
[INFO] [stdout]   |                           ^^^^^^^^^^^^^^^^^^^^                         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::level_intro_dialog::DialogResource`
[INFO] [stdout]  --> src/level.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::level_intro_dialog::DialogResource;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EguiContext`
[INFO] [stdout]  --> src/level_intro_dialog.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use bevy_egui::{egui, EguiContext, EguiContexts};
[INFO] [stdout]   |                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `RepeatCount`, `RepeatStrategy`
[INFO] [stdout]  --> src/launch_platform.rs:5:45
[INFO] [stdout]   |
[INFO] [stdout] 5 | use bevy_tweening::{Animator, EaseFunction, RepeatCount, RepeatStrategy, Tween};
[INFO] [stdout]   |                                             ^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/level_ui.rs:17:34
[INFO] [stdout]    |
[INFO] [stdout] 17 |             .add_systems(Update, (target_ui));
[INFO] [stdout]    |                                  ^         ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 17 -             .add_systems(Update, (target_ui));
[INFO] [stdout] 17 +             .add_systems(Update, target_ui);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/launch_platform.rs:17:55
[INFO] [stdout]    |
[INFO] [stdout] 17 |         app.add_systems(OnEnter(LevelState::Playing), (spawn_launch_platform_system))
[INFO] [stdout]    |                                                       ^                            ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 17 -         app.add_systems(OnEnter(LevelState::Playing), (spawn_launch_platform_system))
[INFO] [stdout] 17 +         app.add_systems(OnEnter(LevelState::Playing), spawn_launch_platform_system)
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/state.rs:36:26
[INFO] [stdout]    |
[INFO] [stdout] 36 |     mut all_query: Query<(Entity), With<LevelLifecycle>>,
[INFO] [stdout]    |                          ^      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 36 -     mut all_query: Query<(Entity), With<LevelLifecycle>>,
[INFO] [stdout] 36 +     mut all_query: Query<Entity, With<LevelLifecycle>>,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/throw.rs:108:22
[INFO] [stdout]     |
[INFO] [stdout] 108 |     mut query: Query<(Entity), With<TargetIndicator>>,
[INFO] [stdout]     |                      ^      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 108 -     mut query: Query<(Entity), With<TargetIndicator>>,
[INFO] [stdout] 108 +     mut query: Query<Entity, With<TargetIndicator>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/launch_platform.rs:151:9
[INFO] [stdout]     |
[INFO] [stdout] 151 |           /// WASD for launch platform
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 152 | /         if key_code.pressed(KeyCode::A) {
[INFO] [stdout] 153 | |             velocity.linvel.x -= increment;
[INFO] [stdout] 154 | |             if velocity.linvel.x < -max_velocity {
[INFO] [stdout] 155 | |                 velocity.linvel.x = -max_velocity;
[INFO] [stdout] ...   |
[INFO] [stdout] 171 | |             }
[INFO] [stdout] 172 | |         }
[INFO] [stdout]     | |_________- rustdoc does not generate documentation for expressions
[INFO] [stdout]     |
[INFO] [stdout]     = help: use `//` for a plain comment
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::level_intro_dialog::DialogResource`
[INFO] [stdout]  --> src/level.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::level_intro_dialog::DialogResource;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/throw.rs:109:35
[INFO] [stdout]     |
[INFO] [stdout] 109 |     mut aiming_block_query: Query<(Entity), With<Aiming>>,
[INFO] [stdout]     |                                   ^      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 109 -     mut aiming_block_query: Query<(Entity), With<Aiming>>,
[INFO] [stdout] 109 +     mut aiming_block_query: Query<Entity, With<Aiming>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EguiContext`
[INFO] [stdout]  --> src/level_intro_dialog.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use bevy_egui::{egui, EguiContext, EguiContexts};
[INFO] [stdout]   |                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/throw.rs:124:9
[INFO] [stdout]     |
[INFO] [stdout] 124 |         (With<Aiming>),
[INFO] [stdout]     |         ^            ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 124 -         (With<Aiming>),
[INFO] [stdout] 124 +         With<Aiming>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/level_ui.rs:17:34
[INFO] [stdout]    |
[INFO] [stdout] 17 |             .add_systems(Update, (target_ui));
[INFO] [stdout]    |                                  ^         ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 17 -             .add_systems(Update, (target_ui));
[INFO] [stdout] 17 +             .add_systems(Update, target_ui);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/throw.rs:308:22
[INFO] [stdout]     |
[INFO] [stdout] 308 |     mut query: Query<(Entity), With<Aiming>>,
[INFO] [stdout]     |                      ^      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 308 -     mut query: Query<(Entity), With<Aiming>>,
[INFO] [stdout] 308 +     mut query: Query<Entity, With<Aiming>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/throw.rs:527:22
[INFO] [stdout]     |
[INFO] [stdout] 527 |     mut query: Query<(Entity), With<Aiming>>,
[INFO] [stdout]     |                      ^      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 527 -     mut query: Query<(Entity), With<Aiming>>,
[INFO] [stdout] 527 +     mut query: Query<Entity, With<Aiming>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/state.rs:36:26
[INFO] [stdout]    |
[INFO] [stdout] 36 |     mut all_query: Query<(Entity), With<LevelLifecycle>>,
[INFO] [stdout]    |                          ^      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 36 -     mut all_query: Query<(Entity), With<LevelLifecycle>>,
[INFO] [stdout] 36 +     mut all_query: Query<Entity, With<LevelLifecycle>>,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/ui.rs:10:33
[INFO] [stdout]    |
[INFO] [stdout] 10 |         app.add_systems(Update, (update_ui_scale_factor));
[INFO] [stdout]    |                                 ^                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 10 -         app.add_systems(Update, (update_ui_scale_factor));
[INFO] [stdout] 10 +         app.add_systems(Update, update_ui_scale_factor);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/throw.rs:108:22
[INFO] [stdout]     |
[INFO] [stdout] 108 |     mut query: Query<(Entity), With<TargetIndicator>>,
[INFO] [stdout]     |                      ^      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 108 -     mut query: Query<(Entity), With<TargetIndicator>>,
[INFO] [stdout] 108 +     mut query: Query<Entity, With<TargetIndicator>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/throw.rs:109:35
[INFO] [stdout]     |
[INFO] [stdout] 109 |     mut aiming_block_query: Query<(Entity), With<Aiming>>,
[INFO] [stdout]     |                                   ^      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 109 -     mut aiming_block_query: Query<(Entity), With<Aiming>>,
[INFO] [stdout] 109 +     mut aiming_block_query: Query<Entity, With<Aiming>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/throw.rs:124:9
[INFO] [stdout]     |
[INFO] [stdout] 124 |         (With<Aiming>),
[INFO] [stdout]     |         ^            ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 124 -         (With<Aiming>),
[INFO] [stdout] 124 +         With<Aiming>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/throw.rs:308:22
[INFO] [stdout]     |
[INFO] [stdout] 308 |     mut query: Query<(Entity), With<Aiming>>,
[INFO] [stdout]     |                      ^      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 308 -     mut query: Query<(Entity), With<Aiming>>,
[INFO] [stdout] 308 +     mut query: Query<Entity, With<Aiming>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/throw.rs:527:22
[INFO] [stdout]     |
[INFO] [stdout] 527 |     mut query: Query<(Entity), With<Aiming>>,
[INFO] [stdout]     |                      ^      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 527 -     mut query: Query<(Entity), With<Aiming>>,
[INFO] [stdout] 527 +     mut query: Query<Entity, With<Aiming>>,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/ui.rs:10:33
[INFO] [stdout]    |
[INFO] [stdout] 10 |         app.add_systems(Update, (update_ui_scale_factor));
[INFO] [stdout]    |                                 ^                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 10 -         app.add_systems(Update, (update_ui_scale_factor));
[INFO] [stdout] 10 +         app.add_systems(Update, update_ui_scale_factor);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `bevy::prelude::EventReader::<'w, 's, E>::iter`: use `.read()` instead.
[INFO] [stdout]    --> src/block.rs:383:31
[INFO] [stdout]     |
[INFO] [stdout] 383 |     for event in event_reader.iter() {
[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::EventReader::<'w, 's, E>::iter`: use `.read()` instead.
[INFO] [stdout]    --> src/block.rs:383:31
[INFO] [stdout]     |
[INFO] [stdout] 383 |     for event in event_reader.iter() {
[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::EventReader::<'w, 's, E>::iter`: use `.read()` instead.
[INFO] [stdout]    --> src/block.rs:457:25
[INFO] [stdout]     |
[INFO] [stdout] 457 |     for event in events.iter() {
[INFO] [stdout]     |                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `bevy::prelude::EventReader::<'w, 's, E>::iter`: use `.read()` instead.
[INFO] [stdout]    --> src/block.rs:457:25
[INFO] [stdout]     |
[INFO] [stdout] 457 |     for event in events.iter() {
[INFO] [stdout]     |                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `bevy::prelude::EventReader::<'w, 's, E>::iter`: use `.read()` instead.
[INFO] [stdout]    --> src/environment/debris_cleaner.rs:102:50
[INFO] [stdout]     |
[INFO] [stdout] 102 |     for event in debris_cleaner_collision_events.iter() {
[INFO] [stdout]     |                                                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `bevy::prelude::EventReader::<'w, 's, E>::iter`: use `.read()` instead.
[INFO] [stdout]    --> src/environment/debris_cleaner.rs:102:50
[INFO] [stdout]     |
[INFO] [stdout] 102 |     for event in debris_cleaner_collision_events.iter() {
[INFO] [stdout]     |                                                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/base.rs:69:43
[INFO] [stdout]    |
[INFO] [stdout] 69 | pub fn setup_base(mut commands: Commands, mut assets: ResMut<AssetServer>, mut level: Res<Level>) {
[INFO] [stdout]    |                                           ----^^^^^^
[INFO] [stdout]    |                                           |
[INFO] [stdout]    |                                           help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/base.rs:69:76
[INFO] [stdout]    |
[INFO] [stdout] 69 | pub fn setup_base(mut commands: Commands, mut assets: ResMut<AssetServer>, mut level: Res<Level>) {
[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/base.rs:69:43
[INFO] [stdout]    |
[INFO] [stdout] 69 | pub fn setup_base(mut commands: Commands, mut assets: ResMut<AssetServer>, mut level: Res<Level>) {
[INFO] [stdout]    |                                           ----^^^^^^
[INFO] [stdout]    |                                           |
[INFO] [stdout]    |                                           help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/base.rs:69:76
[INFO] [stdout]    |
[INFO] [stdout] 69 | pub fn setup_base(mut commands: Commands, mut assets: ResMut<AssetServer>, mut level: Res<Level>) {
[INFO] [stdout]    |                                                                            ----^^^^^
[INFO] [stdout]    |                                                                            |
[INFO] [stdout]    |                                                                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `flags`
[INFO] [stdout]    --> src/block.rs:385:59
[INFO] [stdout]     |
[INFO] [stdout] 385 |             CollisionEvent::Started(collider1, collider2, flags) => {
[INFO] [stdout]     |                                                           ^^^^^ help: if this is intentional, prefix it with an underscore: `_flags`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/block.rs:374:9
[INFO] [stdout]     |
[INFO] [stdout] 374 |     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: `block`
[INFO] [stdout]    --> src/block.rs:394:48
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut transform, _)) =
[INFO] [stdout]     |                                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `velocity`
[INFO] [stdout]    --> src/block.rs:394:59
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut transform, _)) =
[INFO] [stdout]     |                                                           ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_velocity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transform`
[INFO] [stdout]    --> src/block.rs:394:73
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut transform, _)) =
[INFO] [stdout]     |                                                                         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transform`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/block.rs:389:29
[INFO] [stdout]     |
[INFO] [stdout] 389 |                         let mut valid_catcher = catcher_query.get_mut(*catcher);
[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/block.rs:394:44
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut 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/block.rs:394:55
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut 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/block.rs:394:69
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut 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/block.rs:374:5
[INFO] [stdout]     |
[INFO] [stdout] 374 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]    --> src/block.rs:431:14
[INFO] [stdout]     |
[INFO] [stdout] 431 |         for (entity, mut transform, ..) in 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: `key_code`
[INFO] [stdout]    --> src/block.rs:424:5
[INFO] [stdout]     |
[INFO] [stdout] 424 |     key_code: Res<Input<KeyCode>>,
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_key_code`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/block.rs:441:5
[INFO] [stdout]     |
[INFO] [stdout] 441 |     mut floor_query: Query<(&Transform, With<Floor>)>,
[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/block.rs:444:18
[INFO] [stdout]     |
[INFO] [stdout] 444 |     for (entity, mut transform, ..) in query.iter_mut() {
[INFO] [stdout]     |                  ----^^^^^^^^^
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `global_transform`
[INFO] [stdout]   --> src/camera_movement.rs:43:25
[INFO] [stdout]    |
[INFO] [stdout] 43 |     for (mut transform, global_transform, camera) in camera_query.iter_mut() {
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_global_transform`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `flags`
[INFO] [stdout]    --> src/block.rs:385:59
[INFO] [stdout]     |
[INFO] [stdout] 385 |             CollisionEvent::Started(collider1, collider2, flags) => {
[INFO] [stdout]     |                                                           ^^^^^ help: if this is intentional, prefix it with an underscore: `_flags`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/block.rs:374:9
[INFO] [stdout]     |
[INFO] [stdout] 374 |     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: `block`
[INFO] [stdout]    --> src/block.rs:394:48
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut transform, _)) =
[INFO] [stdout]     |                                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `velocity`
[INFO] [stdout]    --> src/block.rs:394:59
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut transform, _)) =
[INFO] [stdout]     |                                                           ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_velocity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transform`
[INFO] [stdout]    --> src/block.rs:394:73
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut transform, _)) =
[INFO] [stdout]     |                                                                         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transform`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/block.rs:389:29
[INFO] [stdout]     |
[INFO] [stdout] 389 |                         let mut valid_catcher = catcher_query.get_mut(*catcher);
[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/block.rs:394:44
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut 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/block.rs:394:55
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut 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/block.rs:394:69
[INFO] [stdout]     |
[INFO] [stdout] 394 |                         if let Ok((entity, mut block, mut velocity, mut 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/block.rs:374:5
[INFO] [stdout]     |
[INFO] [stdout] 374 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]    --> src/block.rs:431:14
[INFO] [stdout]     |
[INFO] [stdout] 431 |         for (entity, mut transform, ..) in 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: `key_code`
[INFO] [stdout]    --> src/block.rs:424:5
[INFO] [stdout]     |
[INFO] [stdout] 424 |     key_code: Res<Input<KeyCode>>,
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_key_code`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]    --> src/debris.rs:110:37
[INFO] [stdout]     |
[INFO] [stdout] 110 |             CollisionEvent::Stopped(a, b, _) => {}
[INFO] [stdout]     |                                     ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]    --> src/debris.rs:110:40
[INFO] [stdout]     |
[INFO] [stdout] 110 |             CollisionEvent::Stopped(a, b, _) => {}
[INFO] [stdout]     |                                        ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/block.rs:441:5
[INFO] [stdout]     |
[INFO] [stdout] 441 |     mut floor_query: Query<(&Transform, With<Floor>)>,
[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/block.rs:444:18
[INFO] [stdout]     |
[INFO] [stdout] 444 |     for (entity, mut transform, ..) in 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/debris.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     mut floor_query: Query<&mut DestroyBlockOnContact>,
[INFO] [stdout]    |     ----^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `global_transform`
[INFO] [stdout]   --> src/camera_movement.rs:43:25
[INFO] [stdout]    |
[INFO] [stdout] 43 |     for (mut transform, global_transform, camera) in camera_query.iter_mut() {
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_global_transform`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/debris.rs:118:5
[INFO] [stdout]     |
[INFO] [stdout] 118 |     mut timer: ResMut<Time>,
[INFO] [stdout]     |     ----^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]   --> src/effect/glue.rs:48:20
[INFO] [stdout]    |
[INFO] [stdout] 48 |         if let Ok((entity, mut glue_effect)) = query.get_mut(*falling) {
[INFO] [stdout]    |                    ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `base_rotation`
[INFO] [stdout]   --> src/effect/glue.rs:98:29
[INFO] [stdout]    |
[INFO] [stdout] 98 |                         let base_rotation = base_transform
[INFO] [stdout]    |                             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_base_rotation`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `falling_rotation`
[INFO] [stdout]    --> src/effect/glue.rs:101:29
[INFO] [stdout]     |
[INFO] [stdout] 101 |                         let falling_rotation = falling_transform
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_falling_rotation`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `offset_global`
[INFO] [stdout]    --> src/effect/glue.rs:105:29
[INFO] [stdout]     |
[INFO] [stdout] 105 |                         let offset_global = falling_translation - base_translation;
[INFO] [stdout]     |                             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_offset_global`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `base_right`
[INFO] [stdout]    --> src/effect/glue.rs:117:29
[INFO] [stdout]     |
[INFO] [stdout] 117 |                         let base_right = (base_transform.rotation * Vec3::Y).xy();
[INFO] [stdout]     |                             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_base_right`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `falling_right`
[INFO] [stdout]    --> src/effect/glue.rs:120:29
[INFO] [stdout]     |
[INFO] [stdout] 120 |                         let falling_right = (falling_transform.rotation * Vec3::Y).xy();
[INFO] [stdout]     |                             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_falling_right`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/effect/glue.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 82 |     mut target_query: Query<(Entity, &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/effect/glue.rs:87:28
[INFO] [stdout]    |
[INFO] [stdout] 87 |         if let Ok((entity, mut glue_effect, transform)) = query.get_mut(*entity) {
[INFO] [stdout]    |                            ----^^^^^^^^^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `mag_entity`
[INFO] [stdout]   --> src/effect/magnetic.rs:46:11
[INFO] [stdout]    |
[INFO] [stdout] 46 |     for ((mag_entity, magnet_transform, mut magnet_self_impulse, effect)) in
[INFO] [stdout]    |           ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_mag_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_entity`
[INFO] [stdout]   --> src/effect/magnetic.rs:49:14
[INFO] [stdout]    |
[INFO] [stdout] 49 |         for (block_entity, block_transform, mut external_impulse) in blocks_query.iter_mut() {
[INFO] [stdout]    |              ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_a`
[INFO] [stdout]   --> src/effect/magnetic.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 |         [(entity_a, transform_a, mut impulse_a, effect_a), (entity_b, transform_b, mut impulse_b, effect_b)],
[INFO] [stdout]    |           ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_b`
[INFO] [stdout]   --> src/effect/magnetic.rs:61:61
[INFO] [stdout]    |
[INFO] [stdout] 61 |         [(entity_a, transform_a, mut impulse_a, effect_a), (entity_b, transform_b, mut impulse_b, effect_b)],
[INFO] [stdout]    |                                                             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]    --> src/debris.rs:110:37
[INFO] [stdout]     |
[INFO] [stdout] 110 |             CollisionEvent::Stopped(a, b, _) => {}
[INFO] [stdout]     |                                     ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]    --> src/debris.rs:110:40
[INFO] [stdout]     |
[INFO] [stdout] 110 |             CollisionEvent::Stopped(a, b, _) => {}
[INFO] [stdout]     |                                        ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/debris.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     mut floor_query: Query<&mut DestroyBlockOnContact>,
[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/debris.rs:118:5
[INFO] [stdout]     |
[INFO] [stdout] 118 |     mut timer: ResMut<Time>,
[INFO] [stdout]     |     ----^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `beam_entity`
[INFO] [stdout]   --> src/environment/beam.rs:60:10
[INFO] [stdout]    |
[INFO] [stdout] 60 |     for (beam_entity, beam, mut beam_transform, beam_global_transform, mut sprite) in
[INFO] [stdout]    |          ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_beam_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]   --> src/effect/glue.rs:48:20
[INFO] [stdout]    |
[INFO] [stdout] 48 |         if let Ok((entity, mut glue_effect)) = query.get_mut(*falling) {
[INFO] [stdout]    |                    ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `base_rotation`
[INFO] [stdout]   --> src/effect/glue.rs:98:29
[INFO] [stdout]    |
[INFO] [stdout] 98 |                         let base_rotation = base_transform
[INFO] [stdout]    |                             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_base_rotation`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `falling_rotation`
[INFO] [stdout]    --> src/effect/glue.rs:101:29
[INFO] [stdout]     |
[INFO] [stdout] 101 |                         let falling_rotation = falling_transform
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_falling_rotation`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `offset_global`
[INFO] [stdout]    --> src/effect/glue.rs:105:29
[INFO] [stdout]     |
[INFO] [stdout] 105 |                         let offset_global = falling_translation - base_translation;
[INFO] [stdout]     |                             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_offset_global`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `base_right`
[INFO] [stdout]    --> src/effect/glue.rs:117:29
[INFO] [stdout]     |
[INFO] [stdout] 117 |                         let base_right = (base_transform.rotation * Vec3::Y).xy();
[INFO] [stdout]     |                             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_base_right`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `falling_right`
[INFO] [stdout]    --> src/effect/glue.rs:120:29
[INFO] [stdout]     |
[INFO] [stdout] 120 |                         let falling_right = (falling_transform.rotation * Vec3::Y).xy();
[INFO] [stdout]     |                             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_falling_right`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/effect/glue.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 82 |     mut target_query: Query<(Entity, &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/effect/glue.rs:87:28
[INFO] [stdout]    |
[INFO] [stdout] 87 |         if let Ok((entity, mut glue_effect, transform)) = query.get_mut(*entity) {
[INFO] [stdout]    |                            ----^^^^^^^^^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `mag_entity`
[INFO] [stdout]   --> src/effect/magnetic.rs:46:11
[INFO] [stdout]    |
[INFO] [stdout] 46 |     for ((mag_entity, magnet_transform, mut magnet_self_impulse, effect)) in
[INFO] [stdout]    |           ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_mag_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_entity`
[INFO] [stdout]   --> src/effect/magnetic.rs:49:14
[INFO] [stdout]    |
[INFO] [stdout] 49 |         for (block_entity, block_transform, mut external_impulse) in blocks_query.iter_mut() {
[INFO] [stdout]    |              ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_a`
[INFO] [stdout]   --> src/effect/magnetic.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 |         [(entity_a, transform_a, mut impulse_a, effect_a), (entity_b, transform_b, mut impulse_b, effect_b)],
[INFO] [stdout]    |           ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity_b`
[INFO] [stdout]   --> src/effect/magnetic.rs:61:61
[INFO] [stdout]    |
[INFO] [stdout] 61 |         [(entity_a, transform_a, mut impulse_a, effect_a), (entity_b, transform_b, mut impulse_b, effect_b)],
[INFO] [stdout]    |                                                             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/environment/car.rs:233:5
[INFO] [stdout]     |
[INFO] [stdout] 233 |     mut block_query: Query<Entity, With<Block>>,
[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/environment/car.rs:281:5
[INFO] [stdout]     |
[INFO] [stdout] 281 |     mut time: ResMut<Time>,
[INFO] [stdout]     |     ----^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `level`
[INFO] [stdout]   --> src/environment/city.rs:26:69
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub fn setup_city(mut commands: Commands, assets: Res<AssetServer>, level: Res<Level>) {
[INFO] [stdout]    |                                                                     ^^^^^ help: if this is intentional, prefix it with an underscore: `_level`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `beam_entity`
[INFO] [stdout]   --> src/environment/beam.rs:60:10
[INFO] [stdout]    |
[INFO] [stdout] 60 |     for (beam_entity, beam, mut beam_transform, beam_global_transform, mut sprite) in
[INFO] [stdout]    |          ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_beam_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/environment/debris_cleaner.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     mut assets: ResMut<AssetServer>,
[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/environment/debris_cleaner.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 |     let mut debris_cleaner_count = debris_cleaner_query.iter_mut().count();
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `debris_cleaner_entity`
[INFO] [stdout]   --> src/environment/debris_cleaner.rs:76:10
[INFO] [stdout]    |
[INFO] [stdout] 76 |     for (debris_cleaner_entity, debris_cleaner_transform) in debris_cleaner_query.iter_mut() {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_debris_cleaner_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `debris_entity`
[INFO] [stdout]   --> src/environment/debris_cleaner.rs:77:14
[INFO] [stdout]    |
[INFO] [stdout] 77 |         for (debris_entity, debris_transform, mut debris_impulse) in debris_query.iter_mut() {
[INFO] [stdout]    |              ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_debris_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]   --> src/environment/debris_cleaner.rs:72:9
[INFO] [stdout]    |
[INFO] [stdout] 72 |     mut commands: Commands,
[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/environment/debris_cleaner.rs:72:5
[INFO] [stdout]    |
[INFO] [stdout] 72 |     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/environment/debris_cleaner.rs:97:5
[INFO] [stdout]    |
[INFO] [stdout] 97 |     mut debris_cleaner_query: Query<Entity, With<DebrisCleaner>>,
[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/environment/debris_cleaner.rs:100:5
[INFO] [stdout]     |
[INFO] [stdout] 100 |     mut assets: ResMut<AssetServer>,
[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/environment/car.rs:233:5
[INFO] [stdout]     |
[INFO] [stdout] 233 |     mut block_query: Query<Entity, With<Block>>,
[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/environment/car.rs:281:5
[INFO] [stdout]     |
[INFO] [stdout] 281 |     mut time: ResMut<Time>,
[INFO] [stdout]     |     ----^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `level`
[INFO] [stdout]   --> src/environment/city.rs:26:69
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub fn setup_city(mut commands: Commands, assets: Res<AssetServer>, level: Res<Level>) {
[INFO] [stdout]    |                                                                     ^^^^^ help: if this is intentional, prefix it with an underscore: `_level`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> src/environment/rain.rs:68:17
[INFO] [stdout]    |
[INFO] [stdout] 68 |             for i in 0..rain_amount {
[INFO] [stdout]    |                 ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transform`
[INFO] [stdout]    --> src/environment/rain.rs:153:35
[INFO] [stdout]     |
[INFO] [stdout] 153 |                         if let Ok(transform) = splash_query.get(*other_entity) {
[INFO] [stdout]     |                                   ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transform`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/environment/debris_cleaner.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     mut assets: ResMut<AssetServer>,
[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/environment/debris_cleaner.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 |     let mut debris_cleaner_count = debris_cleaner_query.iter_mut().count();
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `debris_cleaner_entity`
[INFO] [stdout]   --> src/environment/debris_cleaner.rs:76:10
[INFO] [stdout]    |
[INFO] [stdout] 76 |     for (debris_cleaner_entity, debris_cleaner_transform) in debris_cleaner_query.iter_mut() {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_debris_cleaner_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `debris_entity`
[INFO] [stdout]   --> src/environment/debris_cleaner.rs:77:14
[INFO] [stdout]    |
[INFO] [stdout] 77 |         for (debris_entity, debris_transform, mut debris_impulse) in debris_query.iter_mut() {
[INFO] [stdout]    |              ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_debris_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]   --> src/environment/debris_cleaner.rs:72:9
[INFO] [stdout]    |
[INFO] [stdout] 72 |     mut commands: Commands,
[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/environment/debris_cleaner.rs:72:5
[INFO] [stdout]    |
[INFO] [stdout] 72 |     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/environment/debris_cleaner.rs:97:5
[INFO] [stdout]    |
[INFO] [stdout] 97 |     mut debris_cleaner_query: Query<Entity, With<DebrisCleaner>>,
[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/environment/debris_cleaner.rs:100:5
[INFO] [stdout]     |
[INFO] [stdout] 100 |     mut assets: ResMut<AssetServer>,
[INFO] [stdout]     |     ----^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `car`
[INFO] [stdout]   --> src/environment/tow_truck.rs:80:36
[INFO] [stdout]    |
[INFO] [stdout] 80 |         if let Ok((car_entity, mut car, mut car_transform, mut car_velocity)) =
[INFO] [stdout]    |                                    ^^^ help: if this is intentional, prefix it with an underscore: `_car`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/environment/tow_truck.rs:80:32
[INFO] [stdout]    |
[INFO] [stdout] 80 |         if let Ok((car_entity, mut car, mut car_transform, mut car_velocity)) =
[INFO] [stdout]    |                                ----^^^
[INFO] [stdout]    |                                |
[INFO] [stdout]    |                                help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `collider`
[INFO] [stdout]   --> src/launch_platform.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 |     let collider = Collider::cuboid(100.0, 10.0);
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_collider`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/launch_platform.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 |     mut assets: ResMut<AssetServer>,
[INFO] [stdout]    |     ----^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> src/environment/rain.rs:68:17
[INFO] [stdout]    |
[INFO] [stdout] 68 |             for i in 0..rain_amount {
[INFO] [stdout]    |                 ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transform`
[INFO] [stdout]    --> src/environment/rain.rs:153:35
[INFO] [stdout]     |
[INFO] [stdout] 153 |                         if let Ok(transform) = splash_query.get(*other_entity) {
[INFO] [stdout]     |                                   ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transform`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/launch_platform.rs:132:16
[INFO] [stdout]     |
[INFO] [stdout] 132 |     let (base, mut base_transform) = base_query.get_single_mut().unwrap();
[INFO] [stdout]     |                ----^^^^^^^^^^^^^^
[INFO] [stdout]     |                |
[INFO] [stdout]     |                help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `car`
[INFO] [stdout]   --> src/environment/tow_truck.rs:80:36
[INFO] [stdout]    |
[INFO] [stdout] 80 |         if let Ok((car_entity, mut car, mut car_transform, mut car_velocity)) =
[INFO] [stdout]    |                                    ^^^ help: if this is intentional, prefix it with an underscore: `_car`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/environment/tow_truck.rs:80:32
[INFO] [stdout]    |
[INFO] [stdout] 80 |         if let Ok((car_entity, mut car, mut car_transform, mut car_velocity)) =
[INFO] [stdout]    |                                ----^^^
[INFO] [stdout]    |                                |
[INFO] [stdout]    |                                help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/level.rs:336:9
[INFO] [stdout]     |
[INFO] [stdout] 336 |     mut commands: Commands,
[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/level.rs:336:5
[INFO] [stdout]     |
[INFO] [stdout] 336 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `collider`
[INFO] [stdout]   --> src/launch_platform.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 |     let collider = Collider::cuboid(100.0, 10.0);
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_collider`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/level.rs:403:9
[INFO] [stdout]     |
[INFO] [stdout] 403 |     mut commands: Commands,
[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/level.rs:403:5
[INFO] [stdout]     |
[INFO] [stdout] 403 |     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/launch_platform.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 |     mut assets: ResMut<AssetServer>,
[INFO] [stdout]    |     ----^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/level.rs:436:9
[INFO] [stdout]     |
[INFO] [stdout] 436 |     mut commands: Commands,
[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/level.rs:436:5
[INFO] [stdout]     |
[INFO] [stdout] 436 |     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/launch_platform.rs:132:16
[INFO] [stdout]     |
[INFO] [stdout] 132 |     let (base, mut base_transform) = base_query.get_single_mut().unwrap();
[INFO] [stdout]     |                ----^^^^^^^^^^^^^^
[INFO] [stdout]     |                |
[INFO] [stdout]     |                help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `asset_server`
[INFO] [stdout]   --> src/level_ui.rs:30:47
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn setup_level_ui(mut commands: Commands, 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: `commands`
[INFO] [stdout]    --> src/level.rs:336:9
[INFO] [stdout]     |
[INFO] [stdout] 336 |     mut commands: Commands,
[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/level.rs:336:5
[INFO] [stdout]     |
[INFO] [stdout] 336 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `max_blocks`
[INFO] [stdout]    --> src/level_ui.rs:238:33
[INFO] [stdout]     |
[INFO] [stdout] 238 |                     if let Some(max_blocks) = level.max_blocks {
[INFO] [stdout]     |                                 ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_max_blocks`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/level.rs:403:9
[INFO] [stdout]     |
[INFO] [stdout] 403 |     mut commands: Commands,
[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/level.rs:403:5
[INFO] [stdout]     |
[INFO] [stdout] 403 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/level.rs:436:9
[INFO] [stdout]     |
[INFO] [stdout] 436 |     mut commands: Commands,
[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/level.rs:436:5
[INFO] [stdout]     |
[INFO] [stdout] 436 |     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/level_ui.rs:129:5
[INFO] [stdout]     |
[INFO] [stdout] 129 |     mut has_aiming_block: Query<(), With<Aiming>>,
[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/target_height_indicator.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     mut level: Res<Level>,
[INFO] [stdout]    |     ----^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `asset_server`
[INFO] [stdout]   --> src/level_ui.rs:30:47
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn setup_level_ui(mut commands: Commands, 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: `max_blocks`
[INFO] [stdout]    --> src/level_ui.rs:238:33
[INFO] [stdout]     |
[INFO] [stdout] 238 |                     if let Some(max_blocks) = level.max_blocks {
[INFO] [stdout]     |                                 ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_max_blocks`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/level_ui.rs:129:5
[INFO] [stdout]     |
[INFO] [stdout] 129 |     mut has_aiming_block: Query<(), With<Aiming>>,
[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/target_height_indicator.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     mut level: Res<Level>,
[INFO] [stdout]    |     ----^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `hit` is assigned to, but never used
[INFO] [stdout]    --> src/throw.rs:163:17
[INFO] [stdout]     |
[INFO] [stdout] 163 |         let mut hit = false;
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_hit` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hit` is never read
[INFO] [stdout]    --> src/throw.rs:189:21
[INFO] [stdout]     |
[INFO] [stdout] 189 |                     hit = true;
[INFO] [stdout]     |                     ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]    --> src/throw.rs:199:46
[INFO] [stdout]     |
[INFO] [stdout] 199 |                     .fold(Vec2::ZERO, |acc, (entity, magnet_transform, effect)| {
[INFO] [stdout]     |                                              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]    --> src/throw.rs:220:50
[INFO] [stdout]     |
[INFO] [stdout] 220 |                         .fold(Vec2::ZERO, |acc, (entity, block_transform)| {
[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/throw.rs:221:33
[INFO] [stdout]     |
[INFO] [stdout] 221 | ...                   let mut impulse = calculate_magnetic_impulse(
[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/throw.rs:283:33
[INFO] [stdout]     |
[INFO] [stdout] 283 | ...                   let mut texture = effect.texture(block.block_type);
[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/throw.rs:145:5
[INFO] [stdout]     |
[INFO] [stdout] 145 |     mut assets: ResMut<AssetServer>,
[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/throw.rs:161:13
[INFO] [stdout]     |
[INFO] [stdout] 161 |         let mut acceleration = Vec2::Y * GRAVITY;
[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/throw.rs:173:17
[INFO] [stdout]     |
[INFO] [stdout] 173 |             let mut intersection = rapier_context.cast_shape(
[INFO] [stdout]     |                 ----^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `camera_movement`
[INFO] [stdout]    --> src/throw.rs:310:9
[INFO] [stdout]     |
[INFO] [stdout] 310 |     mut camera_movement: ResMut<CameraMovement>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_camera_movement`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/throw.rs:308:5
[INFO] [stdout]     |
[INFO] [stdout] 308 |     mut query: Query<(Entity), With<Aiming>>,
[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/throw.rs:310:5
[INFO] [stdout]     |
[INFO] [stdout] 310 |     mut camera_movement: ResMut<CameraMovement>,
[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/throw.rs:311:5
[INFO] [stdout]     |
[INFO] [stdout] 311 |     mut launch_platform_query: Query<&Transform, With<LaunchPlatform>>,
[INFO] [stdout]     |     ----^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]    --> src/throw.rs:335:10
[INFO] [stdout]     |
[INFO] [stdout] 335 |     for (entity, mut transform) in query.iter_mut() {
[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/throw.rs:332:5
[INFO] [stdout]     |
[INFO] [stdout] 332 |     mut launch_platform_query: Query<&Transform, With<LaunchPlatform>>,
[INFO] [stdout]     |     ----^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `effect`
[INFO] [stdout]    --> src/throw.rs:345:51
[INFO] [stdout]     |
[INFO] [stdout] 345 |             .choose_weighted(&mut thread_rng(), |(effect, weight)| *weight)
[INFO] [stdout]     |                                                   ^^^^^^ help: if this is intentional, prefix it with an underscore: `_effect`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `level_stats`
[INFO] [stdout]    --> src/throw.rs:384:5
[INFO] [stdout]     |
[INFO] [stdout] 384 |     level_stats: Res<LevelStats>,
[INFO] [stdout]     |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_level_stats`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `query`
[INFO] [stdout]    --> src/throw.rs:393:9
[INFO] [stdout]     |
[INFO] [stdout] 393 |     mut query: Query<&mut Transform, With<Aiming>>,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_query`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/throw.rs:393:5
[INFO] [stdout]     |
[INFO] [stdout] 393 |     mut query: Query<&mut Transform, With<Aiming>>,
[INFO] [stdout]     |     ----^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `shot` is never read
[INFO] [stdout]    --> src/throw.rs:428:17
[INFO] [stdout]     |
[INFO] [stdout] 428 |         let mut shot = None;
[INFO] [stdout]     |                 ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `input`
[INFO] [stdout]    --> src/throw.rs:419:9
[INFO] [stdout]     |
[INFO] [stdout] 419 |     mut input: ResMut<Input<KeyCode>>,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_input`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/throw.rs:417:5
[INFO] [stdout]     |
[INFO] [stdout] 417 |     mut query: Query<&mut Transform, With<Aiming>>,
[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/throw.rs:419:5
[INFO] [stdout]     |
[INFO] [stdout] 419 |     mut input: ResMut<Input<KeyCode>>,
[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/throw.rs:422:15
[INFO] [stdout]     |
[INFO] [stdout] 422 |     if let Ok(mut transform) = query.get_single() {
[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/throw.rs:523:5
[INFO] [stdout]     |
[INFO] [stdout] 523 |     mut input: ResMut<Input<KeyCode>>,
[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/throw.rs:524:5
[INFO] [stdout]     |
[INFO] [stdout] 524 |     mut mouse_button_input: ResMut<Input<MouseButton>>,
[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/throw.rs:525:5
[INFO] [stdout]     |
[INFO] [stdout] 525 |     mut touch_input: ResMut<Touches>,
[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/throw.rs:530:5
[INFO] [stdout]     |
[INFO] [stdout] 530 |     mut barrel: Query<Entity, With<Barrel>>,
[INFO] [stdout]     |     ----^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `window`
[INFO] [stdout]   --> src/ui.rs:31:15
[INFO] [stdout]    |
[INFO] [stdout] 31 |     if let Ok(window) = windows.get_single() {
[INFO] [stdout]    |               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_window`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `hit` is assigned to, but never used
[INFO] [stdout]    --> src/throw.rs:163:17
[INFO] [stdout]     |
[INFO] [stdout] 163 |         let mut hit = false;
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_hit` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `hit` is never read
[INFO] [stdout]    --> src/throw.rs:189:21
[INFO] [stdout]     |
[INFO] [stdout] 189 |                     hit = true;
[INFO] [stdout]     |                     ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]    --> src/throw.rs:199:46
[INFO] [stdout]     |
[INFO] [stdout] 199 |                     .fold(Vec2::ZERO, |acc, (entity, magnet_transform, effect)| {
[INFO] [stdout]     |                                              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]    --> src/throw.rs:220:50
[INFO] [stdout]     |
[INFO] [stdout] 220 |                         .fold(Vec2::ZERO, |acc, (entity, block_transform)| {
[INFO] [stdout]     |                                                  ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `assets`
[INFO] [stdout]    --> src/main.rs:146:51
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub fn setup_graphics(mut commands: Commands, mut assets: ResMut<AssetServer>) {
[INFO] [stdout]     |                                                   ^^^^^^ help: if this is intentional, prefix it with an underscore: `_assets`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:146:47
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub fn setup_graphics(mut commands: Commands, mut assets: ResMut<AssetServer>) {
[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:163:9
[INFO] [stdout]     |
[INFO] [stdout] 163 |     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: `context`
[INFO] [stdout]    --> src/main.rs:165:9
[INFO] [stdout]     |
[INFO] [stdout] 165 |     mut context: ResMut<RapierContext>,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:163:5
[INFO] [stdout]     |
[INFO] [stdout] 163 |     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:165:5
[INFO] [stdout]     |
[INFO] [stdout] 165 |     mut context: ResMut<RapierContext>,
[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/throw.rs:221:33
[INFO] [stdout]     |
[INFO] [stdout] 221 | ...                   let mut impulse = calculate_magnetic_impulse(
[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/throw.rs:283:33
[INFO] [stdout]     |
[INFO] [stdout] 283 | ...                   let mut texture = effect.texture(block.block_type);
[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/throw.rs:145:5
[INFO] [stdout]     |
[INFO] [stdout] 145 |     mut assets: ResMut<AssetServer>,
[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/throw.rs:161:13
[INFO] [stdout]     |
[INFO] [stdout] 161 |         let mut acceleration = Vec2::Y * GRAVITY;
[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/throw.rs:173:17
[INFO] [stdout]     |
[INFO] [stdout] 173 |             let mut intersection = rapier_context.cast_shape(
[INFO] [stdout]     |                 ----^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `camera_movement`
[INFO] [stdout]    --> src/throw.rs:310:9
[INFO] [stdout]     |
[INFO] [stdout] 310 |     mut camera_movement: ResMut<CameraMovement>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_camera_movement`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `base_position` is never used
[INFO] [stdout]    --> src/base.rs:131:8
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub fn base_position(key_code: Res<Input<KeyCode>>, mut query: Query<&mut Velocity, With<Base>>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `despawn_target_beam` is never used
[INFO] [stdout]    --> src/block.rs:451:8
[INFO] [stdout]     |
[INFO] [stdout] 451 | pub fn despawn_target_beam(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `building_collision_groups` is never used
[INFO] [stdout]   --> src/consts.rs:17:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub fn building_collision_groups() -> Group {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `despawn_debris_system` is never used
[INFO] [stdout]    --> src/debris.rs:115:8
[INFO] [stdout]     |
[INFO] [stdout] 115 | pub fn despawn_debris_system(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Platform` is never constructed
[INFO] [stdout]   --> src/effect/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub enum EffectType {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] 25 |     Glue,
[INFO] [stdout] 26 |     Platform,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `EffectType` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ALL_EFFECTS` is never used
[INFO] [stdout]   --> src/effect/mod.rs:30:11
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub const ALL_EFFECTS: [EffectType; 3] =
[INFO] [stdout]    |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_EFFECTS` is never used
[INFO] [stdout]   --> src/effect/mod.rs:33:11
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub const DEFAULT_EFFECTS: [EffectType; 2] = [EffectType::Glue, EffectType::Magnetic];
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Glued` is never constructed
[INFO] [stdout]   --> src/effect/glue.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub enum GlueEffectPhase {
[INFO] [stdout]    |          --------------- variant in this enum
[INFO] [stdout] 25 |     Gluing { targets: Vec<Entity> },
[INFO] [stdout] 26 |     Glued,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GlueEffectPhase` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `car_type` is never read
[INFO] [stdout]    --> src/environment/car.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 107 | pub struct Car {
[INFO] [stdout]     |            --- field in this struct
[INFO] [stdout] 108 |     state: CarState,
[INFO] [stdout] 109 |     car_type: CarType,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Car` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/throw.rs:308:5
[INFO] [stdout]     |
[INFO] [stdout] 308 |     mut query: Query<(Entity), With<Aiming>>,
[INFO] [stdout]     |     ----^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `egui_level_ui` is never used
[INFO] [stdout]   --> src/level_ui.rs:59:8
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub fn egui_level_ui(
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Playing` is never constructed
[INFO] [stdout]   --> src/state.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub enum GameState {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 29 |     Playing,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GameState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/throw.rs:310:5
[INFO] [stdout]     |
[INFO] [stdout] 310 |     mut camera_movement: ResMut<CameraMovement>,
[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/throw.rs:311:5
[INFO] [stdout]     |
[INFO] [stdout] 311 |     mut launch_platform_query: Query<&Transform, With<LaunchPlatform>>,
[INFO] [stdout]     |     ----^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entity`
[INFO] [stdout]    --> src/throw.rs:335:10
[INFO] [stdout]     |
[INFO] [stdout] 335 |     for (entity, mut transform) in query.iter_mut() {
[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/throw.rs:332:5
[INFO] [stdout]     |
[INFO] [stdout] 332 |     mut launch_platform_query: Query<&Transform, With<LaunchPlatform>>,
[INFO] [stdout]     |     ----^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `effect`
[INFO] [stdout]    --> src/throw.rs:345:51
[INFO] [stdout]     |
[INFO] [stdout] 345 |             .choose_weighted(&mut thread_rng(), |(effect, weight)| *weight)
[INFO] [stdout]     |                                                   ^^^^^^ help: if this is intentional, prefix it with an underscore: `_effect`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `level_stats`
[INFO] [stdout]    --> src/throw.rs:384:5
[INFO] [stdout]     |
[INFO] [stdout] 384 |     level_stats: Res<LevelStats>,
[INFO] [stdout]     |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_level_stats`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `query`
[INFO] [stdout]    --> src/throw.rs:393:9
[INFO] [stdout]     |
[INFO] [stdout] 393 |     mut query: Query<&mut Transform, With<Aiming>>,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_query`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/throw.rs:393:5
[INFO] [stdout]     |
[INFO] [stdout] 393 |     mut query: Query<&mut Transform, With<Aiming>>,
[INFO] [stdout]     |     ----^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `shot` is never read
[INFO] [stdout]    --> src/throw.rs:428:17
[INFO] [stdout]     |
[INFO] [stdout] 428 |         let mut shot = None;
[INFO] [stdout]     |                 ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `input`
[INFO] [stdout]    --> src/throw.rs:419:9
[INFO] [stdout]     |
[INFO] [stdout] 419 |     mut input: ResMut<Input<KeyCode>>,
[INFO] [stdout]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_input`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/throw.rs:417:5
[INFO] [stdout]     |
[INFO] [stdout] 417 |     mut query: Query<&mut Transform, With<Aiming>>,
[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/throw.rs:419:5
[INFO] [stdout]     |
[INFO] [stdout] 419 |     mut input: ResMut<Input<KeyCode>>,
[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/throw.rs:422:15
[INFO] [stdout]     |
[INFO] [stdout] 422 |     if let Ok(mut transform) = query.get_single() {
[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/throw.rs:523:5
[INFO] [stdout]     |
[INFO] [stdout] 523 |     mut input: ResMut<Input<KeyCode>>,
[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/throw.rs:524:5
[INFO] [stdout]     |
[INFO] [stdout] 524 |     mut mouse_button_input: ResMut<Input<MouseButton>>,
[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/throw.rs:525:5
[INFO] [stdout]     |
[INFO] [stdout] 525 |     mut touch_input: ResMut<Touches>,
[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/throw.rs:530:5
[INFO] [stdout]     |
[INFO] [stdout] 530 |     mut barrel: Query<Entity, With<Barrel>>,
[INFO] [stdout]     |     ----^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `window`
[INFO] [stdout]   --> src/ui.rs:31:15
[INFO] [stdout]    |
[INFO] [stdout] 31 |     if let Ok(window) = windows.get_single() {
[INFO] [stdout]    |               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_window`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `assets`
[INFO] [stdout]    --> src/main.rs:146:51
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub fn setup_graphics(mut commands: Commands, mut assets: ResMut<AssetServer>) {
[INFO] [stdout]     |                                                   ^^^^^^ help: if this is intentional, prefix it with an underscore: `_assets`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:146:47
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub fn setup_graphics(mut commands: Commands, mut assets: ResMut<AssetServer>) {
[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:163:9
[INFO] [stdout]     |
[INFO] [stdout] 163 |     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: `context`
[INFO] [stdout]    --> src/main.rs:165:9
[INFO] [stdout]     |
[INFO] [stdout] 165 |     mut context: ResMut<RapierContext>,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:163:5
[INFO] [stdout]     |
[INFO] [stdout] 163 |     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:165:5
[INFO] [stdout]     |
[INFO] [stdout] 165 |     mut context: ResMut<RapierContext>,
[INFO] [stdout]     |     ----^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 148 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `base_position` is never used
[INFO] [stdout]    --> src/base.rs:131:8
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub fn base_position(key_code: Res<Input<KeyCode>>, mut query: Query<&mut Velocity, With<Base>>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `despawn_target_beam` is never used
[INFO] [stdout]    --> src/block.rs:451:8
[INFO] [stdout]     |
[INFO] [stdout] 451 | pub fn despawn_target_beam(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `building_collision_groups` is never used
[INFO] [stdout]   --> src/consts.rs:17:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub fn building_collision_groups() -> Group {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `despawn_debris_system` is never used
[INFO] [stdout]    --> src/debris.rs:115:8
[INFO] [stdout]     |
[INFO] [stdout] 115 | pub fn despawn_debris_system(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Platform` is never constructed
[INFO] [stdout]   --> src/effect/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub enum EffectType {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] 25 |     Glue,
[INFO] [stdout] 26 |     Platform,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `EffectType` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ALL_EFFECTS` is never used
[INFO] [stdout]   --> src/effect/mod.rs:30:11
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub const ALL_EFFECTS: [EffectType; 3] =
[INFO] [stdout]    |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_EFFECTS` is never used
[INFO] [stdout]   --> src/effect/mod.rs:33:11
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub const DEFAULT_EFFECTS: [EffectType; 2] = [EffectType::Glue, EffectType::Magnetic];
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Glued` is never constructed
[INFO] [stdout]   --> src/effect/glue.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub enum GlueEffectPhase {
[INFO] [stdout]    |          --------------- variant in this enum
[INFO] [stdout] 25 |     Gluing { targets: Vec<Entity> },
[INFO] [stdout] 26 |     Glued,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GlueEffectPhase` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `car_type` is never read
[INFO] [stdout]    --> src/environment/car.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 107 | pub struct Car {
[INFO] [stdout]     |            --- field in this struct
[INFO] [stdout] 108 |     state: CarState,
[INFO] [stdout] 109 |     car_type: CarType,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Car` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `egui_level_ui` is never used
[INFO] [stdout]   --> src/level_ui.rs:59:8
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub fn egui_level_ui(
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Playing` is never constructed
[INFO] [stdout]   --> src/state.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub enum GameState {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 29 |     Playing,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GameState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 148 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished dev [optimized + debuginfo] target(s) in 46.49s
[INFO] running `Command { std: "docker" "inspect" "892c86bbf84536f30da666426a1d0a6db822f634b6fbe8ee089b9388c8ddc028", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "892c86bbf84536f30da666426a1d0a6db822f634b6fbe8ee089b9388c8ddc028", kill_on_drop: false }`
[INFO] [stdout] 892c86bbf84536f30da666426a1d0a6db822f634b6fbe8ee089b9388c8ddc028
