[INFO] cloning repository https://github.com/OrkanBoy/wgpu_learn
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/OrkanBoy/wgpu_learn" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FOrkanBoy%2Fwgpu_learn", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FOrkanBoy%2Fwgpu_learn'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] a30123ad01088f4f6df9c6c965429fd229ec368f
[INFO] checking OrkanBoy/wgpu_learn against 1.95.0 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FOrkanBoy%2Fwgpu_learn" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/OrkanBoy/wgpu_learn
[INFO] finished tweaking git repo https://github.com/OrkanBoy/wgpu_learn
[INFO] tweaked toml for git repo https://github.com/OrkanBoy/wgpu_learn written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/OrkanBoy/wgpu_learn on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/OrkanBoy/wgpu_learn already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded errno v0.3.5
[INFO] [stderr]   Downloaded winnow v0.5.17
[INFO] [stderr]   Downloaded wgpu v0.17.1
[INFO] [stderr]   Downloaded rustix v0.38.20
[INFO] [stderr]   Downloaded linux-raw-sys v0.4.10
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 15138387802f07d8941ae2fd362b2bfc475271d31f757a8c2337880e71a310c7
[INFO] running `Command { std: "docker" "start" "-a" "15138387802f07d8941ae2fd362b2bfc475271d31f757a8c2337880e71a310c7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "15138387802f07d8941ae2fd362b2bfc475271d31f757a8c2337880e71a310c7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "15138387802f07d8941ae2fd362b2bfc475271d31f757a8c2337880e71a310c7", kill_on_drop: false }`
[INFO] [stdout] 15138387802f07d8941ae2fd362b2bfc475271d31f757a8c2337880e71a310c7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 411fd3f407dbc3afa4ddf9f54031f1f946713dfd71cdf1946c70e32048d4a01e
[INFO] running `Command { std: "docker" "start" "-a" "411fd3f407dbc3afa4ddf9f54031f1f946713dfd71cdf1946c70e32048d4a01e", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.149
[INFO] [stderr]    Compiling xml-rs v0.8.19
[INFO] [stderr]     Checking libloading v0.8.1
[INFO] [stderr]     Checking bitflags v2.4.1
[INFO] [stderr]     Checking smallvec v1.11.1
[INFO] [stderr]     Checking log v0.4.20
[INFO] [stderr]    Compiling wayland-sys v0.29.5
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]    Compiling ahash v0.8.3
[INFO] [stderr]    Compiling slotmap v1.0.6
[INFO] [stderr]     Checking termcolor v1.3.0
[INFO] [stderr]     Checking miniz_oxide v0.7.1
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]    Compiling bytemuck_derive v1.5.0
[INFO] [stderr]     Checking fdeflate v0.3.0
[INFO] [stderr]    Compiling smithay-client-toolkit v0.16.1
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking dlib v0.5.2
[INFO] [stderr]    Compiling rustix v0.38.20
[INFO] [stderr]     Checking owned_ttf_parser v0.19.0
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]     Checking glow v0.12.3
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.1.2
[INFO] [stderr]     Checking wgpu-types v0.17.0
[INFO] [stderr]     Checking flate2 v1.0.28
[INFO] [stderr]     Checking hashbrown v0.14.1
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking profiling v1.0.11
[INFO] [stderr]     Checking linux-raw-sys v0.4.10
[INFO] [stderr]     Checking regex-syntax v0.8.2
[INFO] [stderr]     Checking renderdoc-sys v1.0.0
[INFO] [stderr]     Checking png v0.17.10
[INFO] [stderr]     Checking ab_glyph v0.2.22
[INFO] [stderr]     Checking pollster v0.3.0
[INFO] [stderr]     Checking bytemuck v1.14.0
[INFO] [stderr]     Checking spirv v0.2.0+1.5.4
[INFO] [stderr]    Compiling wayland-scanner v0.29.5
[INFO] [stderr]     Checking tiny-skia-path v0.8.4
[INFO] [stderr]     Checking gpu-descriptor v0.2.4
[INFO] [stderr]     Checking is-terminal v0.4.9
[INFO] [stderr]     Checking naga v0.13.0
[INFO] [stderr]     Checking tiny-skia v0.8.4
[INFO] [stderr]     Checking regex-automata v0.4.3
[INFO] [stderr]     Checking nix v0.24.3
[INFO] [stderr]     Checking parking_lot_core v0.9.9
[INFO] [stderr]     Checking nix v0.25.1
[INFO] [stderr]     Checking khronos-egl v4.1.0
[INFO] [stderr]     Checking memmap2 v0.5.10
[INFO] [stderr]     Checking getrandom v0.2.10
[INFO] [stderr]     Checking mio v0.8.8
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling wayland-client v0.29.5
[INFO] [stderr]    Compiling wayland-protocols v0.29.5
[INFO] [stderr]    Compiling winit v0.28.7
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking xcursor v0.3.4
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking wayland-commons v0.29.5
[INFO] [stderr]     Checking calloop v0.10.6
[INFO] [stderr]     Checking regex v1.10.2
[INFO] [stderr]     Checking wayland-cursor v0.29.5
[INFO] [stderr]     Checking wgpu-hal v0.17.2
[INFO] [stderr]     Checking env_logger v0.10.0
[INFO] [stderr]     Checking wgpu-core v0.17.1
[INFO] [stderr]     Checking wgpu v0.17.1
[INFO] [stderr]     Checking sctk-adwaita v0.5.4
[INFO] [stderr]     Checking wgpu_learn v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `cmp::Ordering` and `f32::consts::TAU`
[INFO] [stdout]  --> src/main.rs:1:25
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{mem::size_of, f32::consts::TAU, cmp::Ordering};
[INFO] [stdout]   |                         ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Rotor`
[INFO] [stdout]  --> src/main.rs:6:49
[INFO] [stdout]   |
[INFO] [stdout] 6 | use math::{Vector3, BiVector3, Vector2, Scale2, Rotor};
[INFO] [stdout]   |                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `process::Output`
[INFO] [stdout]  --> src/math.rs:2:19
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::{ops::*, process::Output};
[INFO] [stdout]   |                   ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `max` and `min`
[INFO] [stdout]  --> src/polygon.rs:1:16
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::cmp::{min, max};
[INFO] [stdout]   |                ^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Vector3`
[INFO] [stdout]  --> src/polygon.rs:3:25
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::math::{self, Vector3};
[INFO] [stdout]   |                         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `cmp::Ordering` and `f32::consts::TAU`
[INFO] [stdout]  --> src/main.rs:1:25
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{mem::size_of, f32::consts::TAU, cmp::Ordering};
[INFO] [stdout]   |                         ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Rotor`
[INFO] [stdout]  --> src/main.rs:6:49
[INFO] [stdout]   |
[INFO] [stdout] 6 | use math::{Vector3, BiVector3, Vector2, Scale2, Rotor};
[INFO] [stdout]   |                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `process::Output`
[INFO] [stdout]  --> src/math.rs:2:19
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::{ops::*, process::Output};
[INFO] [stdout]   |                   ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `max` and `min`
[INFO] [stdout]  --> src/polygon.rs:1:16
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::cmp::{min, max};
[INFO] [stdout]   |                ^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Vector3`
[INFO] [stdout]  --> src/polygon.rs:3:25
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::math::{self, Vector3};
[INFO] [stdout]   |                         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: taking a mutable reference to a `const` item
[INFO] [stdout]   --> src/main.rs:65:10
[INFO] [stdout]    |
[INFO] [stdout] 65 |         *math::Affine3::IDENTITY
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: each usage of a `const` item creates a new temporary
[INFO] [stdout]    = note: the mutable reference will refer to this temporary, not the original `const` item
[INFO] [stdout] note: `const` item defined here
[INFO] [stdout]   --> src/math.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub const IDENTITY: Self = Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(const_item_mutation)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: taking a mutable reference to a `const` item
[INFO] [stdout]   --> src/main.rs:93:10
[INFO] [stdout]    |
[INFO] [stdout] 93 |         *math::Affine3::IDENTITY
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: each usage of a `const` item creates a new temporary
[INFO] [stdout]    = note: the mutable reference will refer to this temporary, not the original `const` item
[INFO] [stdout] note: `const` item defined here
[INFO] [stdout]   --> src/math.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub const IDENTITY: Self = Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: taking a mutable reference to a `const` item
[INFO] [stdout]    --> src/main.rs:103:20
[INFO] [stdout]     |
[INFO] [stdout] 103 |             view: *math::Affine3::IDENTITY
[INFO] [stdout]     |                    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: each usage of a `const` item creates a new temporary
[INFO] [stdout]     = note: the mutable reference will refer to this temporary, not the original `const` item
[INFO] [stdout] note: `const` item defined here
[INFO] [stdout]    --> src/math.rs:32:5
[INFO] [stdout]     |
[INFO] [stdout]  32 |     pub const IDENTITY: Self = Self {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `width`
[INFO] [stdout]    --> src/main.rs:147:23
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_width`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `height`
[INFO] [stdout]    --> src/main.rs:147:35
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |                                   ^^^^^^ help: if this is intentional, prefix it with an underscore: `_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `near`
[INFO] [stdout]    --> src/main.rs:147:48
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |                                                ^^^^ help: if this is intentional, prefix it with an underscore: `_near`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `far`
[INFO] [stdout]    --> src/main.rs:147:59
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |                                                           ^^^ help: if this is intentional, prefix it with an underscore: `_far`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `divs`
[INFO] [stdout]    --> src/main.rs:147:69
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |                                                                     ^^^^ help: if this is intentional, prefix it with an underscore: `_divs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `camera_near_z`
[INFO] [stdout]    --> src/main.rs:153:5
[INFO] [stdout]     |
[INFO] [stdout] 153 |     camera_near_z: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_camera_near_z`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `camera_far_z`
[INFO] [stdout]    --> src/main.rs:154:5
[INFO] [stdout]     |
[INFO] [stdout] 154 |     camera_far_z: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_camera_far_z`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `light_width`
[INFO] [stdout]    --> src/main.rs:159:5
[INFO] [stdout]     |
[INFO] [stdout] 159 |     light_width: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_light_width`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `light_height`
[INFO] [stdout]    --> src/main.rs:160:5
[INFO] [stdout]     |
[INFO] [stdout] 160 |     light_height: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_light_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `max_fits`
[INFO] [stdout]    --> src/main.rs:161:5
[INFO] [stdout]     |
[INFO] [stdout] 161 |     max_fits: usize,
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_max_fits`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `out_fits`
[INFO] [stdout]    --> src/main.rs:162:5
[INFO] [stdout]     |
[INFO] [stdout] 162 |     out_fits: &mut [(Vector2, Scale2)],
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_out_fits`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value captured by `frames` is never read
[INFO] [stdout]    --> src/main.rs:744:17
[INFO] [stdout]     |
[INFO] [stdout] 744 |                 frames += 1;
[INFO] [stdout]     |                 ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: did you mean to capture by reference instead?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `frames` is never read
[INFO] [stdout]    --> src/main.rs:744:17
[INFO] [stdout]     |
[INFO] [stdout] 744 |                 frames += 1;
[INFO] [stdout]     |                 ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value captured by `time_rendered` is never read
[INFO] [stdout]    --> src/main.rs:748:17
[INFO] [stdout]     |
[INFO] [stdout] 748 |                 time_rendered += delta_frame_time;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: did you mean to capture by reference instead?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `time_rendered` is never read
[INFO] [stdout]    --> src/main.rs:748:17
[INFO] [stdout]     |
[INFO] [stdout] 748 |                 time_rendered += delta_frame_time;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value captured by `depth_texture` is never read
[INFO] [stdout]    --> src/main.rs:891:26
[INFO] [stdout]     |
[INFO] [stdout] 891 |                         (depth_texture, depth_texture_view) = create_depth_texture(&device, size.width, size.height);
[INFO] [stdout]     |                          ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: did you mean to capture by reference instead?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `depth_texture` is never read
[INFO] [stdout]    --> src/main.rs:891:26
[INFO] [stdout]     |
[INFO] [stdout] 891 |                         (depth_texture, depth_texture_view) = create_depth_texture(&device, size.width, size.height);
[INFO] [stdout]     |                          ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `depth_texture`
[INFO] [stdout]    --> src/main.rs:356:10
[INFO] [stdout]     |
[INFO] [stdout] 356 |     let (mut depth_texture, mut depth_texture_view) = create_depth_texture(&device, size.width, size.height);
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_depth_texture`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `time_rendered`
[INFO] [stdout]    --> src/main.rs:646:9
[INFO] [stdout]     |
[INFO] [stdout] 646 |     let mut time_rendered = 0.0;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_time_rendered`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `frames`
[INFO] [stdout]    --> src/main.rs:647:9
[INFO] [stdout]     |
[INFO] [stdout] 647 |     let mut frames = 0;
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_frames`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]   --> src/main.rs:20:1
[INFO] [stdout]    |
[INFO] [stdout] 20 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/main.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | struct Vertex {
[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/main.rs:55:1
[INFO] [stdout]    |
[INFO] [stdout] 55 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/main.rs:57:8
[INFO] [stdout]    |
[INFO] [stdout] 57 | struct LightRaw {
[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/main.rs:114:1
[INFO] [stdout]     |
[INFO] [stdout] 114 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/main.rs:116:8
[INFO] [stdout]     |
[INFO] [stdout] 116 | 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/main.rs:120:1
[INFO] [stdout]     |
[INFO] [stdout] 120 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/main.rs:122:8
[INFO] [stdout]     |
[INFO] [stdout] 122 | struct CameraRaw {
[INFO] [stdout]     |        ^^^^^^^^^ field in this struct
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compute_depth_divs` is never used
[INFO] [stdout]    --> src/main.rs:147:4
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compute_fits` is never used
[INFO] [stdout]    --> src/main.rs:151:4
[INFO] [stdout]     |
[INFO] [stdout] 151 | fn compute_fits(
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `delta_mouse_pos` is never read
[INFO] [stdout]  --> src/input.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct InputState {
[INFO] [stdout]   |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 7 |     pub delta_mouse_pos: [f32; 2],
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/math.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct Affine3 {
[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/math.rs:12:1
[INFO] [stdout]    |
[INFO] [stdout] 12 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated constant `IDENTITY` is never used
[INFO] [stdout]    --> src/math.rs:203:15
[INFO] [stdout]     |
[INFO] [stdout] 202 | impl Scale3 {
[INFO] [stdout]     | ----------- associated constant in this implementation
[INFO] [stdout] 203 |     pub const IDENTITY: Vector3 = Vector3 {
[INFO] [stdout]     |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `norm_sqr` and `dot` are never used
[INFO] [stdout]    --> src/math.rs:271:12
[INFO] [stdout]     |
[INFO] [stdout] 260 | impl Vector3 {
[INFO] [stdout]     | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 271 |     pub fn norm_sqr(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 283 |     pub fn dot(&self, rhs: &Vector3) -> f32 {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `commute` is never used
[INFO] [stdout]    --> src/math.rs:354:12
[INFO] [stdout]     |
[INFO] [stdout] 349 | impl BiVector3 {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 354 |     pub fn commute(&self, other: &BiVector3) -> BiVector3 {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `norm_sqr` is never used
[INFO] [stdout]    --> src/math.rs:448:12
[INFO] [stdout]     |
[INFO] [stdout] 440 | impl Rotor {
[INFO] [stdout]     | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 448 |     pub fn norm_sqr(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/math.rs:479:12
[INFO] [stdout]     |
[INFO] [stdout] 479 | pub struct Vector2 {
[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/math.rs:477:1
[INFO] [stdout]     |
[INFO] [stdout] 477 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `NAN` and `wedge` are never used
[INFO] [stdout]    --> src/math.rs:485:15
[INFO] [stdout]     |
[INFO] [stdout] 484 | impl Vector2 {
[INFO] [stdout]     | ------------ associated items in this implementation
[INFO] [stdout] 485 |     pub const NAN: Self = Vector2{ x: f32::NAN, y: f32::NAN };
[INFO] [stdout]     |               ^^^
[INFO] [stdout] ...
[INFO] [stdout] 495 |     pub fn wedge(self, rhs: Vector2) -> BiVector2 {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BiVector2` is never constructed
[INFO] [stdout]    --> src/math.rs:524:12
[INFO] [stdout]     |
[INFO] [stdout] 524 | pub struct BiVector2 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/math.rs:542:12
[INFO] [stdout]     |
[INFO] [stdout] 542 | pub struct Scale2 {
[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/math.rs:540:1
[INFO] [stdout]     |
[INFO] [stdout] 540 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `graham_scan` is never used
[INFO] [stdout]   --> src/polygon.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub fn graham_scan(
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `convex_intersect_alloc` is never used
[INFO] [stdout]   --> src/polygon.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 81 | pub fn convex_intersect_alloc(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `convex_intersect_no_alloc` is never used
[INFO] [stdout]    --> src/polygon.rs:155:8
[INFO] [stdout]     |
[INFO] [stdout] 155 | pub fn convex_intersect_no_alloc(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: taking a mutable reference to a `const` item
[INFO] [stdout]   --> src/main.rs:65:10
[INFO] [stdout]    |
[INFO] [stdout] 65 |         *math::Affine3::IDENTITY
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: each usage of a `const` item creates a new temporary
[INFO] [stdout]    = note: the mutable reference will refer to this temporary, not the original `const` item
[INFO] [stdout] note: `const` item defined here
[INFO] [stdout]   --> src/math.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub const IDENTITY: Self = Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(const_item_mutation)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: taking a mutable reference to a `const` item
[INFO] [stdout]   --> src/main.rs:93:10
[INFO] [stdout]    |
[INFO] [stdout] 93 |         *math::Affine3::IDENTITY
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: each usage of a `const` item creates a new temporary
[INFO] [stdout]    = note: the mutable reference will refer to this temporary, not the original `const` item
[INFO] [stdout] note: `const` item defined here
[INFO] [stdout]   --> src/math.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub const IDENTITY: Self = Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: taking a mutable reference to a `const` item
[INFO] [stdout]    --> src/main.rs:103:20
[INFO] [stdout]     |
[INFO] [stdout] 103 |             view: *math::Affine3::IDENTITY
[INFO] [stdout]     |                    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: each usage of a `const` item creates a new temporary
[INFO] [stdout]     = note: the mutable reference will refer to this temporary, not the original `const` item
[INFO] [stdout] note: `const` item defined here
[INFO] [stdout]    --> src/math.rs:32:5
[INFO] [stdout]     |
[INFO] [stdout]  32 |     pub const IDENTITY: Self = Self {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `width`
[INFO] [stdout]    --> src/main.rs:147:23
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_width`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `height`
[INFO] [stdout]    --> src/main.rs:147:35
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |                                   ^^^^^^ help: if this is intentional, prefix it with an underscore: `_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `near`
[INFO] [stdout]    --> src/main.rs:147:48
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |                                                ^^^^ help: if this is intentional, prefix it with an underscore: `_near`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `far`
[INFO] [stdout]    --> src/main.rs:147:59
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |                                                           ^^^ help: if this is intentional, prefix it with an underscore: `_far`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `divs`
[INFO] [stdout]    --> src/main.rs:147:69
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |                                                                     ^^^^ help: if this is intentional, prefix it with an underscore: `_divs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `camera_near_z`
[INFO] [stdout]    --> src/main.rs:153:5
[INFO] [stdout]     |
[INFO] [stdout] 153 |     camera_near_z: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_camera_near_z`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `camera_far_z`
[INFO] [stdout]    --> src/main.rs:154:5
[INFO] [stdout]     |
[INFO] [stdout] 154 |     camera_far_z: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_camera_far_z`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `light_width`
[INFO] [stdout]    --> src/main.rs:159:5
[INFO] [stdout]     |
[INFO] [stdout] 159 |     light_width: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_light_width`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `light_height`
[INFO] [stdout]    --> src/main.rs:160:5
[INFO] [stdout]     |
[INFO] [stdout] 160 |     light_height: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_light_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `max_fits`
[INFO] [stdout]    --> src/main.rs:161:5
[INFO] [stdout]     |
[INFO] [stdout] 161 |     max_fits: usize,
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_max_fits`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `out_fits`
[INFO] [stdout]    --> src/main.rs:162:5
[INFO] [stdout]     |
[INFO] [stdout] 162 |     out_fits: &mut [(Vector2, Scale2)],
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_out_fits`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value captured by `frames` is never read
[INFO] [stdout]    --> src/main.rs:744:17
[INFO] [stdout]     |
[INFO] [stdout] 744 |                 frames += 1;
[INFO] [stdout]     |                 ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: did you mean to capture by reference instead?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `frames` is never read
[INFO] [stdout]    --> src/main.rs:744:17
[INFO] [stdout]     |
[INFO] [stdout] 744 |                 frames += 1;
[INFO] [stdout]     |                 ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value captured by `time_rendered` is never read
[INFO] [stdout]    --> src/main.rs:748:17
[INFO] [stdout]     |
[INFO] [stdout] 748 |                 time_rendered += delta_frame_time;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: did you mean to capture by reference instead?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `time_rendered` is never read
[INFO] [stdout]    --> src/main.rs:748:17
[INFO] [stdout]     |
[INFO] [stdout] 748 |                 time_rendered += delta_frame_time;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value captured by `depth_texture` is never read
[INFO] [stdout]    --> src/main.rs:891:26
[INFO] [stdout]     |
[INFO] [stdout] 891 |                         (depth_texture, depth_texture_view) = create_depth_texture(&device, size.width, size.height);
[INFO] [stdout]     |                          ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: did you mean to capture by reference instead?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `depth_texture` is never read
[INFO] [stdout]    --> src/main.rs:891:26
[INFO] [stdout]     |
[INFO] [stdout] 891 |                         (depth_texture, depth_texture_view) = create_depth_texture(&device, size.width, size.height);
[INFO] [stdout]     |                          ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `depth_texture`
[INFO] [stdout]    --> src/main.rs:356:10
[INFO] [stdout]     |
[INFO] [stdout] 356 |     let (mut depth_texture, mut depth_texture_view) = create_depth_texture(&device, size.width, size.height);
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_depth_texture`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `time_rendered`
[INFO] [stdout]    --> src/main.rs:646:9
[INFO] [stdout]     |
[INFO] [stdout] 646 |     let mut time_rendered = 0.0;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_time_rendered`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `frames`
[INFO] [stdout]    --> src/main.rs:647:9
[INFO] [stdout]     |
[INFO] [stdout] 647 |     let mut frames = 0;
[INFO] [stdout]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_frames`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]   --> src/main.rs:20:1
[INFO] [stdout]    |
[INFO] [stdout] 20 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/main.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | struct Vertex {
[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/main.rs:55:1
[INFO] [stdout]    |
[INFO] [stdout] 55 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/main.rs:57:8
[INFO] [stdout]    |
[INFO] [stdout] 57 | struct LightRaw {
[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/main.rs:114:1
[INFO] [stdout]     |
[INFO] [stdout] 114 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/main.rs:116:8
[INFO] [stdout]     |
[INFO] [stdout] 116 | 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/main.rs:120:1
[INFO] [stdout]     |
[INFO] [stdout] 120 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/main.rs:122:8
[INFO] [stdout]     |
[INFO] [stdout] 122 | struct CameraRaw {
[INFO] [stdout]     |        ^^^^^^^^^ field in this struct
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compute_depth_divs` is never used
[INFO] [stdout]    --> src/main.rs:147:4
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn compute_depth_divs(width: f32, height: f32, near: f32, far: f32, divs: &mut [f32]) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compute_fits` is never used
[INFO] [stdout]    --> src/main.rs:151:4
[INFO] [stdout]     |
[INFO] [stdout] 151 | fn compute_fits(
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `delta_mouse_pos` is never read
[INFO] [stdout]  --> src/input.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct InputState {
[INFO] [stdout]   |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 7 |     pub delta_mouse_pos: [f32; 2],
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/math.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct Affine3 {
[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/math.rs:12:1
[INFO] [stdout]    |
[INFO] [stdout] 12 | #[repr(C)]
[INFO] [stdout]    | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated constant `IDENTITY` is never used
[INFO] [stdout]    --> src/math.rs:203:15
[INFO] [stdout]     |
[INFO] [stdout] 202 | impl Scale3 {
[INFO] [stdout]     | ----------- associated constant in this implementation
[INFO] [stdout] 203 |     pub const IDENTITY: Vector3 = Vector3 {
[INFO] [stdout]     |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `norm_sqr` and `dot` are never used
[INFO] [stdout]    --> src/math.rs:271:12
[INFO] [stdout]     |
[INFO] [stdout] 260 | impl Vector3 {
[INFO] [stdout]     | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 271 |     pub fn norm_sqr(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 283 |     pub fn dot(&self, rhs: &Vector3) -> f32 {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `commute` is never used
[INFO] [stdout]    --> src/math.rs:354:12
[INFO] [stdout]     |
[INFO] [stdout] 349 | impl BiVector3 {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 354 |     pub fn commute(&self, other: &BiVector3) -> BiVector3 {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `norm_sqr` is never used
[INFO] [stdout]    --> src/math.rs:448:12
[INFO] [stdout]     |
[INFO] [stdout] 440 | impl Rotor {
[INFO] [stdout]     | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 448 |     pub fn norm_sqr(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/math.rs:479:12
[INFO] [stdout]     |
[INFO] [stdout] 479 | pub struct Vector2 {
[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/math.rs:477:1
[INFO] [stdout]     |
[INFO] [stdout] 477 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `NAN` and `wedge` are never used
[INFO] [stdout]    --> src/math.rs:485:15
[INFO] [stdout]     |
[INFO] [stdout] 484 | impl Vector2 {
[INFO] [stdout]     | ------------ associated items in this implementation
[INFO] [stdout] 485 |     pub const NAN: Self = Vector2{ x: f32::NAN, y: f32::NAN };
[INFO] [stdout]     |               ^^^
[INFO] [stdout] ...
[INFO] [stdout] 495 |     pub fn wedge(self, rhs: Vector2) -> BiVector2 {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BiVector2` is never constructed
[INFO] [stdout]    --> src/math.rs:524:12
[INFO] [stdout]     |
[INFO] [stdout] 524 | pub struct BiVector2 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]    --> src/math.rs:542:12
[INFO] [stdout]     |
[INFO] [stdout] 542 | pub struct Scale2 {
[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/math.rs:540:1
[INFO] [stdout]     |
[INFO] [stdout] 540 | #[repr(C)]
[INFO] [stdout]     | ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `graham_scan` is never used
[INFO] [stdout]   --> src/polygon.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub fn graham_scan(
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `convex_intersect_alloc` is never used
[INFO] [stdout]   --> src/polygon.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 81 | pub fn convex_intersect_alloc(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `convex_intersect_no_alloc` is never used
[INFO] [stdout]    --> src/polygon.rs:155:8
[INFO] [stdout]     |
[INFO] [stdout] 155 | pub fn convex_intersect_no_alloc(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 46.45s
[INFO] running `Command { std: "docker" "inspect" "411fd3f407dbc3afa4ddf9f54031f1f946713dfd71cdf1946c70e32048d4a01e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "411fd3f407dbc3afa4ddf9f54031f1f946713dfd71cdf1946c70e32048d4a01e", kill_on_drop: false }`
[INFO] [stdout] 411fd3f407dbc3afa4ddf9f54031f1f946713dfd71cdf1946c70e32048d4a01e
