[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] testing toyoyou11/yt-game against 1.90.0 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftoyoyou11%2Fyt-game" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-2-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-2-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/toyoyou11/yt-game on toolchain 1.90.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.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.90.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded memmap2 v0.5.7
[INFO] [stderr]   Downloaded pollster v0.2.5
[INFO] [stderr]   Downloaded url v2.3.0
[INFO] [stderr]   Downloaded generational-arena v0.2.8
[INFO] [stderr]   Downloaded crossfont v0.5.0
[INFO] [stderr]   Downloaded sctk-adwaita v0.4.2
[INFO] [stderr]   Downloaded bytemuck v1.12.1
[INFO] [stderr]   Downloaded calloop v0.10.1
[INFO] [stderr]   Downloaded x11-dl v2.20.0
[INFO] [stderr]   Downloaded once_cell v1.13.1
[INFO] [stderr]   Downloaded futures-task v0.3.24
[INFO] [stderr]   Downloaded libc v0.2.132
[INFO] [stderr]   Downloaded tokio-util v0.7.3
[INFO] [stderr]   Downloaded bytes v1.2.1
[INFO] [stderr]   Downloaded paste v1.0.9
[INFO] [stderr]   Downloaded wide v0.7.4
[INFO] [stderr]   Downloaded openssl-sys v0.9.75
[INFO] [stderr]   Downloaded anyhow v1.0.64
[INFO] [stderr]   Downloaded openssl v0.10.41
[INFO] [stderr]   Downloaded futures-channel v0.3.24
[INFO] [stderr]   Downloaded tracing v0.1.36
[INFO] [stderr]   Downloaded num-complex v0.4.2
[INFO] [stderr]   Downloaded unicode-normalization v0.1.21
[INFO] [stderr]   Downloaded png v0.17.6
[INFO] [stderr]   Downloaded simba v0.7.2
[INFO] [stderr]   Downloaded profiling v1.0.6
[INFO] [stderr]   Downloaded cmake v0.1.48
[INFO] [stderr]   Downloaded wgpu v0.14.0
[INFO] [stderr]   Downloaded tiff v0.6.1
[INFO] [stderr]   Downloaded serde_json v1.0.85
[INFO] [stderr]   Downloaded hyper v0.14.20
[INFO] [stderr]   Downloaded mio v0.8.4
[INFO] [stderr]   Downloaded serde v1.0.144
[INFO] [stderr]   Downloaded indexmap v1.9.1
[INFO] [stderr]   Downloaded reqwest v0.11.11
[INFO] [stderr]   Downloaded wgpu-hal v0.14.0
[INFO] [stderr]   Downloaded nalgebra v0.31.1
[INFO] [stderr]   Downloaded tracing-core v0.1.29
[INFO] [stderr]   Downloaded security-framework v2.7.0
[INFO] [stderr]   Downloaded gif v0.11.4
[INFO] [stderr]   Downloaded tokio v1.21.0
[INFO] [stderr]   Downloaded futures-util v0.3.24
[INFO] [stderr]   Downloaded tobj v3.2.3
[INFO] [stderr]   Downloaded wgpu-core v0.14.0
[INFO] [stderr]   Downloaded serde_derive v1.0.144
[INFO] [stderr]   Downloaded android_system_properties v0.1.4
[INFO] [stderr]   Downloaded ndk-sys v0.4.0
[INFO] [stderr]   Downloaded bumpalo v3.11.0
[INFO] [stderr]   Downloaded miniz_oxide v0.5.4
[INFO] [stderr]   Downloaded jpeg-decoder v0.1.22
[INFO] [stderr]   Downloaded futures-core v0.3.24
[INFO] [stderr]   Downloaded futures-sink v0.3.24
[INFO] [stderr]   Downloaded ash v0.37.0+1.3.209
[INFO] [stderr]   Downloaded wgpu-types v0.14.0
[INFO] [stderr]   Downloaded bytemuck_derive v1.2.1
[INFO] [stderr]   Downloaded h2 v0.3.14
[INFO] [stderr]   Downloaded winit v0.27.3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] eff61e61bd2f4eebea3017cd79e10c0694873cc7d806a06fd5ea8da9adc823f0
[INFO] running `Command { std: "docker" "start" "-a" "eff61e61bd2f4eebea3017cd79e10c0694873cc7d806a06fd5ea8da9adc823f0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "eff61e61bd2f4eebea3017cd79e10c0694873cc7d806a06fd5ea8da9adc823f0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "eff61e61bd2f4eebea3017cd79e10c0694873cc7d806a06fd5ea8da9adc823f0", kill_on_drop: false }`
[INFO] [stdout] eff61e61bd2f4eebea3017cd79e10c0694873cc7d806a06fd5ea8da9adc823f0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d2cd62846edbf4c3ad2614cccbd6112975dbb9f5793188203fa18a24d616c92b
[INFO] running `Command { std: "docker" "start" "-a" "d2cd62846edbf4c3ad2614cccbd6112975dbb9f5793188203fa18a24d616c92b", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.43
[INFO] [stderr]    Compiling unicode-ident v1.0.3
[INFO] [stderr]    Compiling quote v1.0.21
[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]    Compiling once_cell v1.13.1
[INFO] [stderr]    Compiling cmake v0.1.48
[INFO] [stderr]    Compiling log v0.4.17
[INFO] [stderr]    Compiling smallvec v1.9.0
[INFO] [stderr]    Compiling memchr v2.5.0
[INFO] [stderr]    Compiling xml-rs v0.8.4
[INFO] [stderr]    Compiling ahash v0.7.6
[INFO] [stderr]    Compiling wayland-sys v0.29.4
[INFO] [stderr]    Compiling crc32fast v1.3.2
[INFO] [stderr]    Compiling freetype-sys v0.13.1
[INFO] [stderr]    Compiling expat-sys v2.1.6
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]    Compiling lock_api v0.4.7
[INFO] [stderr]    Compiling getrandom v0.2.7
[INFO] [stderr]    Compiling nix v0.22.3
[INFO] [stderr]    Compiling byteorder v1.4.3
[INFO] [stderr]    Compiling wayland-scanner v0.29.4
[INFO] [stderr]    Compiling parking_lot_core v0.9.3
[INFO] [stderr]    Compiling servo-fontconfig-sys v5.1.0
[INFO] [stderr]    Compiling slotmap v1.0.6
[INFO] [stderr]    Compiling hashbrown v0.12.3
[INFO] [stderr]    Compiling indexmap v1.9.1
[INFO] [stderr]    Compiling termcolor v1.1.3
[INFO] [stderr]    Compiling nom v7.1.1
[INFO] [stderr]    Compiling miniz_oxide v0.5.4
[INFO] [stderr]    Compiling khronos-egl v4.1.0
[INFO] [stderr]    Compiling ash v0.37.0+1.3.209
[INFO] [stderr]    Compiling unicode-width v0.1.9
[INFO] [stderr]    Compiling parking_lot v0.12.1
[INFO] [stderr]    Compiling codespan-reporting v0.11.1
[INFO] [stderr]    Compiling flate2 v1.0.24
[INFO] [stderr]    Compiling wayland-client v0.29.4
[INFO] [stderr]    Compiling wayland-protocols v0.29.4
[INFO] [stderr]    Compiling raw-window-handle v0.5.0
[INFO] [stderr]    Compiling spirv v0.2.0+1.5.4
[INFO] [stderr]    Compiling nix v0.24.2
[INFO] [stderr]    Compiling crossfont v0.5.0
[INFO] [stderr]    Compiling smithay-client-toolkit v0.16.0
[INFO] [stderr]    Compiling gpu-descriptor-types v0.1.1
[INFO] [stderr]    Compiling gpu-alloc-types v0.2.0
[INFO] [stderr]    Compiling miniz_oxide v0.4.4
[INFO] [stderr]    Compiling serde_derive v1.0.144
[INFO] [stderr]    Compiling xcursor v0.3.4
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling anyhow v1.0.64
[INFO] [stderr]    Compiling hexf-parse v0.2.1
[INFO] [stderr]    Compiling unicode-xid v0.2.3
[INFO] [stderr]    Compiling cfg_aliases v0.1.1
[INFO] [stderr]    Compiling vec_map v0.8.2
[INFO] [stderr]    Compiling adler32 v1.2.0
[INFO] [stderr]    Compiling foreign-types-shared v0.3.1
[INFO] [stderr]    Compiling arrayref v0.3.6
[INFO] [stderr]    Compiling wgpu-core v0.14.0
[INFO] [stderr]    Compiling gpu-alloc v0.5.3
[INFO] [stderr]    Compiling gpu-descriptor v0.2.3
[INFO] [stderr]    Compiling png v0.17.6
[INFO] [stderr]    Compiling servo-fontconfig v0.5.1
[INFO] [stderr]    Compiling freetype-rs v0.26.0
[INFO] [stderr]    Compiling wayland-commons v0.29.4
[INFO] [stderr]    Compiling fxhash v0.2.1
[INFO] [stderr]    Compiling memmap2 v0.5.7
[INFO] [stderr]    Compiling x11-dl v2.20.0
[INFO] [stderr]    Compiling wgpu-types v0.14.0
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]    Compiling num-iter v0.1.43
[INFO] [stderr]    Compiling num-rational v0.3.2
[INFO] [stderr]    Compiling arrayvec v0.5.2
[INFO] [stderr]    Compiling glow v0.11.2
[INFO] [stderr]    Compiling arrayvec v0.7.2
[INFO] [stderr]    Compiling profiling v1.0.6
[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 serde v1.0.144
[INFO] [stderr]    Compiling wayland-cursor v0.29.4
[INFO] [stderr]    Compiling foreign-types v0.5.0
[INFO] [stderr]    Compiling typenum v1.15.0
[INFO] [stderr]    Compiling bytemuck v1.12.1
[INFO] [stderr]    Compiling weezl v0.1.7
[INFO] [stderr]    Compiling safe_arch v0.5.2
[INFO] [stderr]    Compiling safe_arch v0.6.0
[INFO] [stderr]    Compiling thiserror v1.0.32
[INFO] [stderr]    Compiling tiny-skia-path v0.7.0
[INFO] [stderr]    Compiling naga v0.10.0
[INFO] [stderr]    Compiling calloop v0.10.1
[INFO] [stderr]    Compiling renderdoc-sys v0.7.1
[INFO] [stderr]    Compiling wide v0.7.4
[INFO] [stderr]    Compiling tiny-skia v0.7.0
[INFO] [stderr]    Compiling miniz_oxide v0.3.7
[INFO] [stderr]    Compiling deflate v0.8.6
[INFO] [stderr]    Compiling num-complex v0.4.2
[INFO] [stderr]    Compiling approx v0.5.1
[INFO] [stderr]    Compiling aho-corasick v0.7.18
[INFO] [stderr]    Compiling paste v1.0.9
[INFO] [stderr]    Compiling glob v0.3.0
[INFO] [stderr]    Compiling rawpointer v0.2.1
[INFO] [stderr]    Compiling serde_json v1.0.85
[INFO] [stderr]    Compiling jpeg-decoder v0.1.22
[INFO] [stderr]    Compiling color_quant v1.1.0
[INFO] [stderr]    Compiling regex-syntax v0.6.27
[INFO] [stderr]    Compiling fs_extra v1.2.0
[INFO] [stderr]    Compiling yt-game v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling tiff v0.6.1
[INFO] [stderr]    Compiling gif v0.11.4
[INFO] [stderr]    Compiling simba v0.7.2
[INFO] [stderr]    Compiling regex v1.6.0
[INFO] [stderr]    Compiling matrixmultiply v0.3.2
[INFO] [stderr]    Compiling wgpu-hal v0.14.0
[INFO] [stderr]    Compiling png v0.16.8
[INFO] [stderr]    Compiling nalgebra-macros v0.1.0
[INFO] [stderr]    Compiling raw-window-handle v0.4.3
[INFO] [stderr]    Compiling mio v0.8.4
[INFO] [stderr]    Compiling atty v0.2.14
[INFO] [stderr]    Compiling instant v0.1.12
[INFO] [stderr]    Compiling itoa v1.0.3
[INFO] [stderr]    Compiling ryu v1.0.11
[INFO] [stderr]    Compiling scoped_threadpool v0.1.9
[INFO] [stderr]    Compiling humantime v2.1.0
[INFO] [stderr]    Compiling env_logger v0.9.0
[INFO] [stderr]    Compiling image v0.23.14
[INFO] [stderr]    Compiling generational-arena v0.2.8
[INFO] [stderr]    Compiling tobj v3.2.3
[INFO] [stderr]    Compiling pollster v0.2.5
[INFO] [stderr]    Compiling nalgebra v0.31.1
[INFO] [stderr]    Compiling wgpu v0.14.0
[INFO] [stderr]    Compiling sctk-adwaita v0.4.2
[INFO] [stderr]    Compiling 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)]` 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)]` 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)]` 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)]` 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: variable `zmax` is assigned to, but never used
[INFO] [stdout]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:187:13
[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)]` 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)]` 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] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 4m 06s
[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 2`
[INFO] running `Command { std: "docker" "inspect" "d2cd62846edbf4c3ad2614cccbd6112975dbb9f5793188203fa18a24d616c92b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d2cd62846edbf4c3ad2614cccbd6112975dbb9f5793188203fa18a24d616c92b", kill_on_drop: false }`
[INFO] [stdout] d2cd62846edbf4c3ad2614cccbd6112975dbb9f5793188203fa18a24d616c92b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 8550b59f807223b7f25e8a4ccccc7d07fe616b5b09cea4e9a7d7a76fe23ffbaf
[INFO] running `Command { std: "docker" "start" "-a" "8550b59f807223b7f25e8a4ccccc7d07fe616b5b09cea4e9a7d7a76fe23ffbaf", kill_on_drop: false }`
[INFO] [stderr]    Compiling yt-game v0.1.0 (/opt/rustwide/workdir)
[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)]` 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)]` 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)]` on by default
[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)]` 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)]` 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)]` 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: 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)]` 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)]` 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:13
[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)]` 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)]` 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:13
[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)]` 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)]` 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 `test` profile [unoptimized + debuginfo] target(s) in 6.78s
[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 2`
[INFO] running `Command { std: "docker" "inspect" "8550b59f807223b7f25e8a4ccccc7d07fe616b5b09cea4e9a7d7a76fe23ffbaf", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8550b59f807223b7f25e8a4ccccc7d07fe616b5b09cea4e9a7d7a76fe23ffbaf", kill_on_drop: false }`
[INFO] [stdout] 8550b59f807223b7f25e8a4ccccc7d07fe616b5b09cea4e9a7d7a76fe23ffbaf
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] b3650079e600fc83942e91a697920157f2cee87d0c3454bf0137da31576dc518
[INFO] running `Command { std: "docker" "start" "-a" "b3650079e600fc83942e91a697920157f2cee87d0c3454bf0137da31576dc518", kill_on_drop: false }`
[INFO] [stderr]    Compiling yt-game v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] warning: unused import: `WindowBuilder`
[INFO] [stderr]  --> src/game.rs:7:22
[INFO] [stderr]   |
[INFO] [stderr] 7 |     window::{Window, WindowBuilder},
[INFO] [stderr]   |                      ^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `self::intersect_sphere_sphere::*`
[INFO] [stderr]  --> src/physics/intersect.rs:3:9
[INFO] [stderr]   |
[INFO] [stderr] 3 | pub use self::intersect_sphere_sphere::*;
[INFO] [stderr]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `BufReader` and `Cursor`
[INFO] [stderr]  --> src/renderer/resource.rs:1:15
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::io::{BufReader, Cursor};
[INFO] [stderr]   |               ^^^^^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `wgpu::util::DeviceExt`
[INFO] [stderr]  --> src/renderer/resource.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use wgpu::util::DeviceExt;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::device::Device`
[INFO] [stderr]  --> src/renderer/texture.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use super::device::Device;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `device::*` and `instance::*`
[INFO] [stderr]   --> src/renderer.rs:22:33
[INFO] [stderr]    |
[INFO] [stderr] 22 |     texture::*, render_pass::*, device::*, instance::*
[INFO] [stderr]    |                                 ^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]   --> src/physics/shape.rs:38:13
[INFO] [stderr]    |
[INFO] [stderr] 38 |             _ => {
[INFO] [stderr]    |             ^ no value can reach this
[INFO] [stderr]    |
[INFO] [stderr] note: multiple earlier patterns match some of the same values
[INFO] [stderr]   --> src/physics/shape.rs:38:13
[INFO] [stderr]    |
[INFO] [stderr] 28 |             (Self::Sphere(s1), Self::Sphere(s2)) => contact_sphere_sphere(s1, s2, pos12),
[INFO] [stderr]    |             ------------------------------------ matches some of the same values
[INFO] [stderr] 29 |             (Self::Sphere(s), Self::Cube(c)) => {
[INFO] [stderr]    |             -------------------------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 33 |             (Self::Cube(c), Self::Sphere(s)) => {
[INFO] [stderr]    |             -------------------------------- matches some of the same values
[INFO] [stderr] ...
[INFO] [stderr] 37 |             (Self::Cube(c1), Self::Cube(c2)) => contact_cube_cube(c1, c2, pos12),
[INFO] [stderr]    |             -------------------------------- matches some of the same values
[INFO] [stderr] 38 |             _ => {
[INFO] [stderr]    |             ^ collectively making this unreachable
[INFO] [stderr]    = note: `#[warn(unreachable_patterns)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `leaf2_id`
[INFO] [stderr]    --> src/physics/bvh.rs:475:13
[INFO] [stderr]     |
[INFO] [stderr] 475 |         let leaf2_id = bvh.insert(
[INFO] [stderr]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_leaf2_id`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `leaf1_id`
[INFO] [stderr]    --> src/physics/bvh.rs:516:13
[INFO] [stderr]     |
[INFO] [stderr] 516 |         let leaf1_id = bvh.insert(
[INFO] [stderr]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_leaf1_id`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/renderer/camera.rs:66:13
[INFO] [stderr]    |
[INFO] [stderr] 66 |         let mut z = self.near;
[INFO] [stderr]    |             ----^
[INFO] [stderr]    |             |
[INFO] [stderr]    |             help: remove this `mut`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `x`
[INFO] [stderr]   --> src/renderer/resource.rs:30:95
[INFO] [stderr]    |
[INFO] [stderr] 30 |         image::RgbaImage::from_fn(Self::DEFAULT_TEXUTER_WIDTH, Self::DEFAULT_TEXUTER_HEIGHT, |x, y| {
[INFO] [stderr]    |                                                                                               ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `y`
[INFO] [stderr]   --> src/renderer/resource.rs:30:98
[INFO] [stderr]    |
[INFO] [stderr] 30 |         image::RgbaImage::from_fn(Self::DEFAULT_TEXUTER_WIDTH, Self::DEFAULT_TEXUTER_HEIGHT, |x, y| {
[INFO] [stderr]    |                                                                                                  ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `zmax` is assigned to, but never used
[INFO] [stderr]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:187:13
[INFO] [stderr]     |
[INFO] [stderr] 187 |     let mut zmax = FLOAT_MIN;
[INFO] [stderr]     |             ^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: consider using `_zmax` instead
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `zmax` is never read
[INFO] [stderr]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:203:9
[INFO] [stderr]     |
[INFO] [stderr] 203 |         zmax = xmax.max(transformed.z);
[INFO] [stderr]     |         ^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr]     = note: `#[warn(unused_assignments)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Pose` is never constructed
[INFO] [stderr]   --> src/game.rs:37:5
[INFO] [stderr]    |
[INFO] [stderr] 35 | enum State{
[INFO] [stderr]    |      ----- variant in this enum
[INFO] [stderr] 36 |     Active,
[INFO] [stderr] 37 |     Pose,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `State` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: struct `World` is never constructed
[INFO] [stderr]  --> src/game/world.rs:2:8
[INFO] [stderr]   |
[INFO] [stderr] 2 | struct World {
[INFO] [stderr]   |        ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `InputManager` is never constructed
[INFO] [stderr]   --> src/input.rs:14:12
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub struct InputManager {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]   --> src/input.rs:21:12
[INFO] [stderr]    |
[INFO] [stderr] 19 | impl InputManager {
[INFO] [stderr]    | ----------------- associated items in this implementation
[INFO] [stderr] 20 |     /// Create input manager
[INFO] [stderr] 21 |     pub fn new() -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 28 |     pub fn begin_frame(&mut self) {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 33 |     pub fn process_input(&mut self, input: &winit::event::DeviceEvent) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 38 |     pub fn key_is_up(&self, key: Keycode) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 41 |     pub fn key_is_down(&self, key: Keycode) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 44 |     pub fn key_is_pressed(&self, key: Keycode) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 47 |     pub fn key_is_released(&self, key: Keycode) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 51 |     pub fn button_is_up(&self, button: u16) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 54 |     pub fn button_is_down(&self, button: u16) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 57 |     pub fn button_is_pressed(&self, button: u16) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 60 |     pub fn button_is_released(&self, button: u16) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 64 |     pub fn get_scroll(&self) -> (f32, f32) {
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 68 |     pub fn get_mouse_move(&self) -> (f32, f32) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `process_input`, `is_down`, and `is_up` are never used
[INFO] [stderr]   --> src/input/keyboard_input.rs:30:12
[INFO] [stderr]    |
[INFO] [stderr] 13 | impl KeyboardInputManager {
[INFO] [stderr]    | ------------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 30 |     pub fn process_input(&mut self, input: &winit::event::DeviceEvent) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 38 |     pub fn is_down(&self, keycode: Keycode) -> bool {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 46 |     pub fn is_up(&self, keycode: Keycode) -> bool {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `get_scroll`, `get_move`, `is_down`, and `is_up` are never used
[INFO] [stderr]   --> src/input/mouse_input.rs:24:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | impl MouseInputManager {
[INFO] [stderr]    | ---------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 24 |     pub fn get_scroll(&self) -> (Float, Float) {
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 27 |     pub fn get_move(&self) -> (Float, Float) {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 37 |     pub fn is_down(&self, id: usize) -> bool {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 44 |     pub fn is_up(&self, id: usize) -> bool {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `E` is never used
[INFO] [stderr]  --> src/math.rs:5:11
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub const E: Float = std::f32::consts::E;
[INFO] [stderr]   |           ^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `FLOAT_MIN` is never used
[INFO] [stderr]  --> src/math.rs:7:11
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub const FLOAT_MIN: Float = f32::MIN;
[INFO] [stderr]   |           ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `FLOAT_MIN_POSITIVE` is never used
[INFO] [stderr]  --> src/math.rs:8:11
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub const FLOAT_MIN_POSITIVE: Float = f32::MIN_POSITIVE;
[INFO] [stderr]   |           ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Point2` is never used
[INFO] [stderr]   --> src/math.rs:10:10
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub type Point2 = na::Point2<Float>;
[INFO] [stderr]    |          ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Isometry2` is never used
[INFO] [stderr]   --> src/math.rs:13:10
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub type Isometry2 = na::Isometry2<Float>;
[INFO] [stderr]    |          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Vector2` is never used
[INFO] [stderr]   --> src/math.rs:16:10
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub type Vector2 = na::Vector2<Float>;
[INFO] [stderr]    |          ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Vector4` is never used
[INFO] [stderr]   --> src/math.rs:18:10
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub type Vector4 = na::Vector4<Float>;
[INFO] [stderr]    |          ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `UnitVector2` is never used
[INFO] [stderr]   --> src/math.rs:20:10
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub type UnitVector2 = na::UnitVector2<Float>;
[INFO] [stderr]    |          ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `UnitVector4` is never used
[INFO] [stderr]   --> src/math.rs:22:10
[INFO] [stderr]    |
[INFO] [stderr] 22 | pub type UnitVector4 = na::UnitVector4<Float>;
[INFO] [stderr]    |          ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Matrix2` is never used
[INFO] [stderr]   --> src/math.rs:24:10
[INFO] [stderr]    |
[INFO] [stderr] 24 | pub type Matrix2 = na::Matrix2<Float>;
[INFO] [stderr]    |          ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Translation2` is never used
[INFO] [stderr]   --> src/math.rs:28:10
[INFO] [stderr]    |
[INFO] [stderr] 28 | pub type Translation2 = na::Translation2<Float>;
[INFO] [stderr]    |          ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Rotation2` is never used
[INFO] [stderr]   --> src/math.rs:31:10
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub type Rotation2 = na::Rotation2<Float>;
[INFO] [stderr]    |          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Rotation3` is never used
[INFO] [stderr]   --> src/math.rs:32:10
[INFO] [stderr]    |
[INFO] [stderr] 32 | pub type Rotation3 = na::Rotation3<Float>;
[INFO] [stderr]    |          ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Quaternion` is never used
[INFO] [stderr]   --> src/math.rs:34:10
[INFO] [stderr]    |
[INFO] [stderr] 34 | pub type Quaternion = na::Quaternion<Float>;
[INFO] [stderr]    |          ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `DualQuaternion` is never used
[INFO] [stderr]   --> src/math.rs:36:10
[INFO] [stderr]    |
[INFO] [stderr] 36 | pub type DualQuaternion = na::DualQuaternion<Float>;
[INFO] [stderr]    |          ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Scale2` is never used
[INFO] [stderr]   --> src/math.rs:38:10
[INFO] [stderr]    |
[INFO] [stderr] 38 | pub type Scale2 = na::Scale2<Float>;
[INFO] [stderr]    |          ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `project_vector_on_axis` is never used
[INFO] [stderr]   --> src/math.rs:41:8
[INFO] [stderr]    |
[INFO] [stderr] 41 | pub fn project_vector_on_axis(v: &Vector3, axis: &Vector3) -> Vector3 {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/physics/rigid_body.rs:72:12
[INFO] [stderr]     |
[INFO] [stderr]  20 | impl RigidBody {
[INFO] [stderr]     | -------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  72 |     pub fn apply_force_point_local(&mut self, force: &Vector3, point: &Point3) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  79 |     pub fn apply_force_point_world(&mut self, force: &Vector3, point: &Point3) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  85 |     pub fn apply_impulse_point_local(&mut self, impulse: &Vector3, point: &Point3) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 103 |     pub fn apply_force_local(&mut self, force: &Vector3) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 108 |     pub fn apply_torque_world(&mut self, force: &Vector3) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 111 |     pub fn apply_torque_local(&mut self, force: &Vector3) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 119 |     pub fn apply_impulse_local(&mut self, impulse: &Vector3) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 126 |     pub fn apply_angular_impulse_local(&mut self, impulse: &Vector3) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 136 |     pub fn get_inv_inertia_tensor_local(&self) -> Matrix3 {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 144 |     pub fn get_center_of_mass_local(&self) -> Point3 {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 162 |     pub fn set_angular_velocity(&mut self, v: &Vector3) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 178 |     pub fn set_inv_mass(&mut self, inv_mass: Float) {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 184 |     pub fn set_elasticity(&mut self, elasticity: Float) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 188 |     pub fn get_damping(&self) -> Float {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 192 |     pub fn set_damping(&mut self, damping: Float) {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 196 |     pub fn get_angular_damping(&self) -> Float {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 200 |     pub fn set_angular_damping(&mut self, damping: Float) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 208 |     pub fn set_friction(&mut self, friction: Float) {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 212 |     pub fn world_to_local_vector(&self, v: &Vector3) -> Vector3 {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 218 |     pub fn world_to_local_point(&self, p: &Point3) -> Point3 {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 233 |     pub fn get_bounding_sphere(&self) -> BoundingSphere {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `build_bounding_sphere` is never used
[INFO] [stderr]   --> src/physics/shape.rs:47:12
[INFO] [stderr]    |
[INFO] [stderr] 14 | impl ShapeType {
[INFO] [stderr]    | -------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 47 |     pub fn build_bounding_sphere(&self, pos: &Isometry3) -> BoundingSphere {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `supporting_point_world` and `build_bounding_sphere` are never used
[INFO] [stderr]   --> src/physics/shape.rs:61:8
[INFO] [stderr]    |
[INFO] [stderr] 59 | pub trait Shape {
[INFO] [stderr]    |           ----- methods in this trait
[INFO] [stderr] 60 |     fn supporting_point(&self, dir: &UnitVector3, bias: Float) -> Point3;
[INFO] [stderr] 61 |     fn supporting_point_world(
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 76 |     fn build_bounding_sphere(&self, pos: &Isometry3) -> BoundingSphere;
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `remove` and `get_mut` are never used
[INFO] [stderr]   --> src/physics/world.rs:86:12
[INFO] [stderr]    |
[INFO] [stderr] 23 | impl PhysicsWorld {
[INFO] [stderr]    | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 86 |     pub fn remove(&mut self, id: RigidBodyId) -> Option<RigidBody> {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 93 |     pub fn get_mut(&mut self, id: RigidBodyId) -> Option<&mut RigidBody> {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `BuildBoundingVolume` is never used
[INFO] [stderr]   --> src/physics/bvh.rs:31:11
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub trait BuildBoundingVolume<V: BoundingVolume> {
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `intersect_sphere_sphere` is never used
[INFO] [stderr]  --> src/physics/intersect/intersect_sphere_sphere.rs:4:8
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub fn intersect_sphere_sphere(s1: &Sphere, s2: &Sphere, pos_12: &Isometry3) -> bool {
[INFO] [stderr]   |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PointLightId` is never constructed
[INFO] [stderr]  --> src/renderer/light.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct PointLightId {
[INFO] [stderr]   |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `insert_point_light`, `get_point_light`, and `get_point_light_mut` are never used
[INFO] [stderr]   --> src/renderer/light.rs:31:12
[INFO] [stderr]    |
[INFO] [stderr] 16 | impl Lights {
[INFO] [stderr]    | ----------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 31 |     pub fn insert_point_light(&mut self, p: PointLight) -> PointLightId {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 37 |     pub fn get_point_light(&self, id: PointLightId) -> Option<&PointLight> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 40 |     pub fn get_point_light_mut(&mut self, id: PointLightId) -> Option<&mut PointLight> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/renderer/light.rs:76:12
[INFO] [stderr]    |
[INFO] [stderr] 75 | impl PointLight {
[INFO] [stderr]    | --------------- associated function in this implementation
[INFO] [stderr] 76 |     pub fn new(color: [Float; 3], radius: Float, point: Point3) -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `OPENGL_TO_WGPU_MATRIX`, `build_camera_matrix`, and `build_projection_matrix` are never used
[INFO] [stderr]   --> src/renderer/camera.rs:15:11
[INFO] [stderr]    |
[INFO] [stderr] 12 | impl Camera {
[INFO] [stderr]    | ----------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 15 |     const OPENGL_TO_WGPU_MATRIX: Matrix4 = 
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 43 |     pub fn build_camera_matrix(&self) -> Matrix4{
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 47 |     pub fn build_projection_matrix(&self) -> Matrix4 {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `create_material`, `create_mesh`, `get_default_texture`, and `create_model` are never used
[INFO] [stderr]   --> src/renderer/resource.rs:40:12
[INFO] [stderr]    |
[INFO] [stderr] 23 | impl ResourceManager{
[INFO] [stderr]    | -------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 40 |     pub fn create_material(&self, desc: &MaterialDescriptor) -> Material{
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 44 |     pub fn create_mesh<T: Vertex>(&self, desc: &MeshDescriptor<T>) -> Mesh{
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 48 |     pub fn get_default_texture(&self) -> Arc<Texture> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 52 |     pub fn create_model<'a, 'b, 'c, T: Vertex>(&mut self, desc: &ModelDescriptor<T>) -> Arc<Model>{
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]    --> src/renderer/resource.rs:218:8
[INFO] [stderr]     |
[INFO] [stderr] 218 | struct StaticVertexData{
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stderr]     |
[INFO] [stderr]     = help: consider removing this field
[INFO] [stderr] 
[INFO] [stderr] warning: function `check` is never used
[INFO] [stderr]    --> src/renderer/resource.rs:216:1
[INFO] [stderr]     |
[INFO] [stderr] 216 | #[repr(C)]
[INFO] [stderr]     | ^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]    --> src/renderer/resource.rs:225:8
[INFO] [stderr]     |
[INFO] [stderr] 225 | struct SkeletalVertexData{
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stderr]     |
[INFO] [stderr]     = help: consider removing this field
[INFO] [stderr] 
[INFO] [stderr] warning: function `check` is never used
[INFO] [stderr]    --> src/renderer/resource.rs:223:1
[INFO] [stderr]     |
[INFO] [stderr] 223 | #[repr(C)]
[INFO] [stderr]     | ^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]   --> src/renderer/scene.rs:37:12
[INFO] [stderr]    |
[INFO] [stderr] 18 | impl Scene {
[INFO] [stderr]    | ---------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 37 |     pub fn remove_entity(&mut self, index: EntityId) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 45 |     pub fn iter_mut_entities(&mut self) -> ga::IterMut<Entity> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 49 |     pub fn get_entity(&self, index: EntityId) -> Option<&Entity> {
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 70 |     pub fn set_directional_light(&mut self, directional_light: DirectionalLight) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 80 |     pub fn insert_point_light(&mut self, p: PointLight) -> PointLightId {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 88 |     pub fn get_point_light(&self, id: PointLightId) -> Option<&PointLight> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 91 |     pub fn get_point_light_mut(&mut self, id: PointLightId) -> Option<&mut PointLight> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ModelDescriptor` is never constructed
[INFO] [stderr]   --> src/renderer/model.rs:10:12
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub struct ModelDescriptor<'a, 'b, 'c, 'd, 'e, 'f, 'g, 'h, 'i, T> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/renderer/model.rs:24:12
[INFO] [stderr]    |
[INFO] [stderr] 23 | impl Model {
[INFO] [stderr]    | ---------- associated function in this implementation
[INFO] [stderr] 24 |     pub fn new<T: Vertex>(device: &wgpu::Device, desc: &ModelDescriptor<T>) -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `draw_mesh` is never used
[INFO] [stderr]   --> src/renderer/model.rs:45:8
[INFO] [stderr]    |
[INFO] [stderr] 44 | pub trait DrawModel<'a> {
[INFO] [stderr]    |           --------- method in this trait
[INFO] [stderr] 45 |     fn draw_mesh(&mut self, mesh: &'a Mesh, material: &'a Material);
[INFO] [stderr]    |        ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/renderer/model/material.rs:16:12
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub struct MaterialUniform {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^ field in this struct
[INFO] [stderr]    |
[INFO] [stderr]    = help: consider removing this field
[INFO] [stderr] 
[INFO] [stderr] warning: function `check` is never used
[INFO] [stderr]   --> src/renderer/model/material.rs:14:1
[INFO] [stderr]    |
[INFO] [stderr] 14 | #[repr(C)]
[INFO] [stderr]    | ^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `name`, `buffer`, and `texture` are never read
[INFO] [stderr]   --> src/renderer/model/material.rs:26:9
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub struct Material {
[INFO] [stderr]    |            -------- fields in this struct
[INFO] [stderr] 26 |     pub name: String,
[INFO] [stderr]    |         ^^^^
[INFO] [stderr] 27 |     pub buffer: wgpu::Buffer,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 28 |     pub texture: Arc<Texture>,
[INFO] [stderr]    |         ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Material` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `MeshDescriptor` is never constructed
[INFO] [stderr]  --> src/renderer/model/mesh.rs:4:12
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub struct MeshDescriptor<'a, 'b, 'c, T> {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `name` is never read
[INFO] [stderr]   --> src/renderer/model/mesh.rs:12:9
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub struct Mesh {
[INFO] [stderr]    |            ---- field in this struct
[INFO] [stderr] 12 |     pub name: String,
[INFO] [stderr]    |         ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Mesh` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: associated functions `new` and `new_with_index_u16` are never used
[INFO] [stderr]   --> src/renderer/model/mesh.rs:21:12
[INFO] [stderr]    |
[INFO] [stderr] 20 | impl Mesh {
[INFO] [stderr]    | --------- associated functions in this implementation
[INFO] [stderr] 21 |     pub fn new<'a, 'b, 'c, T: Vertex>(
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 62 |     pub fn new_with_index_u16<T: Vertex>(
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `check` is never used
[INFO] [stderr]  --> src/renderer/model/vertex.rs:6:1
[INFO] [stderr]   |
[INFO] [stderr] 6 | #[repr(C)]
[INFO] [stderr]   | ^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/renderer/model/vertex.rs:10:12
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub struct ModelVertex {
[INFO] [stderr]    |            ^^^^^^^^^^^ field in this struct
[INFO] [stderr]    |
[INFO] [stderr]    = help: consider removing this field
[INFO] [stderr] 
[INFO] [stderr] warning: field `name` is never read
[INFO] [stderr]  --> src/renderer/entity.rs:7:9
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub struct Entity {
[INFO] [stderr]   |            ------ field in this struct
[INFO] [stderr] 7 |     pub name: String,
[INFO] [stderr]   |         ^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `Entity` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `texture` is never read
[INFO] [stderr]  --> src/renderer/texture.rs:7:9
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub struct Texture {
[INFO] [stderr]   |            ------- field in this struct
[INFO] [stderr] 7 |     pub texture: wgpu::Texture,
[INFO] [stderr]   |         ^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `Texture` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `max_point_lights` is never read
[INFO] [stderr]   --> src/renderer/render_pass.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub struct RenderPass {
[INFO] [stderr]    |            ---------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 21 |     max_point_lights: u32,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `RenderPass` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]  --> src/renderer/render_pass/camera_uniform_buffer.rs:3:12
[INFO] [stderr]   |
[INFO] [stderr] 3 | pub struct CameraUniforms {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^ field in this struct
[INFO] [stderr]   |
[INFO] [stderr]   = help: consider removing this field
[INFO] [stderr] 
[INFO] [stderr] warning: function `check` is never used
[INFO] [stderr]  --> src/renderer/render_pass/camera_uniform_buffer.rs:1:1
[INFO] [stderr]   |
[INFO] [stderr] 1 | #[repr(C)]
[INFO] [stderr]   | ^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CascadeShadowPass` is never constructed
[INFO] [stderr]  --> src/renderer/render_pass/shadow/cascaded_shadow.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct CascadeShadowPass {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CascadedShadow` is never constructed
[INFO] [stderr]   --> src/renderer/render_pass/shadow/cascaded_shadow.rs:10:12
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub struct CascadedShadow {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `OVERLAP` and `new` are never used
[INFO] [stderr]   --> src/renderer/render_pass/shadow/cascaded_shadow.rs:21:11
[INFO] [stderr]    |
[INFO] [stderr] 20 | impl CascadedShadow {
[INFO] [stderr]    | ------------------- associated items in this implementation
[INFO] [stderr] 21 |     const OVERLAP: Float = 0.1;
[INFO] [stderr]    |           ^^^^^^^
[INFO] [stderr] 22 |     pub fn new(camera: &Camera, light_direction: &Vector3, resolution: Float) -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `calculate_cascade_size` is never used
[INFO] [stderr]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:114:4
[INFO] [stderr]     |
[INFO] [stderr] 114 | fn calculate_cascade_size(camera: &Camera, zmin: Float, zmax: Float) -> Float {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `calculate_min_max` is never used
[INFO] [stderr]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:122:4
[INFO] [stderr]     |
[INFO] [stderr] 122 | fn calculate_min_max(
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `calculate_cascade_position` is never used
[INFO] [stderr]    --> src/renderer/render_pass/shadow/cascaded_shadow.rs:161:8
[INFO] [stderr]     |
[INFO] [stderr] 161 | pub fn calculate_cascade_position(
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `check` is never used
[INFO] [stderr]  --> src/renderer/render_pass/light_uniform_buffer.rs:4:1
[INFO] [stderr]   |
[INFO] [stderr] 4 | #[repr(C)]
[INFO] [stderr]   | ^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]  --> src/renderer/render_pass/light_uniform_buffer.rs:6:12
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub struct AmbientLightUniforms {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stderr]   |
[INFO] [stderr]   = help: consider removing this field
[INFO] [stderr] 
[INFO] [stderr] warning: function `check` is never used
[INFO] [stderr]   --> src/renderer/render_pass/light_uniform_buffer.rs:20:1
[INFO] [stderr]    |
[INFO] [stderr] 20 | #[repr(C)]
[INFO] [stderr]    | ^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/renderer/render_pass/light_uniform_buffer.rs:22:12
[INFO] [stderr]    |
[INFO] [stderr] 22 | pub struct DirectionalLightUniforms {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stderr]    |
[INFO] [stderr]    = help: consider removing this field
[INFO] [stderr] 
[INFO] [stderr] warning: function `check` is never used
[INFO] [stderr]   --> src/renderer/render_pass/light_uniform_buffer.rs:39:1
[INFO] [stderr]    |
[INFO] [stderr] 39 | #[repr(C)]
[INFO] [stderr]    | ^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/renderer/render_pass/light_uniform_buffer.rs:41:12
[INFO] [stderr]    |
[INFO] [stderr] 41 | pub struct PointLightUniforms {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^ field in this struct
[INFO] [stderr]    |
[INFO] [stderr]    = help: consider removing this field
[INFO] [stderr] 
[INFO] [stderr] warning: field `max_point_lights` is never read
[INFO] [stderr]   --> src/renderer/render_pass/light_uniform_buffer.rs:70:9
[INFO] [stderr]    |
[INFO] [stderr] 64 | pub struct LightUniformBuffer {
[INFO] [stderr]    |            ------------------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 70 |     pub max_point_lights: u32,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `LightUniformBuffer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `instance` and `adapter` are never read
[INFO] [stderr]   --> src/renderer/device.rs:50:9
[INFO] [stderr]    |
[INFO] [stderr] 49 | pub struct Device {
[INFO] [stderr]    |            ------ fields in this struct
[INFO] [stderr] 50 |     pub instance: wgpu::Instance,
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] 51 |     pub adapter: wgpu::Adapter,
[INFO] [stderr]    |         ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Device` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]  --> src/renderer/instance.rs:6:12
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub struct InstanceRaw {
[INFO] [stderr]   |            ^^^^^^^^^^^ field in this struct
[INFO] [stderr]   |
[INFO] [stderr]   = help: consider removing this field
[INFO] [stderr] 
[INFO] [stderr] warning: function `check` is never used
[INFO] [stderr]  --> src/renderer/instance.rs:4:1
[INFO] [stderr]   |
[INFO] [stderr] 4 | #[repr(C)]
[INFO] [stderr]   | ^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `InstanceBuffers` is never constructed
[INFO] [stderr]    --> src/renderer/instance.rs:122:8
[INFO] [stderr]     |
[INFO] [stderr] 122 | struct InstanceBuffers {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]    --> src/renderer/instance.rs:130:12
[INFO] [stderr]     |
[INFO] [stderr] 129 | impl InstanceBuffers {
[INFO] [stderr]     | -------------------- associated function in this implementation
[INFO] [stderr] 130 |     pub fn new(
[INFO] [stderr]     |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/renderer/scene.rs:41:26
[INFO] [stderr]    |
[INFO] [stderr] 41 |     pub fn iter_entities(&self) -> ga::Iter<Entity> {
[INFO] [stderr]    |                          ^^^^^     ---------------- the same lifetime is hidden here
[INFO] [stderr]    |                          |
[INFO] [stderr]    |                          the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 41 |     pub fn iter_entities(&self) -> ga::Iter<'_, Entity> {
[INFO] [stderr]    |                                             +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/renderer/scene.rs:45:30
[INFO] [stderr]    |
[INFO] [stderr] 45 |     pub fn iter_mut_entities(&mut self) -> ga::IterMut<Entity> {
[INFO] [stderr]    |                              ^^^^^^^^^     ------------------- the same lifetime is hidden here
[INFO] [stderr]    |                              |
[INFO] [stderr]    |                              the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 45 |     pub fn iter_mut_entities(&mut self) -> ga::IterMut<'_, Entity> {
[INFO] [stderr]    |                                                        +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/renderer/scene.rs:84:30
[INFO] [stderr]    |
[INFO] [stderr] 84 |     pub fn iter_point_lights(&self) -> ga::Iter<PointLight> {
[INFO] [stderr]    |                              ^^^^^     -------------------- the same lifetime is hidden here
[INFO] [stderr]    |                              |
[INFO] [stderr]    |                              the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 84 |     pub fn iter_point_lights(&self) -> ga::Iter<'_, PointLight> {
[INFO] [stderr]    |                                                 +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/renderer/instance.rs:88:19
[INFO] [stderr]    |
[INFO] [stderr] 88 |     pub fn insert(&self, data: &InstanceRaw, queue: &wgpu::Queue) -> Option<wgpu::BufferSlice> {
[INFO] [stderr]    |                   ^^^^^ the lifetime is elided here                         ----------------- the same lifetime is hidden here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 88 |     pub fn insert(&self, data: &InstanceRaw, queue: &wgpu::Queue) -> Option<wgpu::BufferSlice<'_>> {
[INFO] [stderr]    |                                                                                              ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/renderer/instance.rs:93:9
[INFO] [stderr]    |
[INFO] [stderr] 93 |         &self,
[INFO] [stderr]    |         ^^^^^ the lifetime is elided here
[INFO] [stderr] ...
[INFO] [stderr] 96 |     ) -> Option<wgpu::BufferSlice> {
[INFO] [stderr]    |                 ----------------- the same lifetime is hidden here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 96 |     ) -> Option<wgpu::BufferSlice<'_>> {
[INFO] [stderr]    |                                  ++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `x`
[INFO] [stderr]   --> src/renderer/resource.rs:30:95
[INFO] [stderr]    |
[INFO] [stderr] 30 |         image::RgbaImage::from_fn(Self::DEFAULT_TEXUTER_WIDTH, Self::DEFAULT_TEXUTER_HEIGHT, |x, y| {
[INFO] [stderr]    |                                                                                               ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `yt-game` (lib test) generated 92 warnings (run `cargo fix --lib -p yt-game --tests` to apply 7 suggestions)
[INFO] [stderr] warning: enum `ElementState` is never used
[INFO] [stderr]  --> src/input.rs:9:10
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub enum ElementState {
[INFO] [stderr]   |          ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Keycode` is never used
[INFO] [stderr]  --> src/input/keyboard_input.rs:4:10
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub type Keycode = event::VirtualKeyCode;
[INFO] [stderr]   |          ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `KeyboardInputManager` is never constructed
[INFO] [stderr]  --> src/input/keyboard_input.rs:8:12
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub struct KeyboardInputManager {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]   --> src/input/keyboard_input.rs:15:11
[INFO] [stderr]    |
[INFO] [stderr] 13 | impl KeyboardInputManager {
[INFO] [stderr]    | ------------------------- associated items in this implementation
[INFO] [stderr] 14 |     /// Number of keys.
[INFO] [stderr] 15 |     const NUM_KEYS: usize = 256;
[INFO] [stderr]    |           ^^^^^^^^
[INFO] [stderr] 16 |     /// Create manager with all keys up
[INFO] [stderr] 17 |     pub fn new() -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 25 |     pub fn begin_frame(&mut self) {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 30 |     pub fn process_input(&mut self, input: &winit::event::DeviceEvent) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 38 |     pub fn is_down(&self, keycode: Keycode) -> bool {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 46 |     pub fn is_up(&self, keycode: Keycode) -> bool {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 54 |     pub fn is_pressed(&self, keycode: Keycode) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 64 |     pub fn is_released(&self, keycode: Keycode) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 73 |     fn update(&mut self, virtual_keycode: event::VirtualKeyCode, state: event::ElementState) {
[INFO] [stderr]    |        ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `MouseInputManager` is never constructed
[INFO] [stderr]  --> src/input/mouse_input.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct MouseInputManager {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]   --> src/input/mouse_input.rs:13:11
[INFO] [stderr]    |
[INFO] [stderr] 12 | impl MouseInputManager {
[INFO] [stderr]    | ---------------------- associated items in this implementation
[INFO] [stderr] 13 |     const NUM_MOUSE_BUTTONS: usize = 52;
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 14 |     /// Create default manager
[INFO] [stderr] 15 |     pub fn new() -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 24 |     pub fn get_scroll(&self) -> (Float, Float) {
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 27 |     pub fn get_move(&self) -> (Float, Float) {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 31 |     pub fn begin_frame(&mut self) {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 37 |     pub fn is_down(&self, id: usize) -> bool {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 44 |     pub fn is_up(&self, id: usize) -> bool {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 50 |     pub fn is_pressed(&self, id: usize) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 57 |     pub fn is_released(&self, id: usize) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 64 |     pub fn process_input(&mut self, event: &winit::event::DeviceEvent) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `expand` is never used
[INFO] [stderr]   --> src/physics/bvh.rs:21:8
[INFO] [stderr]    |
[INFO] [stderr] 19 | pub trait BoundingVolume: Clone + Copy + PartialEq {
[INFO] [stderr]    |           -------------- method in this trait
[INFO] [stderr] 20 |     fn intersect(&self, other: &Self) -> bool;
[INFO] [stderr] 21 |     fn expand(&self, p: &Point3) -> Self {
[INFO] [stderr]    |        ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new_min_max` is never used
[INFO] [stderr]   --> src/physics/bvh/aabb.rs:14:12
[INFO] [stderr]    |
[INFO] [stderr]  9 | impl AABB {
[INFO] [stderr]    | --------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 14 |     pub fn new_min_max(min: Point3, max: Point3) -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `BoundingSphere` is never constructed
[INFO] [stderr]  --> src/physics/bvh/bounding_sphere.rs:4:12
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub struct BoundingSphere {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/physics/bvh/bounding_sphere.rs:10:12
[INFO] [stderr]    |
[INFO] [stderr]  9 | impl BoundingSphere {
[INFO] [stderr]    | ------------------- associated function in this implementation
[INFO] [stderr] 10 |     pub fn new(center: Point3, radius: f32) -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] 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] [stderr]   --> src/renderer/camera.rs:15:11
[INFO] [stderr]    |
[INFO] [stderr] 12 | impl Camera {
[INFO] [stderr]    | ----------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 15 |     const OPENGL_TO_WGPU_MATRIX: Matrix4 = 
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 43 |     pub fn build_camera_matrix(&self) -> Matrix4{
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 47 |     pub fn build_projection_matrix(&self) -> Matrix4 {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 54 |     pub fn top_left_at_depth(&self, d: Float) -> Point3{
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 61 |     pub fn get_vertex_local(&self, index: usize) -> Point3{
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `yt-game` (lib) generated 98 warnings (86 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 7.17s
[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 2`
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/yt_game-76a8c4ddc5feb9a2)
[INFO] [stdout] 
[INFO] [stdout] running 12 tests
[INFO] [stdout] test input::mouse_input::test::mouse_input_test ... ok
[INFO] [stdout] test physics::bvh::aabb::test::test_aabb_expand ... ok
[INFO] [stdout] test physics::bvh::aabb::test::test_aabb_intersect ... ok
[INFO] [stdout] test physics::bvh::bounding_sphere::test::test_sphere_expand ... ok
[INFO] [stdout] test input::keyboard_input::test::keyboard_input_test ... ok
[INFO] [stdout] test physics::bvh::bounding_sphere::test::test_sphere_intersect ... ok
[INFO] [stdout] test physics::bvh::bounding_sphere::test::test_sphere_merge ... ok
[INFO] [stdout] test physics::bvh::test::test_bvh ... ok
[INFO] [stdout] test physics::contact::contact_sphere_sphere::test::test_contact_sphere_sphere ... ok
[INFO] [stdout] test renderer::camera::test::camera_vertex_test ... ok
[INFO] [stdout] test physics::bvh::aabb::test::test_aabb_merge ... ok
[INFO] [stdout] test physics::bvh::test::test_bvh_insert ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- physics::bvh::test::test_bvh_insert stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'physics::bvh::test::test_bvh_insert' panicked at src/physics/bvh.rs:463:13:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: Some((2, 3))
[INFO] [stdout]  right: None
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x64e309667ad2 - std::backtrace_rs::backtrace::libunwind::trace::h2d45396358f41939
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x64e309667ad2 - std::backtrace_rs::backtrace::trace_unsynchronized::hffcefc0b67f1d6e2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x64e309667ad2 - std::sys::backtrace::_print_fmt::hd72f71d23b436b92
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x64e309667ad2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::hdcfcb6d4c8489523
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x64e30968d8e3 - core::fmt::rt::Argument::fmt::h2c56b3114963061a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x64e30968d8e3 - core::fmt::write::h8a494366950f23bb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x64e309664a53 - std::io::default_write_fmt::h7b8824096454f323
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x64e309664a53 - std::io::Write::write_fmt::h4e71294925c334d0
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x64e309667922 - std::sys::backtrace::BacktraceLock::print::hb2a626a81e06b2dc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x64e309669059 - std::panicking::default_hook::{{closure}}::h4f78485264f12d10
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x64e309668e8e - std::panicking::default_hook::h2c66fc99e962531d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x64e30962cc14 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hb6bd65493727d71a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x64e30962cc14 - test::test_main_with_exit_callback::{{closure}}::h60217ec76a0ece4a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x64e309669b2e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h318e4efb8c1a5689
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x64e309669b2e - std::panicking::rust_panic_with_hook::h33ac55f64bbd807d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x64e3096697fa - std::panicking::begin_panic_handler::{{closure}}::h30e7cb89678a57fe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:706:13
[INFO] [stdout]   16:     0x64e309667fd9 - std::sys::backtrace::__rust_end_short_backtrace::hed60f27456c16ced
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x64e30966948d - __rustc[de2ca18b4c54d5b8]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x64e30968b8c0 - core::panicking::panic_fmt::h62f63d096dd276af
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x64e30968bc13 - core::panicking::assert_failed_inner::h102b4539a88470c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:448:17
[INFO] [stdout]   20:     0x64e3095d929c - core::panicking::assert_failed::h8508794156d3a30a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:403:5
[INFO] [stdout]   21:     0x64e3095e6be5 - yt_game::physics::bvh::test::test_bvh_insert::h607a68fa33fb75c1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/physics/bvh.rs:463:13
[INFO] [stdout]   22:     0x64e3095e60b7 - yt_game::physics::bvh::test::test_bvh_insert::{{closure}}::h6159285fd8049792
[INFO] [stdout]                                at /opt/rustwide/workdir/src/physics/bvh.rs:423:25
[INFO] [stdout]   23:     0x64e3095efc16 - core::ops::function::FnOnce::call_once::h8367317c387b20f4
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   24:     0x64e30963247b - core::ops::function::FnOnce::call_once::h1f9474f1347fff52
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   25:     0x64e30963247b - test::__rust_begin_short_backtrace::ha52ab26e77157f03
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:648:18
[INFO] [stdout]   26:     0x64e3096315b5 - test::run_test_in_process::{{closure}}::h229c1a11a50b261f
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:74
[INFO] [stdout]   27:     0x64e3096315b5 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h78821afbf97b39a9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   28:     0x64e3096315b5 - std::panicking::catch_unwind::do_call::h53abf3ed5bd32ba3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   29:     0x64e3096315b5 - std::panicking::catch_unwind::h6deb5fe1e91873c9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   30:     0x64e3096315b5 - std::panic::catch_unwind::hea0829b6b565654b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x64e3096315b5 - test::run_test_in_process::hdc44dfecea3db21b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:27
[INFO] [stdout]   32:     0x64e3096315b5 - test::run_test::{{closure}}::h0364ba59bf23f652
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:592:43
[INFO] [stdout]   33:     0x64e3095f51b4 - test::run_test::{{closure}}::h32730b304eec05da
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:622:41
[INFO] [stdout]   34:     0x64e3095f51b4 - std::sys::backtrace::__rust_begin_short_backtrace::h177cb952fc54ad2c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   35:     0x64e3095f8b8a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h119d903520007597
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   36:     0x64e3095f8b8a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hab88401d606702a6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   37:     0x64e3095f8b8a - std::panicking::catch_unwind::do_call::h163fe12cca9901c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   38:     0x64e3095f8b8a - std::panicking::catch_unwind::he81557d0e17cc1bc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   39:     0x64e3095f8b8a - std::panic::catch_unwind::hc2b8e79c20593955
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x64e3095f8b8a - std::thread::Builder::spawn_unchecked_::{{closure}}::hfa6b4978e07815cc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   41:     0x64e3095f8b8a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hddcd7484a13fd793
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   42:     0x64e30966caaf - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h5924238c754de3b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   43:     0x64e30966caaf - std::sys::pal::unix::thread::Thread::new::thread_start::hb6e99e73da4d28f8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/pal/unix/thread.rs:107:17
[INFO] [stdout]   44:     0x78ca641b6aa4 - <unknown>
[INFO] [stdout]   45:     0x78ca64243a34 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     physics::bvh::test::test_bvh_insert
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 11 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.12s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "b3650079e600fc83942e91a697920157f2cee87d0c3454bf0137da31576dc518", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b3650079e600fc83942e91a697920157f2cee87d0c3454bf0137da31576dc518", kill_on_drop: false }`
[INFO] [stdout] b3650079e600fc83942e91a697920157f2cee87d0c3454bf0137da31576dc518
