[INFO] cloning repository https://github.com/46-4C-41-47/GDR_wgpu
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/46-4C-41-47/GDR_wgpu" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F46-4C-41-47%2FGDR_wgpu", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F46-4C-41-47%2FGDR_wgpu'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] b6ef54c20d1136f2e3ae45d149384f96d591c733
[INFO] checking 46-4C-41-47/GDR_wgpu against try#5fee451ebd94296ea05214e819c311e164b30af6 for pr-139042
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F46-4C-41-47%2FGDR_wgpu" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/46-4C-41-47/GDR_wgpu on toolchain 5fee451ebd94296ea05214e819c311e164b30af6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+5fee451ebd94296ea05214e819c311e164b30af6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/46-4C-41-47/GDR_wgpu
[INFO] finished tweaking git repo https://github.com/46-4C-41-47/GDR_wgpu
[INFO] tweaked toml for git repo https://github.com/46-4C-41-47/GDR_wgpu written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] crate git repo https://github.com/46-4C-41-47/GDR_wgpu 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" "+5fee451ebd94296ea05214e819c311e164b30af6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4b26683ee3c49f365255c425c23003cbf4366de097804722c29c5bbbee3624d2" "/opt/rustwide/cargo-home/bin/cargo" "+5fee451ebd94296ea05214e819c311e164b30af6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 0c435aabc747baf4c9dde1f73567a0e1602981ea956265d0e1b0ef86ae93ec43
[INFO] running `Command { std: "docker" "start" "-a" "0c435aabc747baf4c9dde1f73567a0e1602981ea956265d0e1b0ef86ae93ec43", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "0c435aabc747baf4c9dde1f73567a0e1602981ea956265d0e1b0ef86ae93ec43", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0c435aabc747baf4c9dde1f73567a0e1602981ea956265d0e1b0ef86ae93ec43", kill_on_drop: false }`
[INFO] [stdout] 0c435aabc747baf4c9dde1f73567a0e1602981ea956265d0e1b0ef86ae93ec43
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4b26683ee3c49f365255c425c23003cbf4366de097804722c29c5bbbee3624d2" "/opt/rustwide/cargo-home/bin/cargo" "+5fee451ebd94296ea05214e819c311e164b30af6" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f843ed1c573bfed3e2111eecc2bbbfe7747e0ac488cada5b3198a00814a7c89a
[INFO] running `Command { std: "docker" "start" "-a" "f843ed1c573bfed3e2111eecc2bbbfe7747e0ac488cada5b3198a00814a7c89a", kill_on_drop: false }`
[INFO] [stderr]     Checking libloading v0.8.6
[INFO] [stderr]    Compiling libc v0.2.167
[INFO] [stderr]    Compiling rustix v0.38.41
[INFO] [stderr]     Checking linux-raw-sys v0.4.14
[INFO] [stderr]    Compiling wayland-sys v0.31.5
[INFO] [stderr]    Compiling cc v1.2.2
[INFO] [stderr]     Checking downcast-rs v1.2.1
[INFO] [stderr]    Compiling wayland-client v0.31.7
[INFO] [stderr]    Compiling version_check v0.9.5
[INFO] [stderr]     Checking tracing-core v0.1.33
[INFO] [stderr]     Checking arrayvec v0.7.6
[INFO] [stderr]    Compiling quick-xml v0.36.2
[INFO] [stderr]    Compiling syn v2.0.90
[INFO] [stderr]    Compiling naga v22.1.0
[INFO] [stderr]     Checking allocator-api2 v0.2.21
[INFO] [stderr]     Checking bit-vec v0.7.0
[INFO] [stderr]    Compiling ash v0.38.0+1.3.281
[INFO] [stderr]     Checking dlib v0.5.2
[INFO] [stderr]    Compiling khronos-egl v6.0.0
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking indexmap v2.7.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.2.0
[INFO] [stderr]     Checking spirv v0.3.0+sdk-1.3.268.0
[INFO] [stderr]     Checking bit-set v0.6.0
[INFO] [stderr]    Compiling wgpu-hal v22.0.0
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking hexf-parse v0.2.1
[INFO] [stderr]     Checking ttf-parser v0.25.1
[INFO] [stderr]     Checking unicode-xid v0.2.6
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]     Checking strict-num v0.1.1
[INFO] [stderr]     Checking xcursor v0.3.8
[INFO] [stderr]     Checking rustc-hash v1.1.0
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]    Compiling smithay-client-toolkit v0.19.2
[INFO] [stderr]     Checking miniz_oxide v0.8.2
[INFO] [stderr]    Compiling wgpu-core v22.1.0
[INFO] [stderr]     Checking wgpu-types v22.0.0
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]    Compiling litrs v0.4.1
[INFO] [stderr]     Checking profiling v1.0.16
[INFO] [stderr]     Checking glow v0.13.1
[INFO] [stderr]     Checking renderdoc-sys v1.1.0
[INFO] [stderr]    Compiling winit v0.30.5
[INFO] [stderr]    Compiling document-features v0.2.10
[INFO] [stderr]     Checking fdeflate v0.3.7
[INFO] [stderr]    Compiling wgpu v22.1.0
[INFO] [stderr]     Checking flate2 v1.0.35
[INFO] [stderr]    Compiling cgmath v0.18.0
[INFO] [stderr]     Checking zune-core v0.4.12
[INFO] [stderr]    Compiling wayland-scanner v0.31.5
[INFO] [stderr]     Checking approx v0.4.0
[INFO] [stderr]     Checking xkbcommon-dl v0.4.2
[INFO] [stderr]     Checking dpi v0.1.1
[INFO] [stderr]     Checking pollster v0.3.0
[INFO] [stderr]     Checking zune-jpeg v0.4.14
[INFO] [stderr]     Checking png v0.17.15
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking memmap2 v0.9.5
[INFO] [stderr]    Compiling wayland-backend v0.3.7
[INFO] [stderr]     Checking is-terminal v0.4.13
[INFO] [stderr]     Checking regex-automata v0.4.9
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking gpu-descriptor v0.3.0
[INFO] [stderr]     Checking owned_ttf_parser v0.25.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling bytemuck_derive v1.8.0
[INFO] [stderr]     Checking ab_glyph v0.2.29
[INFO] [stderr]     Checking regex v1.11.1
[INFO] [stderr]     Checking env_logger v0.10.2
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking bytemuck v1.20.0
[INFO] [stderr]     Checking tiny-skia-path v0.11.4
[INFO] [stderr]     Checking image v0.25.5
[INFO] [stderr]     Checking tiny-skia v0.11.4
[INFO] [stderr]     Checking polling v3.7.4
[INFO] [stderr]     Checking x11rb v0.13.1
[INFO] [stderr]     Checking calloop v0.13.0
[INFO] [stderr]     Checking wayland-csd-frame v0.3.0
[INFO] [stderr]     Checking wayland-protocols v0.32.5
[INFO] [stderr]     Checking calloop-wayland-source v0.3.0
[INFO] [stderr]     Checking wayland-cursor v0.31.7
[INFO] [stderr]     Checking wayland-protocols-wlr v0.3.5
[INFO] [stderr]     Checking wayland-protocols-plasma v0.3.5
[INFO] [stderr]     Checking sctk-adwaita v0.10.1
[INFO] [stderr]     Checking GDR_wgpu v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `KeyCode` and `PhysicalKey`
[INFO] [stdout]  --> src/window_state.rs:9:15
[INFO] [stdout]   |
[INFO] [stdout] 9 |   keyboard::{ KeyCode, PhysicalKey }, 
[INFO] [stdout]   |               ^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> src/window_state.rs:15:13
[INFO] [stdout]    |
[INFO] [stdout] 15 |   texture::{self, Texture}, 
[INFO] [stdout]    |             ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::params::graphical`
[INFO] [stdout]   --> src/window_state.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::params::graphical;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `DIAGONAL_UP_LEFT` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:30:3
[INFO] [stdout]    |
[INFO] [stdout] 30 |   DIAGONAL_UP_LEFT,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DiagonalUpLeft`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `DIAGONAL_UP_RIGHT` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:31:3
[INFO] [stdout]    |
[INFO] [stdout] 31 |   DIAGONAL_UP_RIGHT,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DiagonalUpRight`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `DIAGONAL_DOWN_LEFT` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:32:3
[INFO] [stdout]    |
[INFO] [stdout] 32 |   DIAGONAL_DOWN_LEFT,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DiagonalDownLeft`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `DIAGONAL_DOWN_RIGHT` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:33:3
[INFO] [stdout]    |
[INFO] [stdout] 33 |   DIAGONAL_DOWN_RIGHT,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DiagonalDownRight`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `L_PUNCH` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:35:3
[INFO] [stdout]    |
[INFO] [stdout] 35 |   L_PUNCH,
[INFO] [stdout]    |   ^^^^^^^ help: convert the identifier to upper camel case: `LPunch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `M_PUNCH` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:36:3
[INFO] [stdout]    |
[INFO] [stdout] 36 |   M_PUNCH,
[INFO] [stdout]    |   ^^^^^^^ help: convert the identifier to upper camel case: `MPunch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `H_PUNCH` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:37:3
[INFO] [stdout]    |
[INFO] [stdout] 37 |   H_PUNCH,
[INFO] [stdout]    |   ^^^^^^^ help: convert the identifier to upper camel case: `HPunch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `L_KICK` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:39:3
[INFO] [stdout]    |
[INFO] [stdout] 39 |   L_KICK,
[INFO] [stdout]    |   ^^^^^^ help: convert the identifier to upper camel case: `LKick`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `M_KICK` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:40:3
[INFO] [stdout]    |
[INFO] [stdout] 40 |   M_KICK,
[INFO] [stdout]    |   ^^^^^^ help: convert the identifier to upper camel case: `MKick`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `H_KICK` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:41:3
[INFO] [stdout]    |
[INFO] [stdout] 41 |   H_KICK,
[INFO] [stdout]    |   ^^^^^^ help: convert the identifier to upper camel case: `HKick`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `gdr_engine::Input`
[INFO] [stdout]  --> src/engine/input.rs:3:3
[INFO] [stdout]   |
[INFO] [stdout] 3 |   gdr_engine::Input,
[INFO] [stdout]   |   ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `KeyCode` and `PhysicalKey`
[INFO] [stdout]  --> src/window_state.rs:9:15
[INFO] [stdout]   |
[INFO] [stdout] 9 |   keyboard::{ KeyCode, PhysicalKey }, 
[INFO] [stdout]   |               ^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> src/window_state.rs:15:13
[INFO] [stdout]    |
[INFO] [stdout] 15 |   texture::{self, Texture}, 
[INFO] [stdout]    |             ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::params::graphical`
[INFO] [stdout]   --> src/window_state.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::params::graphical;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `DIAGONAL_UP_LEFT` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:30:3
[INFO] [stdout]    |
[INFO] [stdout] 30 |   DIAGONAL_UP_LEFT,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DiagonalUpLeft`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `DIAGONAL_UP_RIGHT` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:31:3
[INFO] [stdout]    |
[INFO] [stdout] 31 |   DIAGONAL_UP_RIGHT,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DiagonalUpRight`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `DIAGONAL_DOWN_LEFT` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:32:3
[INFO] [stdout]    |
[INFO] [stdout] 32 |   DIAGONAL_DOWN_LEFT,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DiagonalDownLeft`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `DIAGONAL_DOWN_RIGHT` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:33:3
[INFO] [stdout]    |
[INFO] [stdout] 33 |   DIAGONAL_DOWN_RIGHT,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DiagonalDownRight`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `L_PUNCH` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:35:3
[INFO] [stdout]    |
[INFO] [stdout] 35 |   L_PUNCH,
[INFO] [stdout]    |   ^^^^^^^ help: convert the identifier to upper camel case: `LPunch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `M_PUNCH` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:36:3
[INFO] [stdout]    |
[INFO] [stdout] 36 |   M_PUNCH,
[INFO] [stdout]    |   ^^^^^^^ help: convert the identifier to upper camel case: `MPunch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `H_PUNCH` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:37:3
[INFO] [stdout]    |
[INFO] [stdout] 37 |   H_PUNCH,
[INFO] [stdout]    |   ^^^^^^^ help: convert the identifier to upper camel case: `HPunch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `L_KICK` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:39:3
[INFO] [stdout]    |
[INFO] [stdout] 39 |   L_KICK,
[INFO] [stdout]    |   ^^^^^^ help: convert the identifier to upper camel case: `LKick`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `M_KICK` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:40:3
[INFO] [stdout]    |
[INFO] [stdout] 40 |   M_KICK,
[INFO] [stdout]    |   ^^^^^^ help: convert the identifier to upper camel case: `MKick`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `H_KICK` should have an upper camel case name
[INFO] [stdout]   --> src/params.rs:41:3
[INFO] [stdout]    |
[INFO] [stdout] 41 |   H_KICK,
[INFO] [stdout]    |   ^^^^^^ help: convert the identifier to upper camel case: `HKick`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `gdr_engine::Input`
[INFO] [stdout]  --> src/engine/input.rs:3:3
[INFO] [stdout]   |
[INFO] [stdout] 3 |   gdr_engine::Input,
[INFO] [stdout]   |   ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable statement
[INFO] [stdout]    --> src/window_state.rs:176:5
[INFO] [stdout]     |
[INFO] [stdout] 164 | /     match event {
[INFO] [stdout] ...   |
[INFO] [stdout] 174 | |       _ => return false
[INFO] [stdout] 175 | |     }
[INFO] [stdout]     | |_____- any code following this `match` expression is unreachable, as all arms diverge
[INFO] [stdout] 176 |       return true;
[INFO] [stdout]     |       ^^^^^^^^^^^^ unreachable statement
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable statement
[INFO] [stdout]    --> src/window_state.rs:176:5
[INFO] [stdout]     |
[INFO] [stdout] 164 | /     match event {
[INFO] [stdout] ...   |
[INFO] [stdout] 174 | |       _ => return false
[INFO] [stdout] 175 | |     }
[INFO] [stdout]     | |_____- any code following this `match` expression is unreachable, as all arms diverge
[INFO] [stdout] 176 |       return true;
[INFO] [stdout]     |       ^^^^^^^^^^^^ unreachable statement
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `match_to_create`
[INFO] [stdout]    --> src/engine/gdr_engine.rs:142:30
[INFO] [stdout]     |
[INFO] [stdout] 142 |   fn initialize_match(&self, match_to_create: MatchDescriptior) -> Match {
[INFO] [stdout]     |                              ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_match_to_create`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `team_left`
[INFO] [stdout]   --> src/engine/my_match.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |   pub fn new(team_left: Vec<CharacterFile>, team_right: Vec<CharacterFile>) -> Self {
[INFO] [stdout]    |              ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_team_left`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `team_right`
[INFO] [stdout]   --> src/engine/my_match.rs:23:45
[INFO] [stdout]    |
[INFO] [stdout] 23 |   pub fn new(team_left: Vec<CharacterFile>, team_right: Vec<CharacterFile>) -> Self {
[INFO] [stdout]    |                                             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_team_right`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> src/engine/my_match.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |         let a = Self::check_collisions(
[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/engine/my_match.rs:35:13
[INFO] [stdout]    |
[INFO] [stdout] 35 |         let b = Self::check_collisions(
[INFO] [stdout]    |             ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `match_to_create`
[INFO] [stdout]    --> src/engine/gdr_engine.rs:142:30
[INFO] [stdout]     |
[INFO] [stdout] 142 |   fn initialize_match(&self, match_to_create: MatchDescriptior) -> Match {
[INFO] [stdout]     |                              ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_match_to_create`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `enney_hitbox`
[INFO] [stdout]   --> src/engine/character.rs:46:38
[INFO] [stdout]    |
[INFO] [stdout] 46 |   pub fn check_collisions(&mut self, enney_hitbox: Vec<Hitbox>) { 
[INFO] [stdout]    |                                      ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_enney_hitbox`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `json`
[INFO] [stdout]   --> src/engine/action.rs:14:14
[INFO] [stdout]    |
[INFO] [stdout] 14 |   pub fn new(json: String) -> Self { 
[INFO] [stdout]    |              ^^^^ help: if this is intentional, prefix it with an underscore: `_json`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `team_left`
[INFO] [stdout]   --> src/engine/my_match.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |   pub fn new(team_left: Vec<CharacterFile>, team_right: Vec<CharacterFile>) -> Self {
[INFO] [stdout]    |              ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_team_left`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `json`
[INFO] [stdout]  --> src/engine/animation.rs:9:20
[INFO] [stdout]   |
[INFO] [stdout] 9 |   pub fn from_json(json: String) -> Self { todo!() }
[INFO] [stdout]   |                    ^^^^ help: if this is intentional, prefix it with an underscore: `_json`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `team_right`
[INFO] [stdout]   --> src/engine/my_match.rs:23:45
[INFO] [stdout]    |
[INFO] [stdout] 23 |   pub fn new(team_left: Vec<CharacterFile>, team_right: Vec<CharacterFile>) -> Self {
[INFO] [stdout]    |                                             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_team_right`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> src/engine/my_match.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |         let a = Self::check_collisions(
[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/engine/my_match.rs:35:13
[INFO] [stdout]    |
[INFO] [stdout] 35 |         let b = Self::check_collisions(
[INFO] [stdout]    |             ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `update` is never used
[INFO] [stdout]    --> src/window_state.rs:148:10
[INFO] [stdout]     |
[INFO] [stdout] 36  | impl WindowSate {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 148 |   pub fn update(&mut self) {
[INFO] [stdout]     |          ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `enney_hitbox`
[INFO] [stdout]   --> src/engine/character.rs:46:38
[INFO] [stdout]    |
[INFO] [stdout] 46 |   pub fn check_collisions(&mut self, enney_hitbox: Vec<Hitbox>) { 
[INFO] [stdout]    |                                      ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_enney_hitbox`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `json`
[INFO] [stdout]   --> src/engine/action.rs:14:14
[INFO] [stdout]    |
[INFO] [stdout] 14 |   pub fn new(json: String) -> Self { 
[INFO] [stdout]    |              ^^^^ help: if this is intentional, prefix it with an underscore: `_json`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `KnockDownType` is never used
[INFO] [stdout]  --> src/params.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub enum KnockDownType {
[INFO] [stdout]   |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `AttackType` is never used
[INFO] [stdout]   --> src/params.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum AttackType {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ControllerInput` is never used
[INFO] [stdout]   --> src/params.rs:24:10
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub enum ControllerInput {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHADER_PATH` is never used
[INFO] [stdout]  --> src/params.rs:2:13
[INFO] [stdout]   |
[INFO] [stdout] 2 |   pub const SHADER_PATH: &str = "../res/shaders/shader.wgsl";
[INFO] [stdout]   |             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXTURE_PATH` is never used
[INFO] [stdout]  --> src/params.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 |   pub const TEXTURE_PATH: &str = "../res/textures/texture.png";
[INFO] [stdout]   |             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `path`, `dimension`, `image_buffer`, `view`, and `sampler` are never read
[INFO] [stdout]   --> src/texture.rs:6:3
[INFO] [stdout]    |
[INFO] [stdout] 5  | pub struct Texture {
[INFO] [stdout]    |            ------- fields in this struct
[INFO] [stdout] 6  |   path: String,
[INFO] [stdout]    |   ^^^^
[INFO] [stdout] 7  |   dimension: (u32, u32),
[INFO] [stdout]    |   ^^^^^^^^^
[INFO] [stdout] 8  |   image_buffer: RgbaImage,
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout] 9  |   view: TextureView,
[INFO] [stdout]    |   ^^^^
[INFO] [stdout] 10 |   sampler: Sampler,
[INFO] [stdout]    |   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_path` and `get_dimension` are never used
[INFO] [stdout]    --> src/texture.rs:146:10
[INFO] [stdout]     |
[INFO] [stdout] 16  | impl Texture {
[INFO] [stdout]     | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 146 |   pub fn get_path(&self) -> String { self.path.clone() }
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 147 |
[INFO] [stdout] 148 |   pub fn get_dimension(&self) -> (u32, u32) { self.dimension }
[INFO] [stdout]     |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CharacterFile` is never constructed
[INFO] [stdout]   --> src/engine/gdr_engine.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct CharacterFile(String);
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Stage` is never constructed
[INFO] [stdout]   --> src/engine/gdr_engine.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct Stage(String);
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Input` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:23:10
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub enum Input {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Input` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TimeLimit` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:46:10
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub enum TimeLimit {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `RoundType` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:54:10
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub enum RoundType {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `WinType` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:61:10
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub enum WinType {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MatchDescriptior` is never constructed
[INFO] [stdout]   --> src/engine/gdr_engine.rs:71:12
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub struct MatchDescriptior {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TeamType` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:80:10
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub enum TeamType {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MatchResult` is never constructed
[INFO] [stdout]   --> src/engine/gdr_engine.rs:87:12
[INFO] [stdout]    |
[INFO] [stdout] 87 | pub struct MatchResult {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Draw` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:96:7
[INFO] [stdout]    |
[INFO] [stdout] 96 | trait Draw {
[INFO] [stdout]    |       ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DEFAULT_BG_COLOR` is never used
[INFO] [stdout]    --> src/engine/gdr_engine.rs:101:8
[INFO] [stdout]     |
[INFO] [stdout] 101 | static DEFAULT_BG_COLOR: wgpu::Color = wgpu::Color::BLACK;
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `FRAMERATE` is never used
[INFO] [stdout]    --> src/engine/gdr_engine.rs:102:8
[INFO] [stdout]     |
[INFO] [stdout] 102 | static FRAMERATE: u8 = 60;
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `TIME_BETWEEN_FRAMES` is never used
[INFO] [stdout]    --> src/engine/gdr_engine.rs:103:8
[INFO] [stdout]     |
[INFO] [stdout] 103 | static TIME_BETWEEN_FRAMES: Duration = Duration::from_millis(1000 / FRAMERATE as u64);
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GdrEngine` is never constructed
[INFO] [stdout]    --> src/engine/gdr_engine.rs:105:12
[INFO] [stdout]     |
[INFO] [stdout] 105 | pub struct GdrEngine<'a> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `run_match`, `initialize_match`, and `render` are never used
[INFO] [stdout]    --> src/engine/gdr_engine.rs:114:10
[INFO] [stdout]     |
[INFO] [stdout] 113 | impl<'a> GdrEngine<'a> {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout] 114 |   pub fn new(
[INFO] [stdout]     |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |   pub fn run_match(&self, match_to_create: MatchDescriptior) -> MatchResult {
[INFO] [stdout]     |          ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |   fn initialize_match(&self, match_to_create: MatchDescriptior) -> Match {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |   fn render(&self) -> Result<(), wgpu::SurfaceError> {
[INFO] [stdout]     |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CollisionType` is never used
[INFO] [stdout]  --> src/engine/my_match.rs:9:6
[INFO] [stdout]   |
[INFO] [stdout] 9 | enum CollisionType {
[INFO] [stdout]   |      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Match` is never constructed
[INFO] [stdout]   --> src/engine/my_match.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct Match {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `play`, `get_usable_hitbox`, and `check_collisions` are never used
[INFO] [stdout]   --> src/engine/my_match.rs:23:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | impl Match {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 23 |   pub fn new(team_left: Vec<CharacterFile>, team_right: Vec<CharacterFile>) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |   pub fn play(&mut self) -> Option<MatchResult> {
[INFO] [stdout]    |          ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |   fn get_usable_hitbox<'a>(attackant: &'a Vec<Hitbox>, defender: &'a Vec<Hitbox>) 
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |   fn check_collisions(attackant: &Vec<Hitbox>, defender: &Vec<Hitbox>) -> Option<CollisionType> { 
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CharacterState` is never used
[INFO] [stdout]   --> src/engine/character.rs:10:10
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum CharacterState {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Character` is never constructed
[INFO] [stdout]   --> src/engine/character.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct Character {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `check_collisions`, `get_hitbox`, `hit`, `grabbed`, and `grabbing` are never used
[INFO] [stdout]   --> src/engine/character.rs:33:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | impl Character {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 33 |   pub fn new(input_device: InputDevice) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |   pub fn check_collisions(&mut self, enney_hitbox: Vec<Hitbox>) { 
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51 |   pub fn get_hitbox(&self) -> Vec<Hitbox> { todo!() }
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |   fn hit(&mut self) { todo!() }
[INFO] [stdout]    |      ^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |   fn grabbed(&mut self) { todo!() }
[INFO] [stdout]    |      ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60 |   fn grabbing(&mut self) { todo!() }
[INFO] [stdout]    |      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Action` is never constructed
[INFO] [stdout]  --> src/engine/action.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Action {
[INFO] [stdout]   |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `get_current_frame_hitbox`, `next_frame`, and `get_command` are never used
[INFO] [stdout]   --> src/engine/action.rs:14:10
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl Action {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 14 |   pub fn new(json: String) -> Self { 
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |   pub fn get_current_frame_hitbox(&self) -> Vec<Hitbox> { todo!() }
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |   pub fn next_frame(&mut self) { todo!() }
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |   pub fn get_command(&self) -> Vec<Vec<Input>> { self.command.clone() }
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Attack`, `Guard`, `Grab`, and `Body` are never constructed
[INFO] [stdout]  --> src/engine/hitbox.rs:3:3
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub enum HitboxType {
[INFO] [stdout]   |          ---------- variants in this enum
[INFO] [stdout] 3 |   Attack,
[INFO] [stdout]   |   ^^^^^^
[INFO] [stdout] 4 |   Guard,
[INFO] [stdout]   |   ^^^^^
[INFO] [stdout] 5 |   Grab,
[INFO] [stdout]   |   ^^^^
[INFO] [stdout] 6 |   Body,
[INFO] [stdout]   |   ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `HitboxType` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Square` is never constructed
[INFO] [stdout]   --> src/engine/hitbox.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct Square {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Hitbox` is never constructed
[INFO] [stdout]   --> src/engine/hitbox.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct Hitbox {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `collide`, `get_square`, and `get_hitbox_type` are never used
[INFO] [stdout]   --> src/engine/hitbox.rs:24:10
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl Hitbox {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 24 |   pub fn new(square: Square, type_: HitboxType) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |   pub fn collide(&self, other: &Hitbox) -> bool {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39 |   pub fn get_square(&self) -> &Square { &self.square }
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 40 |
[INFO] [stdout] 41 |   pub fn get_hitbox_type(&self) -> HitboxType { self.type_ }
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AnimationDescriptor` is never constructed
[INFO] [stdout]  --> src/engine/animation.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct AnimationDescriptor {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_json` is never used
[INFO] [stdout]  --> src/engine/animation.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | impl AnimationDescriptor {
[INFO] [stdout]   | ------------------------ associated function in this implementation
[INFO] [stdout] 9 |   pub fn from_json(json: String) -> Self { todo!() }
[INFO] [stdout]   |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GraphicConfig` is never constructed
[INFO] [stdout]   --> src/engine/animation.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct GraphicConfig<'a> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Animation` is never constructed
[INFO] [stdout]   --> src/engine/animation.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct Animation {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `draw_next_frame` are never used
[INFO] [stdout]   --> src/engine/animation.rs:28:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | impl Animation {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 28 |   pub fn new(config: AnimationDescriptor, graphic_config: GraphicConfig<'static>) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |   pub fn draw_next_frame(&mut self) { todo!() }
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InputDevice` is never constructed
[INFO] [stdout]  --> src/engine/input.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct InputDevice(u32);
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InputFlow` is never constructed
[INFO] [stdout]   --> src/engine/input.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct InputFlow {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `get_command` are never used
[INFO] [stdout]   --> src/engine/input.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | impl InputFlow {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 17 |   pub fn new(input_device: InputDevice, actions: Vec<Action>) -> Self { 
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 25 |   pub fn get_command(&self) -> Option<u32> { todo!() }
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `json`
[INFO] [stdout]  --> src/engine/animation.rs:9:20
[INFO] [stdout]   |
[INFO] [stdout] 9 |   pub fn from_json(json: String) -> Self { todo!() }
[INFO] [stdout]   |                    ^^^^ help: if this is intentional, prefix it with an underscore: `_json`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `update` is never used
[INFO] [stdout]    --> src/window_state.rs:148:10
[INFO] [stdout]     |
[INFO] [stdout] 36  | impl WindowSate {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 148 |   pub fn update(&mut self) {
[INFO] [stdout]     |          ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `KnockDownType` is never used
[INFO] [stdout]  --> src/params.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub enum KnockDownType {
[INFO] [stdout]   |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `AttackType` is never used
[INFO] [stdout]   --> src/params.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum AttackType {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ControllerInput` is never used
[INFO] [stdout]   --> src/params.rs:24:10
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub enum ControllerInput {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHADER_PATH` is never used
[INFO] [stdout]  --> src/params.rs:2:13
[INFO] [stdout]   |
[INFO] [stdout] 2 |   pub const SHADER_PATH: &str = "../res/shaders/shader.wgsl";
[INFO] [stdout]   |             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXTURE_PATH` is never used
[INFO] [stdout]  --> src/params.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 |   pub const TEXTURE_PATH: &str = "../res/textures/texture.png";
[INFO] [stdout]   |             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `path`, `dimension`, `image_buffer`, `view`, and `sampler` are never read
[INFO] [stdout]   --> src/texture.rs:6:3
[INFO] [stdout]    |
[INFO] [stdout] 5  | pub struct Texture {
[INFO] [stdout]    |            ------- fields in this struct
[INFO] [stdout] 6  |   path: String,
[INFO] [stdout]    |   ^^^^
[INFO] [stdout] 7  |   dimension: (u32, u32),
[INFO] [stdout]    |   ^^^^^^^^^
[INFO] [stdout] 8  |   image_buffer: RgbaImage,
[INFO] [stdout]    |   ^^^^^^^^^^^^
[INFO] [stdout] 9  |   view: TextureView,
[INFO] [stdout]    |   ^^^^
[INFO] [stdout] 10 |   sampler: Sampler,
[INFO] [stdout]    |   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_path` and `get_dimension` are never used
[INFO] [stdout]    --> src/texture.rs:146:10
[INFO] [stdout]     |
[INFO] [stdout] 16  | impl Texture {
[INFO] [stdout]     | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 146 |   pub fn get_path(&self) -> String { self.path.clone() }
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 147 |
[INFO] [stdout] 148 |   pub fn get_dimension(&self) -> (u32, u32) { self.dimension }
[INFO] [stdout]     |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CharacterFile` is never constructed
[INFO] [stdout]   --> src/engine/gdr_engine.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct CharacterFile(String);
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Stage` is never constructed
[INFO] [stdout]   --> src/engine/gdr_engine.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct Stage(String);
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Input` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:23:10
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub enum Input {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Input` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TimeLimit` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:46:10
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub enum TimeLimit {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `RoundType` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:54:10
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub enum RoundType {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `WinType` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:61:10
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub enum WinType {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MatchDescriptior` is never constructed
[INFO] [stdout]   --> src/engine/gdr_engine.rs:71:12
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub struct MatchDescriptior {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TeamType` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:80:10
[INFO] [stdout]    |
[INFO] [stdout] 80 | pub enum TeamType {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MatchResult` is never constructed
[INFO] [stdout]   --> src/engine/gdr_engine.rs:87:12
[INFO] [stdout]    |
[INFO] [stdout] 87 | pub struct MatchResult {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Draw` is never used
[INFO] [stdout]   --> src/engine/gdr_engine.rs:96:7
[INFO] [stdout]    |
[INFO] [stdout] 96 | trait Draw {
[INFO] [stdout]    |       ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DEFAULT_BG_COLOR` is never used
[INFO] [stdout]    --> src/engine/gdr_engine.rs:101:8
[INFO] [stdout]     |
[INFO] [stdout] 101 | static DEFAULT_BG_COLOR: wgpu::Color = wgpu::Color::BLACK;
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `FRAMERATE` is never used
[INFO] [stdout]    --> src/engine/gdr_engine.rs:102:8
[INFO] [stdout]     |
[INFO] [stdout] 102 | static FRAMERATE: u8 = 60;
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `TIME_BETWEEN_FRAMES` is never used
[INFO] [stdout]    --> src/engine/gdr_engine.rs:103:8
[INFO] [stdout]     |
[INFO] [stdout] 103 | static TIME_BETWEEN_FRAMES: Duration = Duration::from_millis(1000 / FRAMERATE as u64);
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GdrEngine` is never constructed
[INFO] [stdout]    --> src/engine/gdr_engine.rs:105:12
[INFO] [stdout]     |
[INFO] [stdout] 105 | pub struct GdrEngine<'a> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `run_match`, `initialize_match`, and `render` are never used
[INFO] [stdout]    --> src/engine/gdr_engine.rs:114:10
[INFO] [stdout]     |
[INFO] [stdout] 113 | impl<'a> GdrEngine<'a> {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout] 114 |   pub fn new(
[INFO] [stdout]     |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |   pub fn run_match(&self, match_to_create: MatchDescriptior) -> MatchResult {
[INFO] [stdout]     |          ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |   fn initialize_match(&self, match_to_create: MatchDescriptior) -> Match {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |   fn render(&self) -> Result<(), wgpu::SurfaceError> {
[INFO] [stdout]     |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CollisionType` is never used
[INFO] [stdout]  --> src/engine/my_match.rs:9:6
[INFO] [stdout]   |
[INFO] [stdout] 9 | enum CollisionType {
[INFO] [stdout]   |      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Match` is never constructed
[INFO] [stdout]   --> src/engine/my_match.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct Match {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `play`, `get_usable_hitbox`, and `check_collisions` are never used
[INFO] [stdout]   --> src/engine/my_match.rs:23:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | impl Match {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 23 |   pub fn new(team_left: Vec<CharacterFile>, team_right: Vec<CharacterFile>) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |   pub fn play(&mut self) -> Option<MatchResult> {
[INFO] [stdout]    |          ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |   fn get_usable_hitbox<'a>(attackant: &'a Vec<Hitbox>, defender: &'a Vec<Hitbox>) 
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |   fn check_collisions(attackant: &Vec<Hitbox>, defender: &Vec<Hitbox>) -> Option<CollisionType> { 
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CharacterState` is never used
[INFO] [stdout]   --> src/engine/character.rs:10:10
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum CharacterState {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Character` is never constructed
[INFO] [stdout]   --> src/engine/character.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct Character {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `check_collisions`, `get_hitbox`, `hit`, `grabbed`, and `grabbing` are never used
[INFO] [stdout]   --> src/engine/character.rs:33:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | impl Character {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 33 |   pub fn new(input_device: InputDevice) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |   pub fn check_collisions(&mut self, enney_hitbox: Vec<Hitbox>) { 
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51 |   pub fn get_hitbox(&self) -> Vec<Hitbox> { todo!() }
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |   fn hit(&mut self) { todo!() }
[INFO] [stdout]    |      ^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |   fn grabbed(&mut self) { todo!() }
[INFO] [stdout]    |      ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60 |   fn grabbing(&mut self) { todo!() }
[INFO] [stdout]    |      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Action` is never constructed
[INFO] [stdout]  --> src/engine/action.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Action {
[INFO] [stdout]   |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `get_current_frame_hitbox`, `next_frame`, and `get_command` are never used
[INFO] [stdout]   --> src/engine/action.rs:14:10
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl Action {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 14 |   pub fn new(json: String) -> Self { 
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |   pub fn get_current_frame_hitbox(&self) -> Vec<Hitbox> { todo!() }
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |   pub fn next_frame(&mut self) { todo!() }
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |   pub fn get_command(&self) -> Vec<Vec<Input>> { self.command.clone() }
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Attack`, `Guard`, `Grab`, and `Body` are never constructed
[INFO] [stdout]  --> src/engine/hitbox.rs:3:3
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub enum HitboxType {
[INFO] [stdout]   |          ---------- variants in this enum
[INFO] [stdout] 3 |   Attack,
[INFO] [stdout]   |   ^^^^^^
[INFO] [stdout] 4 |   Guard,
[INFO] [stdout]   |   ^^^^^
[INFO] [stdout] 5 |   Grab,
[INFO] [stdout]   |   ^^^^
[INFO] [stdout] 6 |   Body,
[INFO] [stdout]   |   ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `HitboxType` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Square` is never constructed
[INFO] [stdout]   --> src/engine/hitbox.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct Square {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Hitbox` is never constructed
[INFO] [stdout]   --> src/engine/hitbox.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct Hitbox {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `collide`, `get_square`, and `get_hitbox_type` are never used
[INFO] [stdout]   --> src/engine/hitbox.rs:24:10
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl Hitbox {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 24 |   pub fn new(square: Square, type_: HitboxType) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |   pub fn collide(&self, other: &Hitbox) -> bool {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39 |   pub fn get_square(&self) -> &Square { &self.square }
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 40 |
[INFO] [stdout] 41 |   pub fn get_hitbox_type(&self) -> HitboxType { self.type_ }
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AnimationDescriptor` is never constructed
[INFO] [stdout]  --> src/engine/animation.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct AnimationDescriptor {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_json` is never used
[INFO] [stdout]  --> src/engine/animation.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | impl AnimationDescriptor {
[INFO] [stdout]   | ------------------------ associated function in this implementation
[INFO] [stdout] 9 |   pub fn from_json(json: String) -> Self { todo!() }
[INFO] [stdout]   |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GraphicConfig` is never constructed
[INFO] [stdout]   --> src/engine/animation.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct GraphicConfig<'a> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Animation` is never constructed
[INFO] [stdout]   --> src/engine/animation.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct Animation {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `draw_next_frame` are never used
[INFO] [stdout]   --> src/engine/animation.rs:28:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | impl Animation {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 28 |   pub fn new(config: AnimationDescriptor, graphic_config: GraphicConfig<'static>) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |   pub fn draw_next_frame(&mut self) { todo!() }
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InputDevice` is never constructed
[INFO] [stdout]  --> src/engine/input.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct InputDevice(u32);
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InputFlow` is never constructed
[INFO] [stdout]   --> src/engine/input.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct InputFlow {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `get_command` are never used
[INFO] [stdout]   --> src/engine/input.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | impl InputFlow {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 17 |   pub fn new(input_device: InputDevice, actions: Vec<Action>) -> Self { 
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 25 |   pub fn get_command(&self) -> Option<u32> { todo!() }
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 50.64s
[INFO] running `Command { std: "docker" "inspect" "f843ed1c573bfed3e2111eecc2bbbfe7747e0ac488cada5b3198a00814a7c89a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f843ed1c573bfed3e2111eecc2bbbfe7747e0ac488cada5b3198a00814a7c89a", kill_on_drop: false }`
[INFO] [stdout] f843ed1c573bfed3e2111eecc2bbbfe7747e0ac488cada5b3198a00814a7c89a
