[INFO] cloning repository https://github.com/pinceau-renderer/pinceau-rs
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/pinceau-renderer/pinceau-rs" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpinceau-renderer%2Fpinceau-rs", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpinceau-renderer%2Fpinceau-rs'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 7ad01498b6754274b8f1b2ade84c7ffd100e6ba2
[INFO] checking pinceau-renderer/pinceau-rs against master#377656d3dd3f9c23a9c8713e163f4365a5261a84 for pr-146470-3
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpinceau-renderer%2Fpinceau-rs" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/pinceau-renderer/pinceau-rs
[INFO] finished tweaking git repo https://github.com/pinceau-renderer/pinceau-rs
[INFO] tweaked toml for git repo https://github.com/pinceau-renderer/pinceau-rs written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/pinceau-renderer/pinceau-rs on toolchain 377656d3dd3f9c23a9c8713e163f4365a5261a84
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/pinceau-renderer/pinceau-rs 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" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded wayland-cursor v0.31.8
[INFO] [stderr]   Downloaded is-terminal v0.4.15
[INFO] [stderr]   Downloaded cc v1.2.14
[INFO] [stderr]   Downloaded wayland-backend v0.3.8
[INFO] [stderr]   Downloaded wayland-client v0.31.8
[INFO] [stderr]   Downloaded winnow v0.7.2
[INFO] [stderr]   Downloaded wgpu v24.0.1
[INFO] [stderr]   Downloaded quick-xml v0.37.2
[INFO] [stderr]   Downloaded wgpu-core v24.0.0
[INFO] [stderr]   Downloaded wgpu-hal v24.0.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 961296ae73a9c8b78b4c150f5cbcdb7ed132d75023be8e711ff5c6cd95433579
[INFO] running `Command { std: "docker" "start" "-a" "961296ae73a9c8b78b4c150f5cbcdb7ed132d75023be8e711ff5c6cd95433579", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "961296ae73a9c8b78b4c150f5cbcdb7ed132d75023be8e711ff5c6cd95433579", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "961296ae73a9c8b78b4c150f5cbcdb7ed132d75023be8e711ff5c6cd95433579", kill_on_drop: false }`
[INFO] [stdout] 961296ae73a9c8b78b4c150f5cbcdb7ed132d75023be8e711ff5c6cd95433579
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 8b0befcc74c1c1afb056d255aae0d6a6f12c8eec085185010060abbf332c7979
[INFO] running `Command { std: "docker" "start" "-a" "8b0befcc74c1c1afb056d255aae0d6a6f12c8eec085185010060abbf332c7979", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde v1.0.217
[INFO] [stderr]    Compiling proc-macro2 v1.0.93
[INFO] [stderr]    Compiling unicode-ident v1.0.16
[INFO] [stderr]     Checking log v0.4.25
[INFO] [stderr]     Checking once_cell v1.20.3
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]     Checking smallvec v1.14.0
[INFO] [stderr]     Checking linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling wayland-sys v0.31.6
[INFO] [stderr]    Compiling cc v1.2.14
[INFO] [stderr]    Compiling quick-xml v0.37.2
[INFO] [stderr]    Compiling wayland-client v0.31.8
[INFO] [stderr]    Compiling rustversion v1.0.19
[INFO] [stderr]     Checking tracing-core v0.1.33
[INFO] [stderr]     Checking foldhash v0.1.4
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling thiserror v2.0.11
[INFO] [stderr]     Checking hashbrown v0.15.2
[INFO] [stderr]    Compiling naga v24.0.0
[INFO] [stderr]    Compiling khronos-egl v6.0.0
[INFO] [stderr]     Checking bit-vec v0.8.0
[INFO] [stderr]    Compiling ash v0.38.0+1.3.281
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking bit-set v0.8.0
[INFO] [stderr]    Compiling wgpu-hal v24.0.0
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking hexf-parse v0.2.1
[INFO] [stderr]     Checking unicode-xid v0.2.6
[INFO] [stderr]     Checking raw-window-handle v0.6.2
[INFO] [stderr]    Compiling smithay-client-toolkit v0.18.1
[INFO] [stderr]     Checking cursor-icon v1.1.0
[INFO] [stderr]     Checking ttf-parser v0.25.1
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking memmap2 v0.9.5
[INFO] [stderr]    Compiling wgpu-core v24.0.0
[INFO] [stderr]     Checking indexmap v2.7.1
[INFO] [stderr]    Compiling quote v1.0.38
[INFO] [stderr]     Checking glow v0.16.0
[INFO] [stderr]    Compiling litrs v0.4.1
[INFO] [stderr]    Compiling syn v2.0.98
[INFO] [stderr]     Checking profiling v1.0.16
[INFO] [stderr]     Checking renderdoc-sys v1.1.0
[INFO] [stderr]     Checking ab_glyph_rasterizer v0.1.8
[INFO] [stderr]    Compiling winit v0.29.15
[INFO] [stderr]    Compiling wayland-scanner v0.31.6
[INFO] [stderr]     Checking regex-automata v0.4.9
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]    Compiling wgpu v24.0.1
[INFO] [stderr]     Checking as-raw-xcb-connection v1.0.1
[INFO] [stderr]     Checking x11rb-protocol v0.13.1
[INFO] [stderr]     Checking x11-dl v2.21.0
[INFO] [stderr]     Checking ordered-float v4.6.0
[INFO] [stderr]     Checking is-terminal v0.4.15
[INFO] [stderr]     Checking raw-window-handle v0.5.2
[INFO] [stderr]     Checking smol_str v0.2.2
[INFO] [stderr]     Checking pollster v0.3.0
[INFO] [stderr]    Compiling document-features v0.2.11
[INFO] [stderr]    Compiling wayland-backend v0.3.8
[INFO] [stderr]     Checking bitflags v2.8.0
[INFO] [stderr]     Checking owned_ttf_parser v0.25.0
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking spirv v0.3.0+sdk-1.3.268.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.2.0
[INFO] [stderr]     Checking wgpu-types v24.0.0
[INFO] [stderr]     Checking xkbcommon-dl v0.4.2
[INFO] [stderr]     Checking ab_glyph v0.2.29
[INFO] [stderr]     Checking gpu-descriptor v0.3.1
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking regex v1.11.1
[INFO] [stderr]     Checking env_logger v0.10.2
[INFO] [stderr]    Compiling bytemuck_derive v1.8.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling thiserror-impl v2.0.11
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking bytemuck v1.21.0
[INFO] [stderr]     Checking tiny-skia-path v0.11.4
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]     Checking tiny-skia v0.11.4
[INFO] [stderr]     Checking polling v3.7.4
[INFO] [stderr]     Checking calloop v0.12.4
[INFO] [stderr]     Checking wayland-csd-frame v0.3.0
[INFO] [stderr]     Checking wayland-protocols v0.31.2
[INFO] [stderr]     Checking calloop-wayland-source v0.2.0
[INFO] [stderr]     Checking wayland-cursor v0.31.8
[INFO] [stderr]     Checking x11rb v0.13.1
[INFO] [stderr]     Checking wayland-protocols-wlr v0.2.0
[INFO] [stderr]     Checking wayland-protocols-plasma v0.2.0
[INFO] [stderr]     Checking sctk-adwaita v0.8.3
[INFO] [stderr]     Checking pinceau_rs v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Neg`
[INFO] [stdout]  --> src/math/utils.rs:1:49
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{f32::consts::PI, ops::{Add, Div, Mul, Neg, Sub}};
[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: `Neg`
[INFO] [stdout]  --> src/math/utils.rs:1:49
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{f32::consts::PI, ops::{Add, Div, Mul, Neg, Sub}};
[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 variable: `event`
[INFO] [stdout]   --> src/state.rs:87:29
[INFO] [stdout]    |
[INFO] [stdout] 87 |     pub fn input(&mut self, event: &WindowEvent) -> bool {
[INFO] [stdout]    |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event`
[INFO] [stdout]   --> src/state.rs:87:29
[INFO] [stdout]    |
[INFO] [stdout] 87 |     pub fn input(&mut self, event: &WindowEvent) -> bool {
[INFO] [stdout]    |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_event`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `math::vec3::Vec3`
[INFO] [stdout]  --> src/main.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use math::vec3::Vec3;
[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: `math::mat4::Mat4`
[INFO] [stdout]  --> src/main.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use math::mat4::Mat4;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Neg`
[INFO] [stdout]  --> src/math/utils.rs:1:49
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{f32::consts::PI, ops::{Add, Div, Mul, Neg, Sub}};
[INFO] [stdout]   |                                                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `math::vec3::Vec3`
[INFO] [stdout]  --> src/main.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use math::vec3::Vec3;
[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: `math::mat4::Mat4`
[INFO] [stdout]  --> src/main.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use math::mat4::Mat4;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Neg`
[INFO] [stdout]  --> src/math/utils.rs:1:49
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{f32::consts::PI, ops::{Add, Div, Mul, Neg, Sub}};
[INFO] [stdout]   |                                                 ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Scalar` is never used
[INFO] [stdout]  --> src/math/utils.rs:3:11
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub trait Scalar:
[INFO] [stdout]   |           ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deg_to_rad` is never used
[INFO] [stdout]   --> src/math/utils.rs:44:8
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub fn deg_to_rad(deg: f32) -> f32 {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Vec3` is never constructed
[INFO] [stdout]  --> src/math/vec3.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct Vec3<T: Scalar> {
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `new` and `cross_vectors` are never used
[INFO] [stdout]   --> src/math/vec3.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl<T: Scalar> Vec3<T> {
[INFO] [stdout]    | ----------------------- associated functions in this implementation
[INFO] [stdout] 20 |     pub fn new(x: T, y: T, z: T) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn cross_vectors(a: &Self, b: &Self) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `dot` and `cross` are never used
[INFO] [stdout]   --> src/math/vec3.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | impl<T: Scalar> Vec3<T> {
[INFO] [stdout]    | ----------------------- methods in this implementation
[INFO] [stdout] 33 |     pub fn dot(&self, other: &Self) -> T {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn cross(&self, other: &Self) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `magnitude` and `normalize` are never used
[INFO] [stdout]    --> src/math/vec3.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 109 | impl Vec3<f32> {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] 110 |     pub fn magnitude(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 113 |     pub fn normalize(self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Mat4` is never constructed
[INFO] [stdout]   --> src/math/mat4.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct Mat4<T> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `new`, `zero`, `identity`, and `index` are never used
[INFO] [stdout]    --> src/math/mat4.rs:42:12
[INFO] [stdout]     |
[INFO] [stdout]  41 | impl<T: Scalar> Mat4<T> {
[INFO] [stdout]     | ----------------------- associated functions in this implementation
[INFO] [stdout]  42 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  67 |     pub fn zero() -> Self {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  88 |     pub fn identity() -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     fn index(row: usize, col: usize) -> usize {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `determinant`, `transpose`, and `extract_basis` are never used
[INFO] [stdout]    --> src/math/mat4.rs:116:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | impl<T: Scalar> Mat4<T> {
[INFO] [stdout]     | ----------------------- methods in this implementation
[INFO] [stdout] 116 |     pub fn determinant(&self) -> T {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn transpose(self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn extract_basis(&self) -> (Vec3<T>, Vec3<T>, Vec3<T>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/math/mat4.rs:164:12
[INFO] [stdout]     |
[INFO] [stdout] 163 | impl Mat4<f32> {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] 164 |     pub fn make_rotation_axis(axis: Vec3<f32>, angle: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 189 |     pub fn rotate(self, axis: Vec3<f32>, angle: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 192 |     pub fn make_scale(x: f32, y: f32, z: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 195 |     pub fn scale(self, x: f32, y: f32, z: f32) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 198 |     pub fn make_translation(x: f32, y: f32, z: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 201 |     pub fn translate(self, x: f32, y: f32, z: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub fn perspective(fov: f32, aspect: f32, near: f32, far: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn orthogonal(top: f32, right: f32, bottom: f32, left: f32, near: f32, far: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 252 |     pub fn invert(self) -> Option<Self> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Scalar` is never used
[INFO] [stdout]  --> src/math/utils.rs:3:11
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub trait Scalar:
[INFO] [stdout]   |           ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deg_to_rad` is never used
[INFO] [stdout]   --> src/math/utils.rs:44:8
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub fn deg_to_rad(deg: f32) -> f32 {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Vec3` is never constructed
[INFO] [stdout]  --> src/math/vec3.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct Vec3<T: Scalar> {
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `new` and `cross_vectors` are never used
[INFO] [stdout]   --> src/math/vec3.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl<T: Scalar> Vec3<T> {
[INFO] [stdout]    | ----------------------- associated functions in this implementation
[INFO] [stdout] 20 |     pub fn new(x: T, y: T, z: T) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn cross_vectors(a: &Self, b: &Self) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `dot` and `cross` are never used
[INFO] [stdout]   --> src/math/vec3.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | impl<T: Scalar> Vec3<T> {
[INFO] [stdout]    | ----------------------- methods in this implementation
[INFO] [stdout] 33 |     pub fn dot(&self, other: &Self) -> T {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn cross(&self, other: &Self) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `magnitude` and `normalize` are never used
[INFO] [stdout]    --> src/math/vec3.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 109 | impl Vec3<f32> {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] 110 |     pub fn magnitude(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 113 |     pub fn normalize(self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Mat4` is never constructed
[INFO] [stdout]   --> src/math/mat4.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct Mat4<T> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `new`, `zero`, `identity`, and `index` are never used
[INFO] [stdout]    --> src/math/mat4.rs:42:12
[INFO] [stdout]     |
[INFO] [stdout]  41 | impl<T: Scalar> Mat4<T> {
[INFO] [stdout]     | ----------------------- associated functions in this implementation
[INFO] [stdout]  42 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  67 |     pub fn zero() -> Self {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  88 |     pub fn identity() -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     fn index(row: usize, col: usize) -> usize {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `determinant`, `transpose`, and `extract_basis` are never used
[INFO] [stdout]    --> src/math/mat4.rs:116:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | impl<T: Scalar> Mat4<T> {
[INFO] [stdout]     | ----------------------- methods in this implementation
[INFO] [stdout] 116 |     pub fn determinant(&self) -> T {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn transpose(self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn extract_basis(&self) -> (Vec3<T>, Vec3<T>, Vec3<T>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/math/mat4.rs:164:12
[INFO] [stdout]     |
[INFO] [stdout] 163 | impl Mat4<f32> {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] 164 |     pub fn make_rotation_axis(axis: Vec3<f32>, angle: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 189 |     pub fn rotate(self, axis: Vec3<f32>, angle: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 192 |     pub fn make_scale(x: f32, y: f32, z: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 195 |     pub fn scale(self, x: f32, y: f32, z: f32) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 198 |     pub fn make_translation(x: f32, y: f32, z: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 201 |     pub fn translate(self, x: f32, y: f32, z: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub fn perspective(fov: f32, aspect: f32, near: f32, far: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     pub fn orthogonal(top: f32, right: f32, bottom: f32, left: f32, near: f32, far: f32) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 252 |     pub fn invert(self) -> Option<Self> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 55.43s
[INFO] running `Command { std: "docker" "inspect" "8b0befcc74c1c1afb056d255aae0d6a6f12c8eec085185010060abbf332c7979", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8b0befcc74c1c1afb056d255aae0d6a6f12c8eec085185010060abbf332c7979", kill_on_drop: false }`
[INFO] [stdout] 8b0befcc74c1c1afb056d255aae0d6a6f12c8eec085185010060abbf332c7979
