[INFO] cloning repository https://github.com/edgarcoime/rust_space_invaders
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/edgarcoime/rust_space_invaders" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fedgarcoime%2Frust_space_invaders", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fedgarcoime%2Frust_space_invaders'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] b53c3d04f90b496f89e7c2665016b2fcda65b2c9
[INFO] checking edgarcoime/rust_space_invaders against 1.95.0 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fedgarcoime%2Frust_space_invaders" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/edgarcoime/rust_space_invaders
[INFO] finished tweaking git repo https://github.com/edgarcoime/rust_space_invaders
[INFO] tweaked toml for git repo https://github.com/edgarcoime/rust_space_invaders written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/edgarcoime/rust_space_invaders on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/edgarcoime/rust_space_invaders already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded bevy_window v0.6.0
[INFO] [stderr]   Downloaded bevy_winit v0.6.1
[INFO] [stderr]   Downloaded bevy_internal v0.6.0
[INFO] [stderr]   Downloaded tracing-attributes v0.1.19
[INFO] [stderr]   Downloaded bevy_utils v0.6.0
[INFO] [stderr]   Downloaded bytemuck_derive v1.0.1
[INFO] [stderr]   Downloaded bevy_audio v0.6.0
[INFO] [stderr]   Downloaded bevy-crevice-derive v0.6.0
[INFO] [stderr]   Downloaded bevy_text v0.6.0
[INFO] [stderr]   Downloaded bevy_input v0.6.0
[INFO] [stderr]   Downloaded bevy_transform v0.6.0
[INFO] [stderr]   Downloaded bevy_gilrs v0.6.0
[INFO] [stderr]   Downloaded bevy_core_pipeline v0.6.0
[INFO] [stderr]   Downloaded bevy_reflect_derive v0.6.0
[INFO] [stderr]   Downloaded bevy_diagnostic v0.6.0
[INFO] [stderr]   Downloaded bevy_core v0.6.0
[INFO] [stderr]   Downloaded gltf-derive v0.16.0
[INFO] [stderr]   Downloaded bevy_app v0.6.0
[INFO] [stderr]   Downloaded bevy_scene v0.6.0
[INFO] [stderr]   Downloaded gltf-json v0.16.0
[INFO] [stderr]   Downloaded bytemuck v1.8.0
[INFO] [stderr]   Downloaded gltf v0.16.0
[INFO] [stderr]   Downloaded bevy_pbr v0.6.1
[INFO] [stderr]   Downloaded bevy_render v0.6.1
[INFO] [stderr]   Downloaded hexasphere v6.1.0
[INFO] [stderr]   Downloaded bevy_reflect v0.6.0
[INFO] [stderr]   Downloaded bevy v0.6.1
[INFO] [stderr]   Downloaded mio v0.8.0
[INFO] [stderr]   Downloaded bevy_ecs v0.6.1
[INFO] [stderr]   Downloaded tracing v0.1.31
[INFO] [stderr]   Downloaded glam v0.20.2
[INFO] [stderr]   Downloaded bevy_gltf v0.6.0
[INFO] [stderr]   Downloaded bevy_asset v0.6.0
[INFO] [stderr]   Downloaded bevy_crevice v0.6.1
[INFO] [stderr]   Downloaded bevy_sprite v0.6.0
[INFO] [stderr]   Downloaded bevy_ui v0.6.1
[INFO] [stderr]   Downloaded bevy_tasks v0.6.0
[INFO] [stderr]   Downloaded bevy_ecs_macros v0.6.0
[INFO] [stderr]   Downloaded tracing-core v0.1.22
[INFO] [stderr]   Downloaded bevy_math v0.6.0
[INFO] [stderr]   Downloaded bevy_log v0.6.0
[INFO] [stderr]   Downloaded bevy_macro_utils v0.6.0
[INFO] [stderr]   Downloaded bevy_derive v0.6.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] ebbe5a2c04385b5bb652bd806ded22d6d88f0f9828587bd5deb40024deb6fb3c
[INFO] running `Command { std: "docker" "start" "-a" "ebbe5a2c04385b5bb652bd806ded22d6d88f0f9828587bd5deb40024deb6fb3c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "ebbe5a2c04385b5bb652bd806ded22d6d88f0f9828587bd5deb40024deb6fb3c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ebbe5a2c04385b5bb652bd806ded22d6d88f0f9828587bd5deb40024deb6fb3c", kill_on_drop: false }`
[INFO] [stdout] ebbe5a2c04385b5bb652bd806ded22d6d88f0f9828587bd5deb40024deb6fb3c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 482ee7e038fce561eba78b1e2f7636d65327f7268c142b47165c2235105eb63e
[INFO] running `Command { std: "docker" "start" "-a" "482ee7e038fce561eba78b1e2f7636d65327f7268c142b47165c2235105eb63e", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v1.0.86
[INFO] [stderr]    Compiling libc v0.2.119
[INFO] [stderr]    Compiling indexmap v1.8.0
[INFO] [stderr]     Checking once_cell v1.10.0
[INFO] [stderr]    Compiling serde v1.0.136
[INFO] [stderr]    Compiling quote v1.0.15
[INFO] [stderr]    Compiling hashbrown v0.11.2
[INFO] [stderr]    Compiling parking_lot_core v0.8.5
[INFO] [stderr]     Checking lock_api v0.4.6
[INFO] [stderr]    Compiling log v0.4.14
[INFO] [stderr]     Checking pin-project-lite v0.2.8
[INFO] [stderr]    Compiling memchr v2.4.1
[INFO] [stderr]     Checking tracing-core v0.1.22
[INFO] [stderr]    Compiling futures-core v0.3.21
[INFO] [stderr]     Checking mint v0.5.9
[INFO] [stderr]     Checking fixedbitset v0.4.1
[INFO] [stderr]    Compiling erased-serde v0.3.18
[INFO] [stderr]    Compiling getrandom v0.2.5
[INFO] [stderr]     Checking cache-padded v1.2.0
[INFO] [stderr]     Checking fxhash v0.2.1
[INFO] [stderr]     Checking concurrent-queue v1.2.2
[INFO] [stderr]    Compiling num-traits v0.2.14
[INFO] [stderr]     Checking fastrand v1.7.0
[INFO] [stderr]     Checking futures-io v0.3.21
[INFO] [stderr]     Checking async-task v4.2.0
[INFO] [stderr]     Checking slab v0.4.5
[INFO] [stderr]     Checking event-listener v2.5.2
[INFO] [stderr]     Checking futures-lite v1.12.0
[INFO] [stderr]     Checking async-channel v1.6.1
[INFO] [stderr]    Compiling pkg-config v0.3.24
[INFO] [stderr]     Checking regex-automata v0.1.10
[INFO] [stderr]     Checking aho-corasick v0.7.18
[INFO] [stderr]     Checking ahash v0.7.6
[INFO] [stderr]     Checking num_cpus v1.13.1
[INFO] [stderr]     Checking async-executor v1.4.1
[INFO] [stderr]     Checking cty v0.2.2
[INFO] [stderr]    Compiling crossbeam-utils v0.8.7
[INFO] [stderr]     Checking bevy_tasks v0.6.0
[INFO] [stderr]     Checking matchers v0.1.0
[INFO] [stderr]     Checking raw-window-handle v0.4.2
[INFO] [stderr]     Checking tracing-log v0.1.2
[INFO] [stderr]     Checking regex v1.5.4
[INFO] [stderr]     Checking thread_local v1.1.4
[INFO] [stderr]     Checking sharded-slab v0.1.4
[INFO] [stderr]     Checking rand_core v0.6.3
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]    Compiling num-integer v0.1.44
[INFO] [stderr]     Checking unicode-xid v0.2.2
[INFO] [stderr]    Compiling ash v0.34.0+1.2.203
[INFO] [stderr]     Checking unicode-width v0.1.9
[INFO] [stderr]     Checking bit-vec v0.6.3
[INFO] [stderr]     Checking termcolor v1.1.3
[INFO] [stderr]    Compiling anyhow v1.0.56
[INFO] [stderr]     Checking crossbeam-channel v0.5.2
[INFO] [stderr]     Checking bit-set v0.5.2
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking pp-rs v0.2.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking petgraph v0.6.0
[INFO] [stderr]     Checking inotify v0.9.6
[INFO] [stderr]     Checking spirv v0.2.0+1.5.4
[INFO] [stderr]     Checking filetime v0.2.15
[INFO] [stderr]     Checking mio v0.7.14
[INFO] [stderr]     Checking gpu-descriptor-types v0.1.1
[INFO] [stderr]    Compiling wgpu-core v0.12.2
[INFO] [stderr]     Checking gpu-descriptor v0.2.2
[INFO] [stderr]     Checking gpu-alloc v0.5.3
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking khronos-egl v4.1.0
[INFO] [stderr]     Checking notify v5.0.0-pre.11
[INFO] [stderr]     Checking wgpu-types v0.12.0
[INFO] [stderr]    Compiling num-rational v0.3.2
[INFO] [stderr]    Compiling num-iter v0.1.42
[INFO] [stderr]     Checking profiling v1.0.5
[INFO] [stderr]     Checking glow v0.11.2
[INFO] [stderr]     Checking renderdoc-sys v0.7.1
[INFO] [stderr]     Checking arrayvec v0.7.2
[INFO] [stderr]     Checking inplace_it v0.3.3
[INFO] [stderr]    Compiling toml v0.5.8
[INFO] [stderr]    Compiling uuid v0.8.2
[INFO] [stderr]     Checking deflate v0.8.6
[INFO] [stderr]     Checking miniz_oxide v0.3.7
[INFO] [stderr]     Checking copyless v0.1.5
[INFO] [stderr]     Checking scoped_threadpool v0.1.9
[INFO] [stderr]     Checking nix v0.23.1
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]     Checking png v0.16.8
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]     Checking ttf-parser v0.15.0
[INFO] [stderr]    Compiling serde_json v1.0.79
[INFO] [stderr]     Checking euclid v0.22.6
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]    Compiling x11-dl v2.19.1
[INFO] [stderr]    Compiling libm v0.1.4
[INFO] [stderr]     Checking itoa v1.0.1
[INFO] [stderr]     Checking ryu v1.0.9
[INFO] [stderr]    Compiling cpal v0.13.5
[INFO] [stderr]     Checking ab_glyph_rasterizer v0.1.5
[INFO] [stderr]     Checking guillotiere v0.6.2
[INFO] [stderr]     Checking tinyvec v1.5.1
[INFO] [stderr]     Checking ogg v0.8.0
[INFO] [stderr]     Checking percent-encoding v2.1.0
[INFO] [stderr]    Compiling winit v0.26.1
[INFO] [stderr]     Checking mio v0.8.0
[INFO] [stderr]     Checking stretch v0.3.2
[INFO] [stderr]     Checking lewton v0.10.2
[INFO] [stderr]    Compiling serde_derive v1.0.136
[INFO] [stderr]    Compiling thiserror-impl v1.0.30
[INFO] [stderr]    Compiling bytemuck_derive v1.0.1
[INFO] [stderr]    Compiling tracing-attributes v0.1.19
[INFO] [stderr]     Checking bytemuck v1.8.0
[INFO] [stderr]     Checking owned_ttf_parser v0.15.0
[INFO] [stderr]    Compiling gltf-derive v0.16.0
[INFO] [stderr]     Checking ab_glyph v0.2.15
[INFO] [stderr]     Checking image v0.23.14
[INFO] [stderr]     Checking glyph_brush_layout v0.2.3
[INFO] [stderr]     Checking thiserror v1.0.30
[INFO] [stderr]     Checking naga v0.8.5
[INFO] [stderr]     Checking tracing v0.1.31
[INFO] [stderr]     Checking alsa v0.6.0
[INFO] [stderr]    Compiling cargo-manifest v0.2.6
[INFO] [stderr]    Compiling bevy_macro_utils v0.6.0
[INFO] [stderr]    Compiling bevy_derive v0.6.0
[INFO] [stderr]    Compiling bevy_reflect_derive v0.6.0
[INFO] [stderr]    Compiling bevy_ecs_macros v0.6.0
[INFO] [stderr]    Compiling bevy-crevice-derive v0.6.0
[INFO] [stderr]     Checking smallvec v1.8.0
[INFO] [stderr]     Checking glam v0.20.2
[INFO] [stderr]     Checking ron v0.7.0
[INFO] [stderr]     Checking tracing-subscriber v0.3.9
[INFO] [stderr]     Checking bevy_utils v0.6.0
[INFO] [stderr]     Checking gilrs-core v0.3.2
[INFO] [stderr]     Checking parking_lot v0.11.2
[INFO] [stderr]     Checking gilrs v0.8.2
[INFO] [stderr]     Checking wgpu-hal v0.12.4
[INFO] [stderr]     Checking rodio v0.14.0
[INFO] [stderr]     Checking gltf-json v0.16.0
[INFO] [stderr]     Checking bevy_reflect v0.6.0
[INFO] [stderr]     Checking hexasphere v6.1.0
[INFO] [stderr]     Checking bevy_crevice v0.6.1
[INFO] [stderr]     Checking gltf v0.16.0
[INFO] [stderr]     Checking bevy_ecs v0.6.1
[INFO] [stderr]     Checking bevy_math v0.6.0
[INFO] [stderr]     Checking wgpu v0.12.0
[INFO] [stderr]     Checking bevy_app v0.6.0
[INFO] [stderr]     Checking bevy_core v0.6.0
[INFO] [stderr]     Checking bevy_log v0.6.0
[INFO] [stderr]     Checking bevy_transform v0.6.0
[INFO] [stderr]     Checking bevy_window v0.6.0
[INFO] [stderr]     Checking bevy_input v0.6.0
[INFO] [stderr]     Checking bevy_diagnostic v0.6.0
[INFO] [stderr]     Checking bevy_gilrs v0.6.0
[INFO] [stderr]     Checking bevy_winit v0.6.1
[INFO] [stderr]     Checking bevy_asset v0.6.0
[INFO] [stderr]     Checking bevy_render v0.6.1
[INFO] [stderr]     Checking bevy_scene v0.6.0
[INFO] [stderr]     Checking bevy_audio v0.6.0
[INFO] [stderr]     Checking bevy_core_pipeline v0.6.0
[INFO] [stderr]     Checking bevy_sprite v0.6.0
[INFO] [stderr]     Checking bevy_pbr v0.6.1
[INFO] [stderr]     Checking bevy_text v0.6.0
[INFO] [stderr]     Checking bevy_ui v0.6.1
[INFO] [stderr]     Checking bevy_gltf v0.6.0
[INFO] [stderr]     Checking bevy_internal v0.6.0
[INFO] [stderr]     Checking bevy v0.6.1
[INFO] [stderr]     Checking space_invaders_classic v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `LogDiagnosticsPlugin`
[INFO] [stdout]  --> src/diagnostics.rs:1:90
[INFO] [stdout]   |
[INFO] [stdout] 1 | use bevy::{prelude::*, app::PluginGroupBuilder, diagnostic::{FrameTimeDiagnosticsPlugin, LogDiagnosticsPlugin}};
[INFO] [stdout]   |                                                                                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/entities/enemy.rs:3:33
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy::{prelude::*, sprite::{self, collide_aabb::collide}, core::FixedTimestep};
[INFO] [stdout]   |                                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Game`
[INFO] [stdout]  --> src/entities/enemy.rs:5:13
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::{Game, WinSize, SpriteInfos, shared::{Health, RenderedAssetInfo, WeaponState, Velocity, MovementSpeed, Projectile}, AssetS...
[INFO] [stdout]   |             ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ecs::bundle` and `utils::HashSet`
[INFO] [stdout]  --> src/entities/obstacles.rs:1:24
[INFO] [stdout]   |
[INFO] [stdout] 1 | use bevy::{prelude::*, ecs::bundle, utils::HashSet};
[INFO] [stdout]   |                        ^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Collision`
[INFO] [stdout]  --> src/shared/weapons.rs:3:47
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy::{prelude::*, sprite::collide_aabb::{Collision, collide}, reflect::List};
[INFO] [stdout]   |                                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AssetScaling` and `SpriteInfos`
[INFO] [stdout]  --> src/shared/weapons.rs:4:79
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::{Game, entities::{FromPlayer, Enemy, Obstacle, FromEnemy, Player}, SpriteInfos, AssetScaling};
[INFO] [stdout]   |                                                                               ^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `LogDiagnosticsPlugin`
[INFO] [stdout]  --> src/diagnostics.rs:1:90
[INFO] [stdout]   |
[INFO] [stdout] 1 | use bevy::{prelude::*, app::PluginGroupBuilder, diagnostic::{FrameTimeDiagnosticsPlugin, LogDiagnosticsPlugin}};
[INFO] [stdout]   |                                                                                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/entities/enemy.rs:3:33
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy::{prelude::*, sprite::{self, collide_aabb::collide}, core::FixedTimestep};
[INFO] [stdout]   |                                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Game`
[INFO] [stdout]  --> src/entities/enemy.rs:5:13
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::{Game, WinSize, SpriteInfos, shared::{Health, RenderedAssetInfo, WeaponState, Velocity, MovementSpeed, Projectile}, AssetS...
[INFO] [stdout]   |             ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ecs::bundle` and `utils::HashSet`
[INFO] [stdout]  --> src/entities/obstacles.rs:1:24
[INFO] [stdout]   |
[INFO] [stdout] 1 | use bevy::{prelude::*, ecs::bundle, utils::HashSet};
[INFO] [stdout]   |                        ^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Collision`
[INFO] [stdout]  --> src/shared/weapons.rs:3:47
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy::{prelude::*, sprite::collide_aabb::{Collision, collide}, reflect::List};
[INFO] [stdout]   |                                               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AssetScaling` and `SpriteInfos`
[INFO] [stdout]  --> src/shared/weapons.rs:4:79
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::{Game, entities::{FromPlayer, Enemy, Obstacle, FromEnemy, Player}, SpriteInfos, AssetScaling};
[INFO] [stdout]   |                                                                               ^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reflect::List`
[INFO] [stdout]  --> src/shared/weapons.rs:3:68
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy::{prelude::*, sprite::collide_aabb::{Collision, collide}, reflect::List};
[INFO] [stdout]   |                                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/entities/enemy.rs:169:5
[INFO] [stdout]     |
[INFO] [stdout] 169 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/entities/enemy.rs:169:5
[INFO] [stdout]     |
[INFO] [stdout] 169 |     mut commands: Commands,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sprite_infos`
[INFO] [stdout]    --> src/entities/enemy.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 |     sprite_infos: Res<SpriteInfos>
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sprite_infos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/entities/enemy.rs:202:5
[INFO] [stdout]     |
[INFO] [stdout] 202 |     mut q: Query<(&mut WeaponState, &Transform), With<Enemy>>,
[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/entities/enemy.rs:203:5
[INFO] [stdout]     |
[INFO] [stdout] 203 |     mut alien_state: ResMut<AlienState>,
[INFO] [stdout]     |     ----^^^^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `time`
[INFO] [stdout]    --> src/entities/enemy.rs:204:5
[INFO] [stdout]     |
[INFO] [stdout] 204 |     time: Res<Time>,
[INFO] [stdout]     |     ^^^^ help: if this is intentional, prefix it with an underscore: `_time`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/entities/enemy.rs:249:5
[INFO] [stdout]     |
[INFO] [stdout] 249 |     mut alien_state: ResMut<AlienState>
[INFO] [stdout]     |     ----^^^^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `en_en`
[INFO] [stdout]   --> src/entities/player.rs:97:14
[INFO] [stdout]    |
[INFO] [stdout] 97 |         for (en_en, en_tf, en_rai) in enemy_q.iter() {
[INFO] [stdout]    |              ^^^^^ help: if this is intentional, prefix it with an underscore: `_en_en`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `app`
[INFO] [stdout]   --> src/entities.rs:24:21
[INFO] [stdout]    |
[INFO] [stdout] 24 |     fn build(&self, app: &mut App) {
[INFO] [stdout]    |                     ^^^ help: if this is intentional, prefix it with an underscore: `_app`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/shared/weapons.rs:75:5
[INFO] [stdout]    |
[INFO] [stdout] 75 |     mut game: ResMut<Game>,
[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/shared/weapons.rs:82:9
[INFO] [stdout]    |
[INFO] [stdout] 82 |     let mut entities_despawned: HashSet<Entity> = HashSet::new();
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game`
[INFO] [stdout]   --> src/shared/weapons.rs:75:5
[INFO] [stdout]    |
[INFO] [stdout] 75 |     mut game: ResMut<Game>,
[INFO] [stdout]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entities_despawned`
[INFO] [stdout]   --> src/shared/weapons.rs:82:9
[INFO] [stdout]    |
[INFO] [stdout] 82 |     let mut entities_despawned: HashSet<Entity> = HashSet::new();
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_entities_despawned`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/shared/weapons.rs:113:9
[INFO] [stdout]     |
[INFO] [stdout] 113 |     let mut entities_despawned: HashSet<Entity> = HashSet::new();
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `app`
[INFO] [stdout]   --> src/shared/attributes.rs:32:21
[INFO] [stdout]    |
[INFO] [stdout] 32 |     fn build(&self, app: &mut App) {}
[INFO] [stdout]    |                     ^^^ help: if this is intentional, prefix it with an underscore: `_app`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `AUDIO_DIR` is never used
[INFO] [stdout]   --> src/main.rs:23:7
[INFO] [stdout]    |
[INFO] [stdout] 23 | const AUDIO_DIR: &str = "assets/audio";
[INFO] [stdout]    |       ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FONT_DIR` is never used
[INFO] [stdout]   --> src/main.rs:24:7
[INFO] [stdout]    |
[INFO] [stdout] 24 | const FONT_DIR: &str = "assets/font";
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `MainMenu`, `Paused`, and `GameOver` are never constructed
[INFO] [stdout]   --> src/main.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 38 | enum GameState {
[INFO] [stdout]    |      --------- variants in this enum
[INFO] [stdout] 39 |     MainMenu,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 40 |     InGame,
[INFO] [stdout] 41 |     Paused,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 42 |     GameOver,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GameState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `player_projectile` is never read
[INFO] [stdout]   --> src/main.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct AssetScaling {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 67 |     player_projectile: Vec3,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `top_alien` is never read
[INFO] [stdout]   --> src/main.rs:87:5
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub struct SpriteInfos {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 87 |     top_alien: (Handle<Image>, Vec2),
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SpriteInfos` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `EnemyState` is never constructed
[INFO] [stdout]   --> src/entities/enemy.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct EnemyState;
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TopAlienBundle` is never constructed
[INFO] [stdout]   --> src/entities/enemy.rs:65:8
[INFO] [stdout]    |
[INFO] [stdout] 65 | struct TopAlienBundle {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/entities/enemy.rs:74:8
[INFO] [stdout]    |
[INFO] [stdout] 73 | impl TopAlienBundle {
[INFO] [stdout]    | ------------------- associated function in this implementation
[INFO] [stdout] 74 |     fn new(x: f32, y: f32, sprite_infos: &Res<SpriteInfos>) -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_top_alien` is never used
[INFO] [stdout]    --> src/entities/enemy.rs:168:4
[INFO] [stdout]     |
[INFO] [stdout] 168 | fn setup_top_alien(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `name` is never read
[INFO] [stdout]   --> src/entities/player.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct PlayerState {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] 15 |     name: String
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `original_hp` is never read
[INFO] [stdout]   --> src/shared/attributes.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct Health {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] 10 |     pub original_hp: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from` is never used
[INFO] [stdout]   --> src/shared/attributes.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl Health {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 22 |     pub fn from(hp: u32) -> Self {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reflect::List`
[INFO] [stdout]  --> src/shared/weapons.rs:3:68
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy::{prelude::*, sprite::collide_aabb::{Collision, collide}, reflect::List};
[INFO] [stdout]   |                                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/entities/enemy.rs:169:5
[INFO] [stdout]     |
[INFO] [stdout] 169 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/entities/enemy.rs:169:5
[INFO] [stdout]     |
[INFO] [stdout] 169 |     mut commands: Commands,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sprite_infos`
[INFO] [stdout]    --> src/entities/enemy.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 |     sprite_infos: Res<SpriteInfos>
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sprite_infos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 52s
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/entities/enemy.rs:202:5
[INFO] [stdout]     |
[INFO] [stdout] 202 |     mut q: Query<(&mut WeaponState, &Transform), With<Enemy>>,
[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/entities/enemy.rs:203:5
[INFO] [stdout]     |
[INFO] [stdout] 203 |     mut alien_state: ResMut<AlienState>,
[INFO] [stdout]     |     ----^^^^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `time`
[INFO] [stdout]    --> src/entities/enemy.rs:204:5
[INFO] [stdout]     |
[INFO] [stdout] 204 |     time: Res<Time>,
[INFO] [stdout]     |     ^^^^ help: if this is intentional, prefix it with an underscore: `_time`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/entities/enemy.rs:249:5
[INFO] [stdout]     |
[INFO] [stdout] 249 |     mut alien_state: ResMut<AlienState>
[INFO] [stdout]     |     ----^^^^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `en_en`
[INFO] [stdout]   --> src/entities/player.rs:97:14
[INFO] [stdout]    |
[INFO] [stdout] 97 |         for (en_en, en_tf, en_rai) in enemy_q.iter() {
[INFO] [stdout]    |              ^^^^^ help: if this is intentional, prefix it with an underscore: `_en_en`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `app`
[INFO] [stdout]   --> src/entities.rs:24:21
[INFO] [stdout]    |
[INFO] [stdout] 24 |     fn build(&self, app: &mut App) {
[INFO] [stdout]    |                     ^^^ help: if this is intentional, prefix it with an underscore: `_app`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/shared/weapons.rs:75:5
[INFO] [stdout]    |
[INFO] [stdout] 75 |     mut game: ResMut<Game>,
[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/shared/weapons.rs:82:9
[INFO] [stdout]    |
[INFO] [stdout] 82 |     let mut entities_despawned: HashSet<Entity> = HashSet::new();
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `game`
[INFO] [stdout]   --> src/shared/weapons.rs:75:5
[INFO] [stdout]    |
[INFO] [stdout] 75 |     mut game: ResMut<Game>,
[INFO] [stdout]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entities_despawned`
[INFO] [stdout]   --> src/shared/weapons.rs:82:9
[INFO] [stdout]    |
[INFO] [stdout] 82 |     let mut entities_despawned: HashSet<Entity> = HashSet::new();
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_entities_despawned`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/shared/weapons.rs:113:9
[INFO] [stdout]     |
[INFO] [stdout] 113 |     let mut entities_despawned: HashSet<Entity> = HashSet::new();
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `app`
[INFO] [stdout]   --> src/shared/attributes.rs:32:21
[INFO] [stdout]    |
[INFO] [stdout] 32 |     fn build(&self, app: &mut App) {}
[INFO] [stdout]    |                     ^^^ help: if this is intentional, prefix it with an underscore: `_app`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `AUDIO_DIR` is never used
[INFO] [stdout]   --> src/main.rs:23:7
[INFO] [stdout]    |
[INFO] [stdout] 23 | const AUDIO_DIR: &str = "assets/audio";
[INFO] [stdout]    |       ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FONT_DIR` is never used
[INFO] [stdout]   --> src/main.rs:24:7
[INFO] [stdout]    |
[INFO] [stdout] 24 | const FONT_DIR: &str = "assets/font";
[INFO] [stdout]    |       ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `MainMenu`, `Paused`, and `GameOver` are never constructed
[INFO] [stdout]   --> src/main.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 38 | enum GameState {
[INFO] [stdout]    |      --------- variants in this enum
[INFO] [stdout] 39 |     MainMenu,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 40 |     InGame,
[INFO] [stdout] 41 |     Paused,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 42 |     GameOver,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GameState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `player_projectile` is never read
[INFO] [stdout]   --> src/main.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct AssetScaling {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 67 |     player_projectile: Vec3,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `top_alien` is never read
[INFO] [stdout]   --> src/main.rs:87:5
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub struct SpriteInfos {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 87 |     top_alien: (Handle<Image>, Vec2),
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SpriteInfos` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `EnemyState` is never constructed
[INFO] [stdout]   --> src/entities/enemy.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct EnemyState;
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TopAlienBundle` is never constructed
[INFO] [stdout]   --> src/entities/enemy.rs:65:8
[INFO] [stdout]    |
[INFO] [stdout] 65 | struct TopAlienBundle {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/entities/enemy.rs:74:8
[INFO] [stdout]    |
[INFO] [stdout] 73 | impl TopAlienBundle {
[INFO] [stdout]    | ------------------- associated function in this implementation
[INFO] [stdout] 74 |     fn new(x: f32, y: f32, sprite_infos: &Res<SpriteInfos>) -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_top_alien` is never used
[INFO] [stdout]    --> src/entities/enemy.rs:168:4
[INFO] [stdout]     |
[INFO] [stdout] 168 | fn setup_top_alien(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `name` is never read
[INFO] [stdout]   --> src/entities/player.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct PlayerState {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] 15 |     name: String
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `original_hp` is never read
[INFO] [stdout]   --> src/shared/attributes.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct Health {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] 10 |     pub original_hp: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from` is never used
[INFO] [stdout]   --> src/shared/attributes.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl Health {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 22 |     pub fn from(hp: u32) -> Self {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "482ee7e038fce561eba78b1e2f7636d65327f7268c142b47165c2235105eb63e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "482ee7e038fce561eba78b1e2f7636d65327f7268c142b47165c2235105eb63e", kill_on_drop: false }`
[INFO] [stdout] 482ee7e038fce561eba78b1e2f7636d65327f7268c142b47165c2235105eb63e
