[INFO] cloning repository https://github.com/toyoyou11/yt-game
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/toyoyou11/yt-game" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftoyoyou11%2Fyt-game", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftoyoyou11%2Fyt-game'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 41bb17605b76e653459a04ec5072d80205667343
[INFO] checking toyoyou11/yt-game against 1.95.0 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftoyoyou11%2Fyt-game" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-3-tc1/source/.cargo/config.toml
[INFO] started tweaking git repo https://github.com/toyoyou11/yt-game
[INFO] finished tweaking git repo https://github.com/toyoyou11/yt-game
[INFO] tweaked toml for git repo https://github.com/toyoyou11/yt-game written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/toyoyou11/yt-game 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/toyoyou11/yt-game 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 sctk-adwaita v0.4.2
[INFO] [stderr]   Downloaded serde_derive v1.0.144
[INFO] [stderr]   Downloaded foreign-types-macros v0.2.2
[INFO] [stderr]   Downloaded serde v1.0.144
[INFO] [stderr]   Downloaded generational-arena v0.2.8
[INFO] [stderr]   Downloaded android_system_properties v0.1.4
[INFO] [stderr]   Downloaded crossfont v0.5.0
[INFO] [stderr]   Downloaded tobj v3.2.3
[INFO] [stderr]   Downloaded anyhow v1.0.64
[INFO] [stderr]   Downloaded wgpu-types v0.14.0
[INFO] [stderr]   Downloaded calloop v0.10.1
[INFO] [stderr]   Downloaded simba v0.7.2
[INFO] [stderr]   Downloaded wide v0.7.4
[INFO] [stderr]   Downloaded url v2.3.0
[INFO] [stderr]   Downloaded png v0.17.6
[INFO] [stderr]   Downloaded wgpu-hal v0.14.0
[INFO] [stderr]   Downloaded nalgebra v0.31.1
[INFO] [stderr]   Downloaded winit v0.27.3
[INFO] [stderr]   Downloaded tokio v1.21.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] c87d63e509874feba5954f1c45c4367e39e7a48b6b9b63d1eeebfd7caac8312f
[INFO] running `Command { std: "docker" "start" "-a" "c87d63e509874feba5954f1c45c4367e39e7a48b6b9b63d1eeebfd7caac8312f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c87d63e509874feba5954f1c45c4367e39e7a48b6b9b63d1eeebfd7caac8312f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c87d63e509874feba5954f1c45c4367e39e7a48b6b9b63d1eeebfd7caac8312f", kill_on_drop: false }`
[INFO] [stdout] c87d63e509874feba5954f1c45c4367e39e7a48b6b9b63d1eeebfd7caac8312f
[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] e3acf654a32edf4ea543c9ffe4266c616538e695d1ce17e47962217b6bf3f9b6
[INFO] running `Command { std: "docker" "start" "-a" "e3acf654a32edf4ea543c9ffe4266c616538e695d1ce17e47962217b6bf3f9b6", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.43
[INFO] [stderr]    Compiling unicode-ident v1.0.3
[INFO] [stderr]    Compiling libc v0.2.132
[INFO] [stderr]    Compiling pkg-config v0.3.25
[INFO] [stderr]    Compiling syn v1.0.99
[INFO] [stderr]    Compiling num-traits v0.2.15
[INFO] [stderr]     Checking once_cell v1.13.1
[INFO] [stderr]     Checking libloading v0.7.3
[INFO] [stderr]    Compiling cc v1.0.73
[INFO] [stderr]     Checking smallvec v1.9.0
[INFO] [stderr]    Compiling xml-rs v0.8.4
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]    Compiling lock_api v0.4.7
[INFO] [stderr]    Compiling parking_lot_core v0.9.3
[INFO] [stderr]    Compiling slotmap v1.0.6
[INFO] [stderr]    Compiling indexmap v1.9.1
[INFO] [stderr]     Checking downcast-rs v1.2.0
[INFO] [stderr]     Checking cty v0.2.2
[INFO] [stderr]     Checking scoped-tls v1.0.0
[INFO] [stderr]     Checking nom v7.1.1
[INFO] [stderr]     Checking miniz_oxide v0.5.4
[INFO] [stderr]    Compiling ash v0.37.0+1.3.209
[INFO] [stderr]     Checking unicode-width v0.1.9
[INFO] [stderr]    Compiling anyhow v1.0.64
[INFO] [stderr]     Checking raw-window-handle v0.5.0
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking gpu-descriptor-types v0.1.1
[INFO] [stderr]    Compiling miniz_oxide v0.4.4
[INFO] [stderr]     Checking foreign-types-shared v0.3.1
[INFO] [stderr]     Checking dlib v0.5.0
[INFO] [stderr]    Compiling serde_derive v1.0.144
[INFO] [stderr]     Checking unicode-xid v0.2.3
[INFO] [stderr]     Checking arrayref v0.3.6
[INFO] [stderr]     Checking adler32 v1.2.0
[INFO] [stderr]    Compiling wgpu-core v0.14.0
[INFO] [stderr]     Checking gpu-alloc v0.5.3
[INFO] [stderr]     Checking wgpu-types v0.14.0
[INFO] [stderr]    Compiling num-iter v0.1.43
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]    Compiling quote v1.0.21
[INFO] [stderr]    Compiling wayland-sys v0.29.4
[INFO] [stderr]    Compiling servo-fontconfig-sys v5.1.0
[INFO] [stderr]     Checking flate2 v1.0.24
[INFO] [stderr]    Compiling smithay-client-toolkit v0.16.0
[INFO] [stderr]    Compiling crossfont v0.5.0
[INFO] [stderr]    Compiling x11-dl v2.20.0
[INFO] [stderr]    Compiling num-rational v0.3.2
[INFO] [stderr]    Compiling wayland-scanner v0.29.4
[INFO] [stderr]     Checking glow v0.11.2
[INFO] [stderr]     Checking renderdoc-sys v0.7.1
[INFO] [stderr]    Compiling typenum v1.15.0
[INFO] [stderr]    Compiling serde v1.0.144
[INFO] [stderr]     Checking arrayvec v0.5.2
[INFO] [stderr]     Checking weezl v0.1.7
[INFO] [stderr]     Checking profiling v1.0.6
[INFO] [stderr]     Checking arrayvec v0.7.2
[INFO] [stderr]     Checking png v0.17.6
[INFO] [stderr]     Checking spirv v0.2.0+1.5.4
[INFO] [stderr]    Compiling cmake v0.1.48
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking num-complex v0.4.2
[INFO] [stderr]     Checking miniz_oxide v0.3.7
[INFO] [stderr]     Checking deflate v0.8.6
[INFO] [stderr]     Checking aho-corasick v0.7.18
[INFO] [stderr]    Compiling paste v1.0.9
[INFO] [stderr]     Checking jpeg-decoder v0.1.22
[INFO] [stderr]    Compiling glob v0.3.0
[INFO] [stderr]    Compiling fs_extra v1.2.0
[INFO] [stderr]    Compiling serde_json v1.0.85
[INFO] [stderr]    Compiling freetype-sys v0.13.1
[INFO] [stderr]    Compiling expat-sys v2.1.6
[INFO] [stderr]     Checking getrandom v0.2.7
[INFO] [stderr]     Checking nix v0.22.3
[INFO] [stderr]     Checking nix v0.24.2
[INFO] [stderr]     Checking xcursor v0.3.4
[INFO] [stderr]     Checking ahash v0.7.6
[INFO] [stderr]     Checking memmap2 v0.5.7
[INFO] [stderr]     Checking freetype-rs v0.26.0
[INFO] [stderr]     Checking khronos-egl v4.1.0
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking regex-syntax v0.6.27
[INFO] [stderr]     Checking matrixmultiply v0.3.2
[INFO] [stderr]     Checking servo-fontconfig v0.5.1
[INFO] [stderr]    Compiling yt-game v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]     Checking tiff v0.6.1
[INFO] [stderr]    Compiling wayland-client v0.29.4
[INFO] [stderr]    Compiling wayland-protocols v0.29.4
[INFO] [stderr]     Checking png v0.16.8
[INFO] [stderr]     Checking mio v0.8.4
[INFO] [stderr]     Checking atty v0.2.14
[INFO] [stderr]     Checking gif v0.11.4
[INFO] [stderr]     Checking raw-window-handle v0.4.3
[INFO] [stderr]     Checking instant v0.1.12
[INFO] [stderr]     Checking itoa v1.0.3
[INFO] [stderr]     Checking scoped_threadpool v0.1.9
[INFO] [stderr]     Checking generational-arena v0.2.8
[INFO] [stderr]     Checking tobj v3.2.3
[INFO] [stderr]     Checking pollster v0.2.5
[INFO] [stderr]     Checking gpu-descriptor v0.2.3
[INFO] [stderr]     Checking regex v1.6.0
[INFO] [stderr]    Compiling bytemuck_derive v1.2.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.32
[INFO] [stderr]    Compiling foreign-types-macros v0.2.2
[INFO] [stderr]    Compiling nalgebra-macros v0.1.0
[INFO] [stderr]     Checking env_logger v0.9.0
[INFO] [stderr]     Checking bytemuck v1.12.1
[INFO] [stderr]     Checking foreign-types v0.5.0
[INFO] [stderr]     Checking wayland-commons v0.29.4
[INFO] [stderr]     Checking safe_arch v0.5.2
[INFO] [stderr]     Checking safe_arch v0.6.0
[INFO] [stderr]     Checking tiny-skia-path v0.7.0
[INFO] [stderr]     Checking image v0.23.14
[INFO] [stderr]     Checking wide v0.7.4
[INFO] [stderr]     Checking thiserror v1.0.32
[INFO] [stderr]     Checking naga v0.10.0
[INFO] [stderr]     Checking calloop v0.10.1
[INFO] [stderr]     Checking tiny-skia v0.7.0
[INFO] [stderr]     Checking wayland-cursor v0.29.4
[INFO] [stderr]     Checking simba v0.7.2
[INFO] [stderr]     Checking wgpu-hal v0.14.0
[INFO] [stderr]     Checking nalgebra v0.31.1
[INFO] [stderr]     Checking wgpu v0.14.0
[INFO] [stderr]     Checking sctk-adwaita v0.4.2
[INFO] [stderr]     Checking winit v0.27.3
[INFO] [stdout] warning: unused import: `WindowBuilder`
[INFO] [stdout]  --> src/game.rs:7:22
[INFO] [stdout]   |
[INFO] [stdout] 7 |     window::{Window, WindowBuilder},
[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::intersect_sphere_sphere::*`
[INFO] [stdout]  --> src/physics/intersect.rs:3:9
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub use self::intersect_sphere_sphere::*;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BufReader` and `Cursor`
[INFO] [stdout]  --> src/renderer/resource.rs:1:15
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::io::{BufReader, Cursor};
[INFO] [stdout]   |               ^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `wgpu::util::DeviceExt`
[INFO] [stdout]  --> src/renderer/resource.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use wgpu::util::DeviceExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::device::Device`
[INFO] [stdout]  --> src/renderer/texture.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use super::device::Device;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `device::*` and `instance::*`
[INFO] [stdout]   --> src/renderer.rs:22:33
[INFO] [stdout]    |
[INFO] [stdout] 22 |     texture::*, render_pass::*, device::*, instance::*
[INFO] [stdout]    |                                 ^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `WindowBuilder`
[INFO] [stdout]  --> src/game.rs:7:22
[INFO] [stdout]   |
[INFO] [stdout] 7 |     window::{Window, WindowBuilder},
[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::intersect_sphere_sphere::*`
[INFO] [stdout]  --> src/physics/intersect.rs:3:9
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub use self::intersect_sphere_sphere::*;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BufReader` and `Cursor`
[INFO] [stdout]  --> src/renderer/resource.rs:1:15
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::io::{BufReader, Cursor};
[INFO] [stdout]   |               ^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `wgpu::util::DeviceExt`
[INFO] [stdout]  --> src/renderer/resource.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use wgpu::util::DeviceExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::device::Device`
[INFO] [stdout]  --> src/renderer/texture.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use super::device::Device;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `device::*` and `instance::*`
[INFO] [stdout]   --> src/renderer.rs:22:33
[INFO] [stdout]    |
[INFO] [stdout] 22 |     texture::*, render_pass::*, device::*, instance::*
[INFO] [stdout]    |                                 ^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/physics/shape.rs:38:13
[INFO] [stdout]    |
[INFO] [stdout] 38 |             _ => {
[INFO] [stdout]    |             ^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]   --> src/physics/shape.rs:38:13
[INFO] [stdout]    |
[INFO] [stdout] 28 |             (Self::Sphere(s1), Self::Sphere(s2)) => contact_sphere_sphere(s1, s2, pos12),
[INFO] [stdout]    |             ------------------------------------ matches some of the same values
[INFO] [stdout] 29 |             (Self::Sphere(s), Self::Cube(c)) => {
[INFO] [stdout]    |             -------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 33 |             (Self::Cube(c), Self::Sphere(s)) => {
[INFO] [stdout]    |             -------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 37 |             (Self::Cube(c1), Self::Cube(c2)) => contact_cube_cube(c1, c2, pos12),
[INFO] [stdout]    |             -------------------------------- matches some of the same values
[INFO] [stdout] 38 |             _ => {
[INFO] [stdout]    |             ^ collectively making this unreachable
[INFO] [stdout]    = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/renderer/camera.rs:66:13
[INFO] [stdout]    |
[INFO] [stdout] 66 |         let mut z = self.near;
[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: `x`
[INFO] [stdout]   --> src/renderer/resource.rs:30:95
[INFO] [stdout]    |
[INFO] [stdout] 30 |         image::RgbaImage::from_fn(Self::DEFAULT_TEXUTER_WIDTH, Self::DEFAULT_TEXUTER_HEIGHT, |x, y| {
[INFO] [stdout]    |                                                                                               ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `y`
[INFO] [stdout]   --> src/renderer/resource.rs:30:98
[INFO] [stdout]    |
[INFO] [stdout] 30 |         image::RgbaImage::from_fn(Self::DEFAULT_TEXUTER_WIDTH, Self::DEFAULT_TEXUTER_HEIGHT, |x, y| {
[INFO] [stdout]    |                                                                                                  ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/physics/shape.rs:38:13
[INFO] [stdout]    |
[INFO] [stdout] 38 |             _ => {
[INFO] [stdout]    |             ^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]   --> src/physics/shape.rs:38:13
[INFO] [stdout]    |
[INFO] [stdout] 28 |             (Self::Sphere(s1), Self::Sphere(s2)) => contact_sphere_sphere(s1, s2, pos12),
[INFO] [stdout]    |             ------------------------------------ matches some of the same values
[INFO] [stdout] 29 |             (Self::Sphere(s), Self::Cube(c)) => {
[INFO] [stdout]    |             -------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 33 |             (Self::Cube(c), Self::Sphere(s)) => {
[INFO] [stdout]    |             -------------------------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 37 |             (Self::Cube(c1), Self::Cube(c2)) => contact_cube_cube(c1, c2, pos12),
[INFO] [stdout]    |             -------------------------------- matches some of the same values
[INFO] [stdout] 38 |             _ => {
[INFO] [stdout]    |             ^ collectively making this unreachable
[INFO] [stdout]    = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `leaf2_id`
[INFO] [stdout]    --> src/physics/bvh.rs:475:13
[INFO] [stdout]     |
[INFO] [stdout] 475 |         let leaf2_id = bvh.insert(
[INFO] [stdout]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_leaf2_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `leaf1_id`
[INFO] [stdout]    --> src/physics/bvh.rs:516:13
[INFO] [stdout]     |
[INFO] [stdout] 516 |         let leaf1_id = bvh.insert(
[INFO] [stdout]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_leaf1_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/renderer/camera.rs:66:13
[INFO] [stdout]    |
[INFO] [stdout] 66 |         let mut z = self.near;
[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: `x`
[INFO] [stdout]   --> src/renderer/resource.rs:30:95
[INFO] [stdout]    |
[INFO] [stdout] 30 |         image::RgbaImage::from_fn(Self::DEFAULT_TEXUTER_WIDTH, Self::DEFAULT_TEXUTER_HEIGHT, |x, y| {
[INFO] [stdout]    |                                                                                               ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `y`
[INFO] [stdout]   --> src/renderer/resource.rs:30:98
[INFO] [stdout]    |
[INFO] [stdout] 30 |         image::RgbaImage::from_fn(Self::DEFAULT_TEXUTER_WIDTH, Self::DEFAULT_TEXUTER_HEIGHT, |x, y| {
[INFO] [stdout]    |                                                                                                  ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `zmax` is assigned to, but never used
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:187:9
[INFO] [stdout]     |
[INFO] [stdout] 187 |     let mut zmax = FLOAT_MIN;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_zmax` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `zmax` is never read
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:203:9
[INFO] [stdout]     |
[INFO] [stdout] 203 |         zmax = xmax.max(transformed.z);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Pose` is never constructed
[INFO] [stdout]   --> src/game.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 35 | enum State{
[INFO] [stdout]    |      ----- variant in this enum
[INFO] [stdout] 36 |     Active,
[INFO] [stdout] 37 |     Pose,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `State` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `World` is never constructed
[INFO] [stdout]  --> src/game/world.rs:2:8
[INFO] [stdout]   |
[INFO] [stdout] 2 | struct World {
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ElementState` is never used
[INFO] [stdout]  --> src/input.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub enum ElementState {
[INFO] [stdout]   |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InputManager` is never constructed
[INFO] [stdout]   --> src/input.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct InputManager {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/input.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl InputManager {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 20 |     /// Create input manager
[INFO] [stdout] 21 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn begin_frame(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33 |     pub fn process_input(&mut self, input: &winit::event::DeviceEvent) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn key_is_up(&self, key: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn key_is_down(&self, key: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn key_is_pressed(&self, key: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn key_is_released(&self, key: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub fn button_is_up(&self, button: u16) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub fn button_is_down(&self, button: u16) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub fn button_is_pressed(&self, button: u16) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60 |     pub fn button_is_released(&self, button: u16) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn get_scroll(&self) -> (f32, f32) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 68 |     pub fn get_mouse_move(&self) -> (f32, f32) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Keycode` is never used
[INFO] [stdout]  --> src/input/keyboard_input.rs:4:10
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub type Keycode = event::VirtualKeyCode;
[INFO] [stdout]   |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `KeyboardInputManager` is never constructed
[INFO] [stdout]  --> src/input/keyboard_input.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct KeyboardInputManager {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/input/keyboard_input.rs:15:11
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl KeyboardInputManager {
[INFO] [stdout]    | ------------------------- associated items in this implementation
[INFO] [stdout] 14 |     /// Number of keys.
[INFO] [stdout] 15 |     const NUM_KEYS: usize = 256;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 16 |     /// Create manager with all keys up
[INFO] [stdout] 17 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 25 |     pub fn begin_frame(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     pub fn process_input(&mut self, input: &winit::event::DeviceEvent) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn is_down(&self, keycode: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn is_up(&self, keycode: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub fn is_pressed(&self, keycode: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn is_released(&self, keycode: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     fn update(&mut self, virtual_keycode: event::VirtualKeyCode, state: event::ElementState) {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MouseInputManager` is never constructed
[INFO] [stdout]  --> src/input/mouse_input.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct MouseInputManager {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/input/mouse_input.rs:13:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl MouseInputManager {
[INFO] [stdout]    | ---------------------- associated items in this implementation
[INFO] [stdout] 13 |     const NUM_MOUSE_BUTTONS: usize = 52;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 14 |     /// Create default manager
[INFO] [stdout] 15 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn get_scroll(&self) -> (Float, Float) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn get_move(&self) -> (Float, Float) {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn begin_frame(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn is_down(&self, id: usize) -> bool {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn is_up(&self, id: usize) -> bool {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 50 |     pub fn is_pressed(&self, id: usize) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub fn is_released(&self, id: usize) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn process_input(&mut self, event: &winit::event::DeviceEvent) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `E` is never used
[INFO] [stdout]  --> src/math.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub const E: Float = std::f32::consts::E;
[INFO] [stdout]   |           ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FLOAT_MIN` is never used
[INFO] [stdout]  --> src/math.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub const FLOAT_MIN: Float = f32::MIN;
[INFO] [stdout]   |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FLOAT_MIN_POSITIVE` is never used
[INFO] [stdout]  --> src/math.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const FLOAT_MIN_POSITIVE: Float = f32::MIN_POSITIVE;
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Point2` is never used
[INFO] [stdout]   --> src/math.rs:10:10
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub type Point2 = na::Point2<Float>;
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Isometry2` is never used
[INFO] [stdout]   --> src/math.rs:13:10
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub type Isometry2 = na::Isometry2<Float>;
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Vector2` is never used
[INFO] [stdout]   --> src/math.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub type Vector2 = na::Vector2<Float>;
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Vector4` is never used
[INFO] [stdout]   --> src/math.rs:18:10
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub type Vector4 = na::Vector4<Float>;
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `UnitVector2` is never used
[INFO] [stdout]   --> src/math.rs:20:10
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub type UnitVector2 = na::UnitVector2<Float>;
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `UnitVector4` is never used
[INFO] [stdout]   --> src/math.rs:22:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub type UnitVector4 = na::UnitVector4<Float>;
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Matrix2` is never used
[INFO] [stdout]   --> src/math.rs:24:10
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub type Matrix2 = na::Matrix2<Float>;
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Translation2` is never used
[INFO] [stdout]   --> src/math.rs:28:10
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub type Translation2 = na::Translation2<Float>;
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Rotation2` is never used
[INFO] [stdout]   --> src/math.rs:31:10
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub type Rotation2 = na::Rotation2<Float>;
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Rotation3` is never used
[INFO] [stdout]   --> src/math.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub type Rotation3 = na::Rotation3<Float>;
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Quaternion` is never used
[INFO] [stdout]   --> src/math.rs:34:10
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub type Quaternion = na::Quaternion<Float>;
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `DualQuaternion` is never used
[INFO] [stdout]   --> src/math.rs:36:10
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub type DualQuaternion = na::DualQuaternion<Float>;
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Scale2` is never used
[INFO] [stdout]   --> src/math.rs:38:10
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub type Scale2 = na::Scale2<Float>;
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `project_vector_on_axis` is never used
[INFO] [stdout]   --> src/math.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub fn project_vector_on_axis(v: &Vector3, axis: &Vector3) -> Vector3 {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/physics/rigid_body.rs:72:12
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl RigidBody {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  72 |     pub fn apply_force_point_local(&mut self, force: &Vector3, point: &Point3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  79 |     pub fn apply_force_point_world(&mut self, force: &Vector3, point: &Point3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     pub fn apply_impulse_point_local(&mut self, impulse: &Vector3, point: &Point3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     pub fn apply_force_local(&mut self, force: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 108 |     pub fn apply_torque_world(&mut self, force: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn apply_torque_local(&mut self, force: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     pub fn apply_impulse_local(&mut self, impulse: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 126 |     pub fn apply_angular_impulse_local(&mut self, impulse: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     pub fn get_inv_inertia_tensor_local(&self) -> Matrix3 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 144 |     pub fn get_center_of_mass_local(&self) -> Point3 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 162 |     pub fn set_angular_velocity(&mut self, v: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 178 |     pub fn set_inv_mass(&mut self, inv_mass: Float) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 184 |     pub fn set_elasticity(&mut self, elasticity: Float) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 188 |     pub fn get_damping(&self) -> Float {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 192 |     pub fn set_damping(&mut self, damping: Float) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 196 |     pub fn get_angular_damping(&self) -> Float {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 200 |     pub fn set_angular_damping(&mut self, damping: Float) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 208 |     pub fn set_friction(&mut self, friction: Float) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub fn world_to_local_vector(&self, v: &Vector3) -> Vector3 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 218 |     pub fn world_to_local_point(&self, p: &Point3) -> Point3 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 233 |     pub fn get_bounding_sphere(&self) -> BoundingSphere {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `build_bounding_sphere` is never used
[INFO] [stdout]   --> src/physics/shape.rs:47:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl ShapeType {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn build_bounding_sphere(&self, pos: &Isometry3) -> BoundingSphere {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `supporting_point_world` and `build_bounding_sphere` are never used
[INFO] [stdout]   --> src/physics/shape.rs:61:8
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub trait Shape {
[INFO] [stdout]    |           ----- methods in this trait
[INFO] [stdout] 60 |     fn supporting_point(&self, dir: &UnitVector3, bias: Float) -> Point3;
[INFO] [stdout] 61 |     fn supporting_point_world(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 76 |     fn build_bounding_sphere(&self, pos: &Isometry3) -> BoundingSphere;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `remove` and `get_mut` are never used
[INFO] [stdout]   --> src/physics/world.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl PhysicsWorld {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 86 |     pub fn remove(&mut self, id: RigidBodyId) -> Option<RigidBody> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 93 |     pub fn get_mut(&mut self, id: RigidBodyId) -> Option<&mut RigidBody> {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `expand` is never used
[INFO] [stdout]   --> src/physics/bvh.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub trait BoundingVolume: Clone + Copy + PartialEq {
[INFO] [stdout]    |           -------------- method in this trait
[INFO] [stdout] 20 |     fn intersect(&self, other: &Self) -> bool;
[INFO] [stdout] 21 |     fn expand(&self, p: &Point3) -> Self {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `BuildBoundingVolume` is never used
[INFO] [stdout]   --> src/physics/bvh.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub trait BuildBoundingVolume<V: BoundingVolume> {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_min_max` is never used
[INFO] [stdout]   --> src/physics/bvh/aabb.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl AABB {
[INFO] [stdout]    | --------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 14 |     pub fn new_min_max(min: Point3, max: Point3) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BoundingSphere` is never constructed
[INFO] [stdout]  --> src/physics/bvh/bounding_sphere.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct BoundingSphere {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/physics/bvh/bounding_sphere.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl BoundingSphere {
[INFO] [stdout]    | ------------------- associated function in this implementation
[INFO] [stdout] 10 |     pub fn new(center: Point3, radius: f32) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `intersect_sphere_sphere` is never used
[INFO] [stdout]  --> src/physics/intersect/intersect_sphere_sphere.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn intersect_sphere_sphere(s1: &Sphere, s2: &Sphere, pos_12: &Isometry3) -> bool {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PointLightId` is never constructed
[INFO] [stdout]  --> src/renderer/light.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct PointLightId {
[INFO] [stdout]   |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `insert_point_light`, `get_point_light`, and `get_point_light_mut` are never used
[INFO] [stdout]   --> src/renderer/light.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | impl Lights {
[INFO] [stdout]    | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn insert_point_light(&mut self, p: PointLight) -> PointLightId {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn get_point_light(&self, id: PointLightId) -> Option<&PointLight> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub fn get_point_light_mut(&mut self, id: PointLightId) -> Option<&mut PointLight> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/renderer/light.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 75 | impl PointLight {
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 76 |     pub fn new(color: [Float; 3], radius: Float, point: Point3) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `OPENGL_TO_WGPU_MATRIX`, `build_camera_matrix`, `build_projection_matrix`, `top_left_at_depth`, and `get_vertex_local` are never used
[INFO] [stdout]   --> src/renderer/camera.rs:15:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl Camera {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 15 |     const OPENGL_TO_WGPU_MATRIX: Matrix4 = 
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 43 |     pub fn build_camera_matrix(&self) -> Matrix4{
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn build_projection_matrix(&self) -> Matrix4 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub fn top_left_at_depth(&self, d: Float) -> Point3{
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn get_vertex_local(&self, index: usize) -> Point3{
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `create_material`, `create_mesh`, `get_default_texture`, and `create_model` are never used
[INFO] [stdout]   --> src/renderer/resource.rs:40:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl ResourceManager{
[INFO] [stdout]    | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub fn create_material(&self, desc: &MaterialDescriptor) -> Material{
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn create_mesh<T: Vertex>(&self, desc: &MeshDescriptor<T>) -> Mesh{
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn get_default_texture(&self) -> Arc<Texture> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn create_model<'a, 'b, 'c, T: Vertex>(&mut self, desc: &ModelDescriptor<T>) -> Arc<Model>{
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/renderer/resource.rs:218:8
[INFO] [stdout]     |
[INFO] [stdout] 218 | struct StaticVertexData{
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]    --> src/renderer/resource.rs:216:1
[INFO] [stdout]     |
[INFO] [stdout] 216 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/renderer/resource.rs:225:8
[INFO] [stdout]     |
[INFO] [stdout] 225 | struct SkeletalVertexData{
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]    --> src/renderer/resource.rs:223:1
[INFO] [stdout]     |
[INFO] [stdout] 223 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]   --> src/renderer/scene.rs:37:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl Scene {
[INFO] [stdout]    | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn remove_entity(&mut self, index: EntityId) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn iter_mut_entities(&mut self) -> ga::IterMut<Entity> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn get_entity(&self, index: EntityId) -> Option<&Entity> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 |     pub fn set_directional_light(&mut self, directional_light: DirectionalLight) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 80 |     pub fn insert_point_light(&mut self, p: PointLight) -> PointLightId {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88 |     pub fn get_point_light(&self, id: PointLightId) -> Option<&PointLight> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 91 |     pub fn get_point_light_mut(&mut self, id: PointLightId) -> Option<&mut PointLight> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ModelDescriptor` is never constructed
[INFO] [stdout]   --> src/renderer/model.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct ModelDescriptor<'a, 'b, 'c, 'd, 'e, 'f, 'g, 'h, 'i, T> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/renderer/model.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl Model {
[INFO] [stdout]    | ---------- associated function in this implementation
[INFO] [stdout] 24 |     pub fn new<T: Vertex>(device: &wgpu::Device, desc: &ModelDescriptor<T>) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `draw_mesh` is never used
[INFO] [stdout]   --> src/renderer/model.rs:45:8
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub trait DrawModel<'a> {
[INFO] [stdout]    |           --------- method in this trait
[INFO] [stdout] 45 |     fn draw_mesh(&mut self, mesh: &'a Mesh, material: &'a Material);
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/renderer/model/material.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct MaterialUniform {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]   --> src/renderer/model/material.rs:14:1
[INFO] [stdout]    |
[INFO] [stdout] 14 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `name`, `buffer`, and `texture` are never read
[INFO] [stdout]   --> src/renderer/model/material.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct Material {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 26 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 27 |     pub buffer: wgpu::Buffer,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 28 |     pub texture: Arc<Texture>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Material` 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 `MeshDescriptor` is never constructed
[INFO] [stdout]  --> src/renderer/model/mesh.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct MeshDescriptor<'a, 'b, 'c, T> {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `name` is never read
[INFO] [stdout]   --> src/renderer/model/mesh.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct Mesh {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout] 12 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Mesh` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `new` and `new_with_index_u16` are never used
[INFO] [stdout]   --> src/renderer/model/mesh.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl Mesh {
[INFO] [stdout]    | --------- associated functions in this implementation
[INFO] [stdout] 21 |     pub fn new<'a, 'b, 'c, T: Vertex>(
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn new_with_index_u16<T: Vertex>(
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]  --> src/renderer/model/vertex.rs:6:1
[INFO] [stdout]   |
[INFO] [stdout] 6 | #[repr(C)]
[INFO] [stdout]   | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/renderer/model/vertex.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct ModelVertex {
[INFO] [stdout]    |            ^^^^^^^^^^^ field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `name` is never read
[INFO] [stdout]  --> src/renderer/entity.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Entity {
[INFO] [stdout]   |            ------ field in this struct
[INFO] [stdout] 7 |     pub name: String,
[INFO] [stdout]   |         ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Entity` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `texture` is never read
[INFO] [stdout]  --> src/renderer/texture.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Texture {
[INFO] [stdout]   |            ------- field in this struct
[INFO] [stdout] 7 |     pub texture: wgpu::Texture,
[INFO] [stdout]   |         ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Texture` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `max_point_lights` is never read
[INFO] [stdout]   --> src/renderer/render_pass.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct RenderPass {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 21 |     max_point_lights: u32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RenderPass` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/renderer/render_pass/camera_uniform_buffer.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub struct CameraUniforms {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]  --> src/renderer/render_pass/camera_uniform_buffer.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | #[repr(C)]
[INFO] [stdout]   | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CascadeShadowPass` is never constructed
[INFO] [stdout]  --> src/renderer/render_pass/shadow/cascaded_shadow.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct CascadeShadowPass {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CascadedShadow` is never constructed
[INFO] [stdout]   --> src/renderer/render_pass/shadow/cascaded_shadow.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct CascadedShadow {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `OVERLAP` and `new` are never used
[INFO] [stdout]   --> src/renderer/render_pass/shadow/cascaded_shadow.rs:21:11
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl CascadedShadow {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 21 |     const OVERLAP: Float = 0.1;
[INFO] [stdout]    |           ^^^^^^^
[INFO] [stdout] 22 |     pub fn new(camera: &Camera, light_direction: &Vector3, resolution: Float) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_cascade_size` is never used
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:114:4
[INFO] [stdout]     |
[INFO] [stdout] 114 | fn calculate_cascade_size(camera: &Camera, zmin: Float, zmax: Float) -> Float {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_min_max` is never used
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:122:4
[INFO] [stdout]     |
[INFO] [stdout] 122 | fn calculate_min_max(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_cascade_position` is never used
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:161:8
[INFO] [stdout]     |
[INFO] [stdout] 161 | pub fn calculate_cascade_position(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]  --> src/renderer/render_pass/light_uniform_buffer.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | #[repr(C)]
[INFO] [stdout]   | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/renderer/render_pass/light_uniform_buffer.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct AmbientLightUniforms {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]   --> src/renderer/render_pass/light_uniform_buffer.rs:20:1
[INFO] [stdout]    |
[INFO] [stdout] 20 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/renderer/render_pass/light_uniform_buffer.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct DirectionalLightUniforms {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]   --> src/renderer/render_pass/light_uniform_buffer.rs:39:1
[INFO] [stdout]    |
[INFO] [stdout] 39 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/renderer/render_pass/light_uniform_buffer.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct PointLightUniforms {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `max_point_lights` is never read
[INFO] [stdout]   --> src/renderer/render_pass/light_uniform_buffer.rs:70:9
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub struct LightUniformBuffer {
[INFO] [stdout]    |            ------------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 70 |     pub max_point_lights: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `LightUniformBuffer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `instance` and `adapter` are never read
[INFO] [stdout]   --> src/renderer/device.rs:50:9
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub struct Device {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] 50 |     pub instance: wgpu::Instance,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 51 |     pub adapter: wgpu::Adapter,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Device` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/renderer/instance.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct InstanceRaw {
[INFO] [stdout]   |            ^^^^^^^^^^^ field in this struct
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]  --> src/renderer/instance.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | #[repr(C)]
[INFO] [stdout]   | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InstanceBuffers` is never constructed
[INFO] [stdout]    --> src/renderer/instance.rs:122:8
[INFO] [stdout]     |
[INFO] [stdout] 122 | struct InstanceBuffers {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/renderer/instance.rs:130:12
[INFO] [stdout]     |
[INFO] [stdout] 129 | impl InstanceBuffers {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] 130 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer/scene.rs:41:26
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn iter_entities(&self) -> ga::Iter<Entity> {
[INFO] [stdout]    |                          ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                          |
[INFO] [stdout]    |                          the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn iter_entities(&self) -> ga::Iter<'_, Entity> {
[INFO] [stdout]    |                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer/scene.rs:45:30
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub fn iter_mut_entities(&mut self) -> ga::IterMut<Entity> {
[INFO] [stdout]    |                              ^^^^^^^^^     ^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub fn iter_mut_entities(&mut self) -> ga::IterMut<'_, Entity> {
[INFO] [stdout]    |                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer/scene.rs:84:30
[INFO] [stdout]    |
[INFO] [stdout] 84 |     pub fn iter_point_lights(&self) -> ga::Iter<PointLight> {
[INFO] [stdout]    |                              ^^^^^     ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 84 |     pub fn iter_point_lights(&self) -> ga::Iter<'_, PointLight> {
[INFO] [stdout]    |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer/instance.rs:88:19
[INFO] [stdout]    |
[INFO] [stdout] 88 |     pub fn insert(&self, data: &InstanceRaw, queue: &wgpu::Queue) -> Option<wgpu::BufferSlice> {
[INFO] [stdout]    |                   ^^^^^ the lifetime is elided here                         ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 88 |     pub fn insert(&self, data: &InstanceRaw, queue: &wgpu::Queue) -> Option<wgpu::BufferSlice<'_>> {
[INFO] [stdout]    |                                                                                              ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer/instance.rs:93:9
[INFO] [stdout]    |
[INFO] [stdout] 93 |         &self,
[INFO] [stdout]    |         ^^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 96 |     ) -> Option<wgpu::BufferSlice> {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 96 |     ) -> Option<wgpu::BufferSlice<'_>> {
[INFO] [stdout]    |                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `zmax` is assigned to, but never used
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:187:9
[INFO] [stdout]     |
[INFO] [stdout] 187 |     let mut zmax = FLOAT_MIN;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_zmax` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `zmax` is never read
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:203:9
[INFO] [stdout]     |
[INFO] [stdout] 203 |         zmax = xmax.max(transformed.z);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Pose` is never constructed
[INFO] [stdout]   --> src/game.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 35 | enum State{
[INFO] [stdout]    |      ----- variant in this enum
[INFO] [stdout] 36 |     Active,
[INFO] [stdout] 37 |     Pose,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `State` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `World` is never constructed
[INFO] [stdout]  --> src/game/world.rs:2:8
[INFO] [stdout]   |
[INFO] [stdout] 2 | struct World {
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InputManager` is never constructed
[INFO] [stdout]   --> src/input.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct InputManager {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/input.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl InputManager {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 20 |     /// Create input manager
[INFO] [stdout] 21 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn begin_frame(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33 |     pub fn process_input(&mut self, input: &winit::event::DeviceEvent) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn key_is_up(&self, key: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn key_is_down(&self, key: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn key_is_pressed(&self, key: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn key_is_released(&self, key: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub fn button_is_up(&self, button: u16) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub fn button_is_down(&self, button: u16) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub fn button_is_pressed(&self, button: u16) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60 |     pub fn button_is_released(&self, button: u16) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn get_scroll(&self) -> (f32, f32) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 68 |     pub fn get_mouse_move(&self) -> (f32, f32) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `process_input`, `is_down`, and `is_up` are never used
[INFO] [stdout]   --> src/input/keyboard_input.rs:30:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl KeyboardInputManager {
[INFO] [stdout]    | ------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 30 |     pub fn process_input(&mut self, input: &winit::event::DeviceEvent) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn is_down(&self, keycode: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn is_up(&self, keycode: Keycode) -> bool {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_scroll`, `get_move`, `is_down`, and `is_up` are never used
[INFO] [stdout]   --> src/input/mouse_input.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl MouseInputManager {
[INFO] [stdout]    | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn get_scroll(&self) -> (Float, Float) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn get_move(&self) -> (Float, Float) {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn is_down(&self, id: usize) -> bool {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn is_up(&self, id: usize) -> bool {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `E` is never used
[INFO] [stdout]  --> src/math.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub const E: Float = std::f32::consts::E;
[INFO] [stdout]   |           ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FLOAT_MIN` is never used
[INFO] [stdout]  --> src/math.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub const FLOAT_MIN: Float = f32::MIN;
[INFO] [stdout]   |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FLOAT_MIN_POSITIVE` is never used
[INFO] [stdout]  --> src/math.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const FLOAT_MIN_POSITIVE: Float = f32::MIN_POSITIVE;
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Point2` is never used
[INFO] [stdout]   --> src/math.rs:10:10
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub type Point2 = na::Point2<Float>;
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Isometry2` is never used
[INFO] [stdout]   --> src/math.rs:13:10
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub type Isometry2 = na::Isometry2<Float>;
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Vector2` is never used
[INFO] [stdout]   --> src/math.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub type Vector2 = na::Vector2<Float>;
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Vector4` is never used
[INFO] [stdout]   --> src/math.rs:18:10
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub type Vector4 = na::Vector4<Float>;
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `UnitVector2` is never used
[INFO] [stdout]   --> src/math.rs:20:10
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub type UnitVector2 = na::UnitVector2<Float>;
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `UnitVector4` is never used
[INFO] [stdout]   --> src/math.rs:22:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub type UnitVector4 = na::UnitVector4<Float>;
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Matrix2` is never used
[INFO] [stdout]   --> src/math.rs:24:10
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub type Matrix2 = na::Matrix2<Float>;
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Translation2` is never used
[INFO] [stdout]   --> src/math.rs:28:10
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub type Translation2 = na::Translation2<Float>;
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Rotation2` is never used
[INFO] [stdout]   --> src/math.rs:31:10
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub type Rotation2 = na::Rotation2<Float>;
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Rotation3` is never used
[INFO] [stdout]   --> src/math.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub type Rotation3 = na::Rotation3<Float>;
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Quaternion` is never used
[INFO] [stdout]   --> src/math.rs:34:10
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub type Quaternion = na::Quaternion<Float>;
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `DualQuaternion` is never used
[INFO] [stdout]   --> src/math.rs:36:10
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub type DualQuaternion = na::DualQuaternion<Float>;
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Scale2` is never used
[INFO] [stdout]   --> src/math.rs:38:10
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub type Scale2 = na::Scale2<Float>;
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `project_vector_on_axis` is never used
[INFO] [stdout]   --> src/math.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub fn project_vector_on_axis(v: &Vector3, axis: &Vector3) -> Vector3 {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/physics/rigid_body.rs:72:12
[INFO] [stdout]     |
[INFO] [stdout]  20 | impl RigidBody {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  72 |     pub fn apply_force_point_local(&mut self, force: &Vector3, point: &Point3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  79 |     pub fn apply_force_point_world(&mut self, force: &Vector3, point: &Point3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     pub fn apply_impulse_point_local(&mut self, impulse: &Vector3, point: &Point3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     pub fn apply_force_local(&mut self, force: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 108 |     pub fn apply_torque_world(&mut self, force: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn apply_torque_local(&mut self, force: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     pub fn apply_impulse_local(&mut self, impulse: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 126 |     pub fn apply_angular_impulse_local(&mut self, impulse: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     pub fn get_inv_inertia_tensor_local(&self) -> Matrix3 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 144 |     pub fn get_center_of_mass_local(&self) -> Point3 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 162 |     pub fn set_angular_velocity(&mut self, v: &Vector3) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 178 |     pub fn set_inv_mass(&mut self, inv_mass: Float) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 184 |     pub fn set_elasticity(&mut self, elasticity: Float) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 188 |     pub fn get_damping(&self) -> Float {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 192 |     pub fn set_damping(&mut self, damping: Float) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 196 |     pub fn get_angular_damping(&self) -> Float {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 200 |     pub fn set_angular_damping(&mut self, damping: Float) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 208 |     pub fn set_friction(&mut self, friction: Float) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub fn world_to_local_vector(&self, v: &Vector3) -> Vector3 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 218 |     pub fn world_to_local_point(&self, p: &Point3) -> Point3 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 233 |     pub fn get_bounding_sphere(&self) -> BoundingSphere {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `build_bounding_sphere` is never used
[INFO] [stdout]   --> src/physics/shape.rs:47:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl ShapeType {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn build_bounding_sphere(&self, pos: &Isometry3) -> BoundingSphere {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `supporting_point_world` and `build_bounding_sphere` are never used
[INFO] [stdout]   --> src/physics/shape.rs:61:8
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub trait Shape {
[INFO] [stdout]    |           ----- methods in this trait
[INFO] [stdout] 60 |     fn supporting_point(&self, dir: &UnitVector3, bias: Float) -> Point3;
[INFO] [stdout] 61 |     fn supporting_point_world(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 76 |     fn build_bounding_sphere(&self, pos: &Isometry3) -> BoundingSphere;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `remove` and `get_mut` are never used
[INFO] [stdout]   --> src/physics/world.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl PhysicsWorld {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 86 |     pub fn remove(&mut self, id: RigidBodyId) -> Option<RigidBody> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 93 |     pub fn get_mut(&mut self, id: RigidBodyId) -> Option<&mut RigidBody> {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `BuildBoundingVolume` is never used
[INFO] [stdout]   --> src/physics/bvh.rs:31:11
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub trait BuildBoundingVolume<V: BoundingVolume> {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `intersect_sphere_sphere` is never used
[INFO] [stdout]  --> src/physics/intersect/intersect_sphere_sphere.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn intersect_sphere_sphere(s1: &Sphere, s2: &Sphere, pos_12: &Isometry3) -> bool {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PointLightId` is never constructed
[INFO] [stdout]  --> src/renderer/light.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct PointLightId {
[INFO] [stdout]   |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `insert_point_light`, `get_point_light`, and `get_point_light_mut` are never used
[INFO] [stdout]   --> src/renderer/light.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | impl Lights {
[INFO] [stdout]    | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn insert_point_light(&mut self, p: PointLight) -> PointLightId {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn get_point_light(&self, id: PointLightId) -> Option<&PointLight> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub fn get_point_light_mut(&mut self, id: PointLightId) -> Option<&mut PointLight> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/renderer/light.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 75 | impl PointLight {
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 76 |     pub fn new(color: [Float; 3], radius: Float, point: Point3) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `OPENGL_TO_WGPU_MATRIX`, `build_camera_matrix`, and `build_projection_matrix` are never used
[INFO] [stdout]   --> src/renderer/camera.rs:15:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl Camera {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 15 |     const OPENGL_TO_WGPU_MATRIX: Matrix4 = 
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 43 |     pub fn build_camera_matrix(&self) -> Matrix4{
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn build_projection_matrix(&self) -> Matrix4 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `create_material`, `create_mesh`, `get_default_texture`, and `create_model` are never used
[INFO] [stdout]   --> src/renderer/resource.rs:40:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl ResourceManager{
[INFO] [stdout]    | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub fn create_material(&self, desc: &MaterialDescriptor) -> Material{
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn create_mesh<T: Vertex>(&self, desc: &MeshDescriptor<T>) -> Mesh{
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     pub fn get_default_texture(&self) -> Arc<Texture> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn create_model<'a, 'b, 'c, T: Vertex>(&mut self, desc: &ModelDescriptor<T>) -> Arc<Model>{
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/renderer/resource.rs:218:8
[INFO] [stdout]     |
[INFO] [stdout] 218 | struct StaticVertexData{
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]    --> src/renderer/resource.rs:216:1
[INFO] [stdout]     |
[INFO] [stdout] 216 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/renderer/resource.rs:225:8
[INFO] [stdout]     |
[INFO] [stdout] 225 | struct SkeletalVertexData{
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]    --> src/renderer/resource.rs:223:1
[INFO] [stdout]     |
[INFO] [stdout] 223 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]   --> src/renderer/scene.rs:37:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl Scene {
[INFO] [stdout]    | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn remove_entity(&mut self, index: EntityId) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn iter_mut_entities(&mut self) -> ga::IterMut<Entity> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn get_entity(&self, index: EntityId) -> Option<&Entity> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 |     pub fn set_directional_light(&mut self, directional_light: DirectionalLight) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 80 |     pub fn insert_point_light(&mut self, p: PointLight) -> PointLightId {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88 |     pub fn get_point_light(&self, id: PointLightId) -> Option<&PointLight> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 91 |     pub fn get_point_light_mut(&mut self, id: PointLightId) -> Option<&mut PointLight> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ModelDescriptor` is never constructed
[INFO] [stdout]   --> src/renderer/model.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct ModelDescriptor<'a, 'b, 'c, 'd, 'e, 'f, 'g, 'h, 'i, T> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/renderer/model.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl Model {
[INFO] [stdout]    | ---------- associated function in this implementation
[INFO] [stdout] 24 |     pub fn new<T: Vertex>(device: &wgpu::Device, desc: &ModelDescriptor<T>) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `draw_mesh` is never used
[INFO] [stdout]   --> src/renderer/model.rs:45:8
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub trait DrawModel<'a> {
[INFO] [stdout]    |           --------- method in this trait
[INFO] [stdout] 45 |     fn draw_mesh(&mut self, mesh: &'a Mesh, material: &'a Material);
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/renderer/model/material.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct MaterialUniform {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]   --> src/renderer/model/material.rs:14:1
[INFO] [stdout]    |
[INFO] [stdout] 14 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `name`, `buffer`, and `texture` are never read
[INFO] [stdout]   --> src/renderer/model/material.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct Material {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 26 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 27 |     pub buffer: wgpu::Buffer,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 28 |     pub texture: Arc<Texture>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Material` 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 `MeshDescriptor` is never constructed
[INFO] [stdout]  --> src/renderer/model/mesh.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct MeshDescriptor<'a, 'b, 'c, T> {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `name` is never read
[INFO] [stdout]   --> src/renderer/model/mesh.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct Mesh {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout] 12 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Mesh` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `new` and `new_with_index_u16` are never used
[INFO] [stdout]   --> src/renderer/model/mesh.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl Mesh {
[INFO] [stdout]    | --------- associated functions in this implementation
[INFO] [stdout] 21 |     pub fn new<'a, 'b, 'c, T: Vertex>(
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn new_with_index_u16<T: Vertex>(
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]  --> src/renderer/model/vertex.rs:6:1
[INFO] [stdout]   |
[INFO] [stdout] 6 | #[repr(C)]
[INFO] [stdout]   | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/renderer/model/vertex.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct ModelVertex {
[INFO] [stdout]    |            ^^^^^^^^^^^ field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `name` is never read
[INFO] [stdout]  --> src/renderer/entity.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Entity {
[INFO] [stdout]   |            ------ field in this struct
[INFO] [stdout] 7 |     pub name: String,
[INFO] [stdout]   |         ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Entity` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `texture` is never read
[INFO] [stdout]  --> src/renderer/texture.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Texture {
[INFO] [stdout]   |            ------- field in this struct
[INFO] [stdout] 7 |     pub texture: wgpu::Texture,
[INFO] [stdout]   |         ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Texture` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `max_point_lights` is never read
[INFO] [stdout]   --> src/renderer/render_pass.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct RenderPass {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 21 |     max_point_lights: u32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RenderPass` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/renderer/render_pass/camera_uniform_buffer.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub struct CameraUniforms {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]  --> src/renderer/render_pass/camera_uniform_buffer.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | #[repr(C)]
[INFO] [stdout]   | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CascadeShadowPass` is never constructed
[INFO] [stdout]  --> src/renderer/render_pass/shadow/cascaded_shadow.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct CascadeShadowPass {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CascadedShadow` is never constructed
[INFO] [stdout]   --> src/renderer/render_pass/shadow/cascaded_shadow.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct CascadedShadow {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `OVERLAP` and `new` are never used
[INFO] [stdout]   --> src/renderer/render_pass/shadow/cascaded_shadow.rs:21:11
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl CascadedShadow {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 21 |     const OVERLAP: Float = 0.1;
[INFO] [stdout]    |           ^^^^^^^
[INFO] [stdout] 22 |     pub fn new(camera: &Camera, light_direction: &Vector3, resolution: Float) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_cascade_size` is never used
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:114:4
[INFO] [stdout]     |
[INFO] [stdout] 114 | fn calculate_cascade_size(camera: &Camera, zmin: Float, zmax: Float) -> Float {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_min_max` is never used
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:122:4
[INFO] [stdout]     |
[INFO] [stdout] 122 | fn calculate_min_max(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_cascade_position` is never used
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:161:8
[INFO] [stdout]     |
[INFO] [stdout] 161 | pub fn calculate_cascade_position(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]  --> src/renderer/render_pass/light_uniform_buffer.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | #[repr(C)]
[INFO] [stdout]   | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/renderer/render_pass/light_uniform_buffer.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct AmbientLightUniforms {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]   --> src/renderer/render_pass/light_uniform_buffer.rs:20:1
[INFO] [stdout]    |
[INFO] [stdout] 20 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/renderer/render_pass/light_uniform_buffer.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct DirectionalLightUniforms {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]   --> src/renderer/render_pass/light_uniform_buffer.rs:39:1
[INFO] [stdout]    |
[INFO] [stdout] 39 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/renderer/render_pass/light_uniform_buffer.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct PointLightUniforms {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `max_point_lights` is never read
[INFO] [stdout]   --> src/renderer/render_pass/light_uniform_buffer.rs:70:9
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub struct LightUniformBuffer {
[INFO] [stdout]    |            ------------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 70 |     pub max_point_lights: u32,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `LightUniformBuffer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `instance` and `adapter` are never read
[INFO] [stdout]   --> src/renderer/device.rs:50:9
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub struct Device {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] 50 |     pub instance: wgpu::Instance,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 51 |     pub adapter: wgpu::Adapter,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Device` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/renderer/instance.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct InstanceRaw {
[INFO] [stdout]   |            ^^^^^^^^^^^ field in this struct
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]  --> src/renderer/instance.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | #[repr(C)]
[INFO] [stdout]   | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InstanceBuffers` is never constructed
[INFO] [stdout]    --> src/renderer/instance.rs:122:8
[INFO] [stdout]     |
[INFO] [stdout] 122 | struct InstanceBuffers {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/renderer/instance.rs:130:12
[INFO] [stdout]     |
[INFO] [stdout] 129 | impl InstanceBuffers {
[INFO] [stdout]     | -------------------- associated function in this implementation
[INFO] [stdout] 130 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer/scene.rs:41:26
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn iter_entities(&self) -> ga::Iter<Entity> {
[INFO] [stdout]    |                          ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                          |
[INFO] [stdout]    |                          the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn iter_entities(&self) -> ga::Iter<'_, Entity> {
[INFO] [stdout]    |                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer/scene.rs:45:30
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub fn iter_mut_entities(&mut self) -> ga::IterMut<Entity> {
[INFO] [stdout]    |                              ^^^^^^^^^     ^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub fn iter_mut_entities(&mut self) -> ga::IterMut<'_, Entity> {
[INFO] [stdout]    |                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer/scene.rs:84:30
[INFO] [stdout]    |
[INFO] [stdout] 84 |     pub fn iter_point_lights(&self) -> ga::Iter<PointLight> {
[INFO] [stdout]    |                              ^^^^^     ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 84 |     pub fn iter_point_lights(&self) -> ga::Iter<'_, PointLight> {
[INFO] [stdout]    |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer/instance.rs:88:19
[INFO] [stdout]    |
[INFO] [stdout] 88 |     pub fn insert(&self, data: &InstanceRaw, queue: &wgpu::Queue) -> Option<wgpu::BufferSlice> {
[INFO] [stdout]    |                   ^^^^^ the lifetime is elided here                         ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 88 |     pub fn insert(&self, data: &InstanceRaw, queue: &wgpu::Queue) -> Option<wgpu::BufferSlice<'_>> {
[INFO] [stdout]    |                                                                                              ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer/instance.rs:93:9
[INFO] [stdout]    |
[INFO] [stdout] 93 |         &self,
[INFO] [stdout]    |         ^^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 96 |     ) -> Option<wgpu::BufferSlice> {
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 96 |     ) -> Option<wgpu::BufferSlice<'_>> {
[INFO] [stdout]    |                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 08s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: fs_extra v1.2.0
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 3`
[INFO] running `Command { std: "docker" "inspect" "e3acf654a32edf4ea543c9ffe4266c616538e695d1ce17e47962217b6bf3f9b6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e3acf654a32edf4ea543c9ffe4266c616538e695d1ce17e47962217b6bf3f9b6", kill_on_drop: false }`
[INFO] [stdout] e3acf654a32edf4ea543c9ffe4266c616538e695d1ce17e47962217b6bf3f9b6
