[INFO] cloning repository https://github.com/K-C-DaCosta/Software-Rasterizer
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/K-C-DaCosta/Software-Rasterizer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FK-C-DaCosta%2FSoftware-Rasterizer", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FK-C-DaCosta%2FSoftware-Rasterizer'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 0e3f299dd3a7da299781133d87eaea23f150bb27
[INFO] testing K-C-DaCosta/Software-Rasterizer against beta-2025-09-21 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FK-C-DaCosta%2FSoftware-Rasterizer" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-6-tc2/source/.cargo/config
[INFO] started tweaking git repo https://github.com/K-C-DaCosta/Software-Rasterizer
[INFO] finished tweaking git repo https://github.com/K-C-DaCosta/Software-Rasterizer
[INFO] tweaked toml for git repo https://github.com/K-C-DaCosta/Software-Rasterizer written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/K-C-DaCosta/Software-Rasterizer on toolchain beta-2025-09-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/K-C-DaCosta/Software-Rasterizer 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" "+beta-2025-09-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 1847041c5c649db42efc8c4449d940ca46a01adff07450dcb9d623b3642d002c
[INFO] running `Command { std: "docker" "start" "-a" "1847041c5c649db42efc8c4449d940ca46a01adff07450dcb9d623b3642d002c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "1847041c5c649db42efc8c4449d940ca46a01adff07450dcb9d623b3642d002c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1847041c5c649db42efc8c4449d940ca46a01adff07450dcb9d623b3642d002c", kill_on_drop: false }`
[INFO] [stdout] 1847041c5c649db42efc8c4449d940ca46a01adff07450dcb9d623b3642d002c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+beta-2025-09-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 25cb54a7e7aab9d5ff15ea7b56ddbd64dd00d832528ef58e847eb99bd3aa6d32
[INFO] running `Command { std: "docker" "start" "-a" "25cb54a7e7aab9d5ff15ea7b56ddbd64dd00d832528ef58e847eb99bd3aa6d32", kill_on_drop: false }`
[INFO] [stderr]    Compiling autocfg v1.0.0
[INFO] [stderr]    Compiling cfg-if v0.1.10
[INFO] [stderr]    Compiling libc v0.2.68
[INFO] [stderr]    Compiling libm v0.2.1
[INFO] [stderr]    Compiling proc-macro2 v1.0.10
[INFO] [stderr]    Compiling unicode-xid v0.2.0
[INFO] [stderr]    Compiling getrandom v0.1.14
[INFO] [stderr]    Compiling syn v1.0.17
[INFO] [stderr]    Compiling bitflags v1.2.1
[INFO] [stderr]    Compiling typenum v1.11.2
[INFO] [stderr]    Compiling byteorder v1.3.4
[INFO] [stderr]    Compiling proc-macro-hack v0.5.15
[INFO] [stderr]    Compiling ppv-lite86 v0.2.6
[INFO] [stderr]    Compiling crc32fast v1.2.0
[INFO] [stderr]    Compiling adler32 v1.0.4
[INFO] [stderr]    Compiling sdl2 v0.33.0
[INFO] [stderr]    Compiling sdl2-sys v0.33.0
[INFO] [stderr]    Compiling rawpointer v0.2.1
[INFO] [stderr]    Compiling inflate v0.4.5
[INFO] [stderr]    Compiling matrixmultiply v0.2.3
[INFO] [stderr]    Compiling lazy_static v1.4.0
[INFO] [stderr]    Compiling num-traits v0.2.11
[INFO] [stderr]    Compiling num-integer v0.1.42
[INFO] [stderr]    Compiling num-complex v0.2.4
[INFO] [stderr]    Compiling num-rational v0.2.4
[INFO] [stderr]    Compiling quote v1.0.3
[INFO] [stderr]    Compiling deflate v0.7.20
[INFO] [stderr]    Compiling generic-array v0.13.2
[INFO] [stderr]    Compiling rand_core v0.5.1
[INFO] [stderr]    Compiling png v0.15.3
[INFO] [stderr]    Compiling rand_chacha v0.2.2
[INFO] [stderr]    Compiling rand v0.7.3
[INFO] [stderr]    Compiling approx v0.3.2
[INFO] [stderr]    Compiling rand_distr v0.2.2
[INFO] [stderr]    Compiling paste-impl v0.1.10
[INFO] [stderr]    Compiling paste v0.1.10
[INFO] [stderr]    Compiling simba v0.1.2
[INFO] [stderr]    Compiling nalgebra v0.21.0
[INFO] [stderr]    Compiling software_rasterizer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `super::super::math_util::fixed_point::*`
[INFO] [stdout]  --> src/image/sampler.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use super::super::math_util::fixed_point::*; 
[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: `png::Transformations`
[INFO] [stdout]    --> src/image.rs:121:9
[INFO] [stdout]     |
[INFO] [stdout] 121 |     use png::Transformations;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LinearSampler2D` and `sampler`
[INFO] [stdout]   --> src/graphics.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |         sampler,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 14 |         sampler::{LinearSampler2D, NearestSampler2D, Sampler2D},
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp`
[INFO] [stdout]  --> src/math_util/geometry.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::cmp;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::*`
[INFO] [stdout]  --> src/system/video.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use sdl2::event::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode`
[INFO] [stdout]  --> src/system/video.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdl2::keyboard::Keycode;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Color`
[INFO] [stdout]  --> src/system/video.rs:8:20
[INFO] [stdout]   |
[INFO] [stdout] 8 | use sdl2::pixels::{Color, PixelFormatEnum};
[INFO] [stdout]   |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::rect::Rect`
[INFO] [stdout]   --> src/system/video.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use sdl2::rect::Rect;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Canvas`, `TextureAccess`, and `Texture`
[INFO] [stdout]   --> src/system/video.rs:12:20
[INFO] [stdout]    |
[INFO] [stdout] 12 | use sdl2::render::{Canvas, Texture, TextureAccess};
[INFO] [stdout]    |                    ^^^^^^  ^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cell::RefCell`
[INFO] [stdout]   --> src/system/video.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use std::cell::RefCell;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::rc::Rc`
[INFO] [stdout]   --> src/system/video.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use std::rc::Rc;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::slice`
[INFO] [stdout]   --> src/system/video.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::slice;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::mem`
[INFO] [stdout]   --> src/system/video.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use std::mem;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker`
[INFO] [stdout]   --> src/system/video.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use std::marker; 
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TiledBuffer2D`
[INFO] [stdout]  --> src/model.rs:5:31
[INFO] [stdout]   |
[INFO] [stdout] 5 |         buffer::{RowBuffer2D, TiledBuffer2D},
[INFO] [stdout]   |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Vector2`
[INFO] [stdout]   --> src/model.rs:11:31
[INFO] [stdout]    |
[INFO] [stdout] 11 | use nalgebra::{Matrix4, Unit, Vector2, Vector3, Vector4};
[INFO] [stdout]    |                               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `#[no_mangle]` attribute cannot be used on provided trait methods
[INFO] [stdout]    --> src/graphics.rs:566:5
[INFO] [stdout]     |
[INFO] [stdout] 566 |     #[no_mangle]
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = help: `#[no_mangle]` can be applied to functions, statics, inherent methods, and trait methods in impl blocks
[INFO] [stdout]     = note: `#[warn(unused_attributes)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `#[no_mangle]` attribute cannot be used on provided trait methods
[INFO] [stdout]    --> src/graphics.rs:690:5
[INFO] [stdout]     |
[INFO] [stdout] 690 |     #[no_mangle]
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = help: `#[no_mangle]` can be applied to functions, statics, inherent methods, and trait methods in impl blocks
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/model.rs:319:43
[INFO] [stdout]     |
[INFO] [stdout] 319 |                 println!("Error: {}", err.description());
[INFO] [stdout]     |                                           ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]   --> src/model.rs:14:24
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::io::{BufRead, Read};
[INFO] [stdout]    |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Buffer2D`
[INFO] [stdout]  --> src/model.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 6 |         Buffer2D,
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `w`
[INFO] [stdout]    --> src/image/buffer.rs:192:26
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout]     |                          ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, _w:i32,h:i32){
[INFO] [stdout]     |                          +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `TILE_RAD_SQRD`
[INFO] [stdout]     |
[INFO] [stdout] 192 -     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout] 192 +     fn resize(&mut self, graphics::Graphics::draw_triangle::TILE_RAD_SQRD:i32,h:i32){
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `h`
[INFO] [stdout]    --> src/image/buffer.rs:192:32
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout]     |                                ^
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, w:i32,_h:i32){
[INFO] [stdout]     |                                +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `TILE_RAD_SQRD`
[INFO] [stdout]     |
[INFO] [stdout] 192 -     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout] 192 +     fn resize(&mut self, w:i32,graphics::Graphics::draw_triangle::TILE_RAD_SQRD:i32){
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/image.rs:183:17
[INFO] [stdout]     |
[INFO] [stdout] 183 |     if let Some(mut texture) = result{
[INFO] [stdout]     |                 ----^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/graphics.rs:670:25
[INFO] [stdout]     |
[INFO] [stdout] 670 |                     let mut tl_tile_bary = fr + delta_x * (off_x as f32) + delta_y * (off_y as f32);
[INFO] [stdout]     |                         ----^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `f` is never read
[INFO] [stdout]    --> src/graphics.rs:721:18
[INFO] [stdout]     |
[INFO] [stdout] 721 |         let (mut f, mut fr) = (Vector4::zeros(), *fr);
[INFO] [stdout]     |                  ^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `grid_table`
[INFO] [stdout]    --> src/graphics.rs:734:13
[INFO] [stdout]     |
[INFO] [stdout] 734 |         let grid_table = [world_z_tl, world_z_tr, world_z_bl, world_z_br];
[INFO] [stdout]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_grid_table`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `points`
[INFO] [stdout]    --> src/graphics.rs:692:9
[INFO] [stdout]     |
[INFO] [stdout] 692 |         points: &mut [Vector4<f32>; 3],
[INFO] [stdout]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_points`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `glbs`
[INFO] [stdout]    --> src/graphics.rs:895:5
[INFO] [stdout]     |
[INFO] [stdout] 895 |     glbs: &ShaderGlobals,
[INFO] [stdout]     |     ^^^^ help: if this is intentional, prefix it with an underscore: `_glbs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TILE_RAD_SQRD` is never used
[INFO] [stdout]    --> src/graphics.rs:586:15
[INFO] [stdout]     |
[INFO] [stdout] 586 |         const TILE_RAD_SQRD: i32 = TILE_W * TILE_W / 4 + TILE_H * TILE_H / 4;
[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 `custom_frag_shader` is never used
[INFO] [stdout]    --> src/graphics.rs:891:4
[INFO] [stdout]     |
[INFO] [stdout] 891 | fn custom_frag_shader<BUF: Buffer2D<u32>>(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/system/video.rs:115:24
[INFO] [stdout]     |
[INFO] [stdout] 115 |     pub fn get_surface(&self) -> WindowSurfaceRef {
[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] 115 |     pub fn get_surface(&self) -> WindowSurfaceRef<'_> {
[INFO] [stdout]     |                                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/containers.rs:123:22
[INFO] [stdout]     |
[INFO] [stdout] 123 |     pub fn node_iter(&self)->DLLNodeIterator<T>{
[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] 123 |     pub fn node_iter(&self)->DLLNodeIterator<'_, T>{
[INFO] [stdout]     |                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/containers.rs:132:17
[INFO] [stdout]     |
[INFO] [stdout] 132 |     pub fn iter(&self) -> DLLIterator<T> {
[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] 132 |     pub fn iter(&self) -> DLLIterator<'_, T> {
[INFO] [stdout]     |                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::mem`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::mem;
[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: `std::thread`
[INFO] [stdout]  --> src/main.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::thread;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time`
[INFO] [stdout]  --> src/main.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::time;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `software_rasterizer::containers::*`
[INFO] [stdout]  --> src/main.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use software_rasterizer::containers::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Matrix4`, `Translation3`, and `Vector2`
[INFO] [stdout]   --> src/main.rs:11:16
[INFO] [stdout]    |
[INFO] [stdout] 11 | use nalgebra::{Matrix4, Rotation3, Translation3, Unit, Vector2, Vector3, Vector4};
[INFO] [stdout]    |                ^^^^^^^             ^^^^^^^^^^^^        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `software_rasterizer::math_util::fixed_point::*`
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use software_rasterizer::math_util::fixed_point::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LinearSampler2D` and `TiledBuffer2D`
[INFO] [stdout]   --> src/main.rs:20:31
[INFO] [stdout]    |
[INFO] [stdout] 20 |         buffer::{RowBuffer2D, TiledBuffer2D},
[INFO] [stdout]    |                               ^^^^^^^^^^^^^
[INFO] [stdout] 21 |         sampler::{LinearSampler2D, NearestSampler2D, Sampler2D},
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bounding`
[INFO] [stdout]   --> src/main.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     bounding::*,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `x_pos` is never read
[INFO] [stdout]    --> src/main.rs:217:9
[INFO] [stdout]     |
[INFO] [stdout] 217 |         x_pos = _mouse_state.x() as f32;
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `y_pos` is never read
[INFO] [stdout]    --> src/main.rs:218:9
[INFO] [stdout]     |
[INFO] [stdout] 218 |         y_pos = _mouse_state.y() as f32;
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary `unsafe` block
[INFO] [stdout]    --> src/main.rs:272:39
[INFO] [stdout]     |
[INFO] [stdout] 272 |                     Keycode::Space => unsafe {
[INFO] [stdout]     |                                       ^^^^^^ unnecessary `unsafe` block
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_unsafe)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary transmute
[INFO] [stdout]   --> src/main.rs:62:18
[INFO] [stdout]    |
[INFO] [stdout] 62 |         unsafe { std::mem::transmute((new_depth as i32 - current_depth as i32) >> 31) };
[INFO] [stdout]    |                  -------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                  |
[INFO] [stdout]    |                  help: replace this with: `i32::cast_unsigned`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unnecessary_transmutes)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 17.87s
[INFO] running `Command { std: "docker" "inspect" "25cb54a7e7aab9d5ff15ea7b56ddbd64dd00d832528ef58e847eb99bd3aa6d32", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "25cb54a7e7aab9d5ff15ea7b56ddbd64dd00d832528ef58e847eb99bd3aa6d32", kill_on_drop: false }`
[INFO] [stdout] 25cb54a7e7aab9d5ff15ea7b56ddbd64dd00d832528ef58e847eb99bd3aa6d32
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+beta-2025-09-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c1bf50e089000884b55e67535cdb03996ea5d5d8d507c2d50d236817c6e40e79
[INFO] running `Command { std: "docker" "start" "-a" "c1bf50e089000884b55e67535cdb03996ea5d5d8d507c2d50d236817c6e40e79", kill_on_drop: false }`
[INFO] [stdout] warning: unused import: `super::super::math_util::fixed_point::*`
[INFO] [stdout]  --> src/image/sampler.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use super::super::math_util::fixed_point::*; 
[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: `png::Transformations`
[INFO] [stdout]    --> src/image.rs:121:9
[INFO] [stdout]     |
[INFO] [stdout] 121 |     use png::Transformations;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LinearSampler2D` and `sampler`
[INFO] [stdout]   --> src/graphics.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |         sampler,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 14 |         sampler::{LinearSampler2D, NearestSampler2D, Sampler2D},
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp`
[INFO] [stdout]  --> src/math_util/geometry.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::cmp;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::*`
[INFO] [stdout]  --> src/system/video.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use sdl2::event::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode`
[INFO] [stdout]  --> src/system/video.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdl2::keyboard::Keycode;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Color`
[INFO] [stdout]  --> src/system/video.rs:8:20
[INFO] [stdout]   |
[INFO] [stdout] 8 | use sdl2::pixels::{Color, PixelFormatEnum};
[INFO] [stdout]   |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::rect::Rect`
[INFO] [stdout]   --> src/system/video.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use sdl2::rect::Rect;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Canvas`, `TextureAccess`, and `Texture`
[INFO] [stdout]   --> src/system/video.rs:12:20
[INFO] [stdout]    |
[INFO] [stdout] 12 | use sdl2::render::{Canvas, Texture, TextureAccess};
[INFO] [stdout]    |                    ^^^^^^  ^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cell::RefCell`
[INFO] [stdout]   --> src/system/video.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use std::cell::RefCell;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::rc::Rc`
[INFO] [stdout]   --> src/system/video.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use std::rc::Rc;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::slice`
[INFO] [stdout]   --> src/system/video.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::slice;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling software_rasterizer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::mem`
[INFO] [stdout]   --> src/system/video.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use std::mem;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker`
[INFO] [stdout]   --> src/system/video.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use std::marker; 
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TiledBuffer2D`
[INFO] [stdout]  --> src/model.rs:5:31
[INFO] [stdout]   |
[INFO] [stdout] 5 |         buffer::{RowBuffer2D, TiledBuffer2D},
[INFO] [stdout]   |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Vector2`
[INFO] [stdout]   --> src/model.rs:11:31
[INFO] [stdout]    |
[INFO] [stdout] 11 | use nalgebra::{Matrix4, Unit, Vector2, Vector3, Vector4};
[INFO] [stdout]    |                               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `#[no_mangle]` attribute cannot be used on provided trait methods
[INFO] [stdout]    --> src/graphics.rs:566:5
[INFO] [stdout]     |
[INFO] [stdout] 566 |     #[no_mangle]
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = help: `#[no_mangle]` can be applied to functions, statics, inherent methods, and trait methods in impl blocks
[INFO] [stdout]     = note: `#[warn(unused_attributes)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `#[no_mangle]` attribute cannot be used on provided trait methods
[INFO] [stdout]    --> src/graphics.rs:690:5
[INFO] [stdout]     |
[INFO] [stdout] 690 |     #[no_mangle]
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = help: `#[no_mangle]` can be applied to functions, statics, inherent methods, and trait methods in impl blocks
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/model.rs:319:43
[INFO] [stdout]     |
[INFO] [stdout] 319 |                 println!("Error: {}", err.description());
[INFO] [stdout]     |                                           ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]   --> src/model.rs:14:24
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::io::{BufRead, Read};
[INFO] [stdout]    |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Buffer2D`
[INFO] [stdout]  --> src/model.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 6 |         Buffer2D,
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `w`
[INFO] [stdout]    --> src/image/buffer.rs:192:26
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout]     |                          ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, _w:i32,h:i32){
[INFO] [stdout]     |                          +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `TILE_RAD_SQRD`
[INFO] [stdout]     |
[INFO] [stdout] 192 -     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout] 192 +     fn resize(&mut self, graphics::Graphics::draw_triangle::TILE_RAD_SQRD:i32,h:i32){
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `h`
[INFO] [stdout]    --> src/image/buffer.rs:192:32
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout]     |                                ^
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, w:i32,_h:i32){
[INFO] [stdout]     |                                +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `TILE_RAD_SQRD`
[INFO] [stdout]     |
[INFO] [stdout] 192 -     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout] 192 +     fn resize(&mut self, w:i32,graphics::Graphics::draw_triangle::TILE_RAD_SQRD:i32){
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/image.rs:183:17
[INFO] [stdout]     |
[INFO] [stdout] 183 |     if let Some(mut texture) = result{
[INFO] [stdout]     |                 ----^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/graphics.rs:670:25
[INFO] [stdout]     |
[INFO] [stdout] 670 |                     let mut tl_tile_bary = fr + delta_x * (off_x as f32) + delta_y * (off_y as f32);
[INFO] [stdout]     |                         ----^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `f` is never read
[INFO] [stdout]    --> src/graphics.rs:721:18
[INFO] [stdout]     |
[INFO] [stdout] 721 |         let (mut f, mut fr) = (Vector4::zeros(), *fr);
[INFO] [stdout]     |                  ^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `grid_table`
[INFO] [stdout]    --> src/graphics.rs:734:13
[INFO] [stdout]     |
[INFO] [stdout] 734 |         let grid_table = [world_z_tl, world_z_tr, world_z_bl, world_z_br];
[INFO] [stdout]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_grid_table`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `points`
[INFO] [stdout]    --> src/graphics.rs:692:9
[INFO] [stdout]     |
[INFO] [stdout] 692 |         points: &mut [Vector4<f32>; 3],
[INFO] [stdout]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_points`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `glbs`
[INFO] [stdout]    --> src/graphics.rs:895:5
[INFO] [stdout]     |
[INFO] [stdout] 895 |     glbs: &ShaderGlobals,
[INFO] [stdout]     |     ^^^^ help: if this is intentional, prefix it with an underscore: `_glbs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TILE_RAD_SQRD` is never used
[INFO] [stdout]    --> src/graphics.rs:586:15
[INFO] [stdout]     |
[INFO] [stdout] 586 |         const TILE_RAD_SQRD: i32 = TILE_W * TILE_W / 4 + TILE_H * TILE_H / 4;
[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 `custom_frag_shader` is never used
[INFO] [stdout]    --> src/graphics.rs:891:4
[INFO] [stdout]     |
[INFO] [stdout] 891 | fn custom_frag_shader<BUF: Buffer2D<u32>>(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/system/video.rs:115:24
[INFO] [stdout]     |
[INFO] [stdout] 115 |     pub fn get_surface(&self) -> WindowSurfaceRef {
[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] 115 |     pub fn get_surface(&self) -> WindowSurfaceRef<'_> {
[INFO] [stdout]     |                                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/containers.rs:123:22
[INFO] [stdout]     |
[INFO] [stdout] 123 |     pub fn node_iter(&self)->DLLNodeIterator<T>{
[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] 123 |     pub fn node_iter(&self)->DLLNodeIterator<'_, T>{
[INFO] [stdout]     |                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/containers.rs:132:17
[INFO] [stdout]     |
[INFO] [stdout] 132 |     pub fn iter(&self) -> DLLIterator<T> {
[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] 132 |     pub fn iter(&self) -> DLLIterator<'_, T> {
[INFO] [stdout]     |                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::mem`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::mem;
[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: `std::thread`
[INFO] [stdout]  --> src/main.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::thread;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time`
[INFO] [stdout]  --> src/main.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::time;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `software_rasterizer::containers::*`
[INFO] [stdout]  --> src/main.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use software_rasterizer::containers::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Matrix4`, `Translation3`, and `Vector2`
[INFO] [stdout]   --> src/main.rs:11:16
[INFO] [stdout]    |
[INFO] [stdout] 11 | use nalgebra::{Matrix4, Rotation3, Translation3, Unit, Vector2, Vector3, Vector4};
[INFO] [stdout]    |                ^^^^^^^             ^^^^^^^^^^^^        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `software_rasterizer::math_util::fixed_point::*`
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use software_rasterizer::math_util::fixed_point::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LinearSampler2D` and `TiledBuffer2D`
[INFO] [stdout]   --> src/main.rs:20:31
[INFO] [stdout]    |
[INFO] [stdout] 20 |         buffer::{RowBuffer2D, TiledBuffer2D},
[INFO] [stdout]    |                               ^^^^^^^^^^^^^
[INFO] [stdout] 21 |         sampler::{LinearSampler2D, NearestSampler2D, Sampler2D},
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::super::math_util::fixed_point::*`
[INFO] [stdout]  --> src/image/sampler.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use super::super::math_util::fixed_point::*; 
[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: `png::Transformations`
[INFO] [stdout]    --> src/image.rs:121:9
[INFO] [stdout]     |
[INFO] [stdout] 121 |     use png::Transformations;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LinearSampler2D` and `sampler`
[INFO] [stdout]   --> src/graphics.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |         sampler,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 14 |         sampler::{LinearSampler2D, NearestSampler2D, Sampler2D},
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp`
[INFO] [stdout]  --> src/math_util/geometry.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::cmp;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bounding`
[INFO] [stdout]   --> src/main.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     bounding::*,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::*`
[INFO] [stdout]  --> src/system/video.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use sdl2::event::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode`
[INFO] [stdout]  --> src/system/video.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdl2::keyboard::Keycode;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Color`
[INFO] [stdout]  --> src/system/video.rs:8:20
[INFO] [stdout]   |
[INFO] [stdout] 8 | use sdl2::pixels::{Color, PixelFormatEnum};
[INFO] [stdout]   |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::rect::Rect`
[INFO] [stdout]   --> src/system/video.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use sdl2::rect::Rect;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Canvas`, `TextureAccess`, and `Texture`
[INFO] [stdout]   --> src/system/video.rs:12:20
[INFO] [stdout]    |
[INFO] [stdout] 12 | use sdl2::render::{Canvas, Texture, TextureAccess};
[INFO] [stdout]    |                    ^^^^^^  ^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `x_pos` is never read
[INFO] [stdout]    --> src/main.rs:217:9
[INFO] [stdout]     |
[INFO] [stdout] 217 |         x_pos = _mouse_state.x() as f32;
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `y_pos` is never read
[INFO] [stdout]    --> src/main.rs:218:9
[INFO] [stdout]     |
[INFO] [stdout] 218 |         y_pos = _mouse_state.y() as f32;
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cell::RefCell`
[INFO] [stdout]   --> src/system/video.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use std::cell::RefCell;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::rc::Rc`
[INFO] [stdout]   --> src/system/video.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use std::rc::Rc;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::slice`
[INFO] [stdout]   --> src/system/video.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::slice;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::mem`
[INFO] [stdout]   --> src/system/video.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use std::mem;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker`
[INFO] [stdout]   --> src/system/video.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use std::marker; 
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TiledBuffer2D`
[INFO] [stdout]  --> src/model.rs:5:31
[INFO] [stdout]   |
[INFO] [stdout] 5 |         buffer::{RowBuffer2D, TiledBuffer2D},
[INFO] [stdout]   |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Vector2`
[INFO] [stdout]   --> src/model.rs:11:31
[INFO] [stdout]    |
[INFO] [stdout] 11 | use nalgebra::{Matrix4, Unit, Vector2, Vector3, Vector4};
[INFO] [stdout]    |                               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary `unsafe` block
[INFO] [stdout]    --> src/main.rs:272:39
[INFO] [stdout]     |
[INFO] [stdout] 272 |                     Keycode::Space => unsafe {
[INFO] [stdout]     |                                       ^^^^^^ unnecessary `unsafe` block
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_unsafe)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary transmute
[INFO] [stdout]   --> src/main.rs:62:18
[INFO] [stdout]    |
[INFO] [stdout] 62 |         unsafe { std::mem::transmute((new_depth as i32 - current_depth as i32) >> 31) };
[INFO] [stdout]    |                  -------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                  |
[INFO] [stdout]    |                  help: replace this with: `i32::cast_unsigned`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unnecessary_transmutes)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `#[no_mangle]` attribute cannot be used on provided trait methods
[INFO] [stdout]    --> src/graphics.rs:566:5
[INFO] [stdout]     |
[INFO] [stdout] 566 |     #[no_mangle]
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = help: `#[no_mangle]` can be applied to functions, statics, inherent methods, and trait methods in impl blocks
[INFO] [stdout]     = note: `#[warn(unused_attributes)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `#[no_mangle]` attribute cannot be used on provided trait methods
[INFO] [stdout]    --> src/graphics.rs:690:5
[INFO] [stdout]     |
[INFO] [stdout] 690 |     #[no_mangle]
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = help: `#[no_mangle]` can be applied to functions, statics, inherent methods, and trait methods in impl blocks
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stdout]    --> src/model.rs:319:43
[INFO] [stdout]     |
[INFO] [stdout] 319 |                 println!("Error: {}", err.description());
[INFO] [stdout]     |                                           ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]   --> src/model.rs:14:24
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::io::{BufRead, Read};
[INFO] [stdout]    |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Buffer2D`
[INFO] [stdout]  --> src/model.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 6 |         Buffer2D,
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `w`
[INFO] [stdout]    --> src/image/buffer.rs:192:26
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout]     |                          ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, _w:i32,h:i32){
[INFO] [stdout]     |                          +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `TILE_RAD_SQRD`
[INFO] [stdout]     |
[INFO] [stdout] 192 -     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout] 192 +     fn resize(&mut self, graphics::Graphics::draw_triangle::TILE_RAD_SQRD:i32,h:i32){
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `h`
[INFO] [stdout]    --> src/image/buffer.rs:192:32
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout]     |                                ^
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 192 |     fn resize(&mut self, w:i32,_h:i32){
[INFO] [stdout]     |                                +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `TILE_RAD_SQRD`
[INFO] [stdout]     |
[INFO] [stdout] 192 -     fn resize(&mut self, w:i32,h:i32){
[INFO] [stdout] 192 +     fn resize(&mut self, w:i32,graphics::Graphics::draw_triangle::TILE_RAD_SQRD:i32){
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/image.rs:183:17
[INFO] [stdout]     |
[INFO] [stdout] 183 |     if let Some(mut texture) = result{
[INFO] [stdout]     |                 ----^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/graphics.rs:670:25
[INFO] [stdout]     |
[INFO] [stdout] 670 |                     let mut tl_tile_bary = fr + delta_x * (off_x as f32) + delta_y * (off_y as f32);
[INFO] [stdout]     |                         ----^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `f` is never read
[INFO] [stdout]    --> src/graphics.rs:721:18
[INFO] [stdout]     |
[INFO] [stdout] 721 |         let (mut f, mut fr) = (Vector4::zeros(), *fr);
[INFO] [stdout]     |                  ^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `grid_table`
[INFO] [stdout]    --> src/graphics.rs:734:13
[INFO] [stdout]     |
[INFO] [stdout] 734 |         let grid_table = [world_z_tl, world_z_tr, world_z_bl, world_z_br];
[INFO] [stdout]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_grid_table`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `points`
[INFO] [stdout]    --> src/graphics.rs:692:9
[INFO] [stdout]     |
[INFO] [stdout] 692 |         points: &mut [Vector4<f32>; 3],
[INFO] [stdout]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_points`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `glbs`
[INFO] [stdout]    --> src/graphics.rs:895:5
[INFO] [stdout]     |
[INFO] [stdout] 895 |     glbs: &ShaderGlobals,
[INFO] [stdout]     |     ^^^^ help: if this is intentional, prefix it with an underscore: `_glbs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TILE_RAD_SQRD` is never used
[INFO] [stdout]    --> src/graphics.rs:586:15
[INFO] [stdout]     |
[INFO] [stdout] 586 |         const TILE_RAD_SQRD: i32 = TILE_W * TILE_W / 4 + TILE_H * TILE_H / 4;
[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 `custom_frag_shader` is never used
[INFO] [stdout]    --> src/graphics.rs:891:4
[INFO] [stdout]     |
[INFO] [stdout] 891 | fn custom_frag_shader<BUF: Buffer2D<u32>>(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/system/video.rs:115:24
[INFO] [stdout]     |
[INFO] [stdout] 115 |     pub fn get_surface(&self) -> WindowSurfaceRef {
[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] 115 |     pub fn get_surface(&self) -> WindowSurfaceRef<'_> {
[INFO] [stdout]     |                                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/containers.rs:123:22
[INFO] [stdout]     |
[INFO] [stdout] 123 |     pub fn node_iter(&self)->DLLNodeIterator<T>{
[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] 123 |     pub fn node_iter(&self)->DLLNodeIterator<'_, T>{
[INFO] [stdout]     |                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/containers.rs:132:17
[INFO] [stdout]     |
[INFO] [stdout] 132 |     pub fn iter(&self) -> DLLIterator<T> {
[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] 132 |     pub fn iter(&self) -> DLLIterator<'_, T> {
[INFO] [stdout]     |                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.17s
[INFO] running `Command { std: "docker" "inspect" "c1bf50e089000884b55e67535cdb03996ea5d5d8d507c2d50d236817c6e40e79", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c1bf50e089000884b55e67535cdb03996ea5d5d8d507c2d50d236817c6e40e79", kill_on_drop: false }`
[INFO] [stdout] c1bf50e089000884b55e67535cdb03996ea5d5d8d507c2d50d236817c6e40e79
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+beta-2025-09-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] ea3d9602a4dad7913c6d34bd562ede4d54ace635edea8a0a16bb54f105193d13
[INFO] running `Command { std: "docker" "start" "-a" "ea3d9602a4dad7913c6d34bd562ede4d54ace635edea8a0a16bb54f105193d13", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `super::super::math_util::fixed_point::*`
[INFO] [stderr]  --> src/image/sampler.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use super::super::math_util::fixed_point::*; 
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `png::Transformations`
[INFO] [stderr]    --> src/image.rs:121:9
[INFO] [stderr]     |
[INFO] [stderr] 121 |     use png::Transformations;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `LinearSampler2D` and `sampler`
[INFO] [stderr]   --> src/graphics.rs:13:9
[INFO] [stderr]    |
[INFO] [stderr] 13 |         sampler,
[INFO] [stderr]    |         ^^^^^^^
[INFO] [stderr] 14 |         sampler::{LinearSampler2D, NearestSampler2D, Sampler2D},
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::cmp`
[INFO] [stderr]  --> src/math_util/geometry.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use std::cmp;
[INFO] [stderr]   |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `sdl2::event::*`
[INFO] [stderr]  --> src/system/video.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use sdl2::event::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `sdl2::keyboard::Keycode`
[INFO] [stderr]  --> src/system/video.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use sdl2::keyboard::Keycode;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Color`
[INFO] [stderr]  --> src/system/video.rs:8:20
[INFO] [stderr]   |
[INFO] [stderr] 8 | use sdl2::pixels::{Color, PixelFormatEnum};
[INFO] [stderr]   |                    ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `sdl2::rect::Rect`
[INFO] [stderr]   --> src/system/video.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use sdl2::rect::Rect;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Canvas`, `TextureAccess`, and `Texture`
[INFO] [stderr]   --> src/system/video.rs:12:20
[INFO] [stderr]    |
[INFO] [stderr] 12 | use sdl2::render::{Canvas, Texture, TextureAccess};
[INFO] [stderr]    |                    ^^^^^^  ^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::cell::RefCell`
[INFO] [stderr]   --> src/system/video.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 16 | use std::cell::RefCell;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::rc::Rc`
[INFO] [stderr]   --> src/system/video.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr] 17 | use std::rc::Rc;
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::slice`
[INFO] [stderr]   --> src/system/video.rs:19:5
[INFO] [stderr]    |
[INFO] [stderr] 19 | use std::slice;
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::mem`
[INFO] [stderr]   --> src/system/video.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 21 | use std::mem;
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::marker`
[INFO] [stderr]   --> src/system/video.rs:22:5
[INFO] [stderr]    |
[INFO] [stderr] 22 | use std::marker; 
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `TiledBuffer2D`
[INFO] [stderr]  --> src/model.rs:5:31
[INFO] [stderr]   |
[INFO] [stderr] 5 |         buffer::{RowBuffer2D, TiledBuffer2D},
[INFO] [stderr]   |                               ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Vector2`
[INFO] [stderr]   --> src/model.rs:11:31
[INFO] [stderr]    |
[INFO] [stderr] 11 | use nalgebra::{Matrix4, Unit, Vector2, Vector3, Vector4};
[INFO] [stderr]    |                               ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `#[no_mangle]` attribute cannot be used on provided trait methods
[INFO] [stderr]    --> src/graphics.rs:566:5
[INFO] [stderr]     |
[INFO] [stderr] 566 |     #[no_mangle]
[INFO] [stderr]     |     ^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = help: `#[no_mangle]` can be applied to functions, statics, inherent methods, and trait methods in impl blocks
[INFO] [stderr]     = note: `#[warn(unused_attributes)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `#[no_mangle]` attribute cannot be used on provided trait methods
[INFO] [stderr]    --> src/graphics.rs:690:5
[INFO] [stderr]     |
[INFO] [stderr] 690 |     #[no_mangle]
[INFO] [stderr]     |     ^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = help: `#[no_mangle]` can be applied to functions, statics, inherent methods, and trait methods in impl blocks
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `std::error::Error::description`: use the Display impl or to_string()
[INFO] [stderr]    --> src/model.rs:319:43
[INFO] [stderr]     |
[INFO] [stderr] 319 |                 println!("Error: {}", err.description());
[INFO] [stderr]     |                                           ^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Read`
[INFO] [stderr]   --> src/model.rs:14:24
[INFO] [stderr]    |
[INFO] [stderr] 14 | use std::io::{BufRead, Read};
[INFO] [stderr]    |                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Buffer2D`
[INFO] [stderr]  --> src/model.rs:6:9
[INFO] [stderr]   |
[INFO] [stderr] 6 |         Buffer2D,
[INFO] [stderr]   |         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `w`
[INFO] [stderr]    --> src/image/buffer.rs:192:26
[INFO] [stderr]     |
[INFO] [stderr] 192 |     fn resize(&mut self, w:i32,h:i32){
[INFO] [stderr]     |                          ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]     |
[INFO] [stderr] 192 |     fn resize(&mut self, _w:i32,h:i32){
[INFO] [stderr]     |                          +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named constant `TILE_RAD_SQRD`
[INFO] [stderr]     |
[INFO] [stderr] 192 -     fn resize(&mut self, w:i32,h:i32){
[INFO] [stderr] 192 +     fn resize(&mut self, graphics::Graphics::draw_triangle::TILE_RAD_SQRD:i32,h:i32){
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `h`
[INFO] [stderr]    --> src/image/buffer.rs:192:32
[INFO] [stderr]     |
[INFO] [stderr] 192 |     fn resize(&mut self, w:i32,h:i32){
[INFO] [stderr]     |                                ^
[INFO] [stderr]     |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]     |
[INFO] [stderr] 192 |     fn resize(&mut self, w:i32,_h:i32){
[INFO] [stderr]     |                                +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named constant `TILE_RAD_SQRD`
[INFO] [stderr]     |
[INFO] [stderr] 192 -     fn resize(&mut self, w:i32,h:i32){
[INFO] [stderr] 192 +     fn resize(&mut self, w:i32,graphics::Graphics::draw_triangle::TILE_RAD_SQRD:i32){
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/image.rs:183:17
[INFO] [stderr]     |
[INFO] [stderr] 183 |     if let Some(mut texture) = result{
[INFO] [stderr]     |                 ----^^^^^^^
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/graphics.rs:670:25
[INFO] [stderr]     |
[INFO] [stderr] 670 |                     let mut tl_tile_bary = fr + delta_x * (off_x as f32) + delta_y * (off_y as f32);
[INFO] [stderr]     |                         ----^^^^^^^^^^^^
[INFO] [stderr]     |                         |
[INFO] [stderr]     |                         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `f` is never read
[INFO] [stderr]    --> src/graphics.rs:721:18
[INFO] [stderr]     |
[INFO] [stderr] 721 |         let (mut f, mut fr) = (Vector4::zeros(), *fr);
[INFO] [stderr]     |                  ^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `grid_table`
[INFO] [stderr]    --> src/graphics.rs:734:13
[INFO] [stderr]     |
[INFO] [stderr] 734 |         let grid_table = [world_z_tl, world_z_tr, world_z_bl, world_z_br];
[INFO] [stderr]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_grid_table`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `points`
[INFO] [stderr]    --> src/graphics.rs:692:9
[INFO] [stderr]     |
[INFO] [stderr] 692 |         points: &mut [Vector4<f32>; 3],
[INFO] [stderr]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_points`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `glbs`
[INFO] [stderr]    --> src/graphics.rs:895:5
[INFO] [stderr]     |
[INFO] [stderr] 895 |     glbs: &ShaderGlobals,
[INFO] [stderr]     |     ^^^^ help: if this is intentional, prefix it with an underscore: `_glbs`
[INFO] [stderr] 
[INFO] [stderr] warning: constant `TILE_RAD_SQRD` is never used
[INFO] [stderr]    --> src/graphics.rs:586:15
[INFO] [stderr]     |
[INFO] [stderr] 586 |         const TILE_RAD_SQRD: i32 = TILE_W * TILE_W / 4 + TILE_H * TILE_H / 4;
[INFO] [stderr]     |               ^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `custom_frag_shader` is never used
[INFO] [stderr]    --> src/graphics.rs:891:4
[INFO] [stderr]     |
[INFO] [stderr] 891 | fn custom_frag_shader<BUF: Buffer2D<u32>>(
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/system/video.rs:115:24
[INFO] [stderr]     |
[INFO] [stderr] 115 |     pub fn get_surface(&self) -> WindowSurfaceRef {
[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] 115 |     pub fn get_surface(&self) -> WindowSurfaceRef<'_> {
[INFO] [stderr]     |                                                  ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/containers.rs:123:22
[INFO] [stderr]     |
[INFO] [stderr] 123 |     pub fn node_iter(&self)->DLLNodeIterator<T>{
[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] 123 |     pub fn node_iter(&self)->DLLNodeIterator<'_, T>{
[INFO] [stderr]     |                                              +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/containers.rs:132:17
[INFO] [stderr]     |
[INFO] [stderr] 132 |     pub fn iter(&self) -> DLLIterator<T> {
[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] 132 |     pub fn iter(&self) -> DLLIterator<'_, T> {
[INFO] [stderr]     |                                       +++
[INFO] [stderr] 
[INFO] [stderr] warning: `software_rasterizer` (lib) generated 34 warnings (run `cargo fix --lib -p software_rasterizer` to apply 25 suggestions)
[INFO] [stderr] warning: `software_rasterizer` (lib test) generated 34 warnings (34 duplicates)
[INFO] [stderr] warning: unused import: `std::mem`
[INFO] [stderr]  --> src/main.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use std::mem;
[INFO] [stderr]   |     ^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::thread`
[INFO] [stderr]  --> src/main.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use std::thread;
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::time`
[INFO] [stderr]  --> src/main.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use std::time;
[INFO] [stderr]   |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `software_rasterizer::containers::*`
[INFO] [stderr]  --> src/main.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 | use software_rasterizer::containers::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Matrix4`, `Translation3`, and `Vector2`
[INFO] [stderr]   --> src/main.rs:11:16
[INFO] [stderr]    |
[INFO] [stderr] 11 | use nalgebra::{Matrix4, Rotation3, Translation3, Unit, Vector2, Vector3, Vector4};
[INFO] [stderr]    |                ^^^^^^^             ^^^^^^^^^^^^        ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `software_rasterizer::math_util::fixed_point::*`
[INFO] [stderr]   --> src/main.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | use software_rasterizer::math_util::fixed_point::*;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `LinearSampler2D` and `TiledBuffer2D`
[INFO] [stderr]   --> src/main.rs:20:31
[INFO] [stderr]    |
[INFO] [stderr] 20 |         buffer::{RowBuffer2D, TiledBuffer2D},
[INFO] [stderr]    |                               ^^^^^^^^^^^^^
[INFO] [stderr] 21 |         sampler::{LinearSampler2D, NearestSampler2D, Sampler2D},
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `bounding`
[INFO] [stderr]   --> src/main.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 |     bounding::*,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `x_pos` is never read
[INFO] [stderr]    --> src/main.rs:217:9
[INFO] [stderr]     |
[INFO] [stderr] 217 |         x_pos = _mouse_state.x() as f32;
[INFO] [stderr]     |         ^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `y_pos` is never read
[INFO] [stderr]    --> src/main.rs:218:9
[INFO] [stderr]     |
[INFO] [stderr] 218 |         y_pos = _mouse_state.y() as f32;
[INFO] [stderr]     |         ^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary `unsafe` block
[INFO] [stderr]    --> src/main.rs:272:39
[INFO] [stderr]     |
[INFO] [stderr] 272 |                     Keycode::Space => unsafe {
[INFO] [stderr]     |                                       ^^^^^^ unnecessary `unsafe` block
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_unsafe)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary transmute
[INFO] [stderr]   --> src/main.rs:62:18
[INFO] [stderr]    |
[INFO] [stderr] 62 |         unsafe { std::mem::transmute((new_depth as i32 - current_depth as i32) >> 31) };
[INFO] [stderr]    |                  -------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |                  |
[INFO] [stderr]    |                  help: replace this with: `i32::cast_unsigned`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unnecessary_transmutes)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `software_rasterizer` (bin "software_rasterizer" test) generated 12 warnings (run `cargo fix --bin "software_rasterizer" --tests` to apply 8 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.04s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/software_rasterizer-60e8dd50bc09369c)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test containers::dll_test1 ... ok
[INFO] [stdout] test math_util::math_tests::fixed_point_tests::convertion_test ... FAILED
[INFO] [stdout] test image::buffer::buffer_tests::tile2d_test ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- math_util::math_tests::fixed_point_tests::convertion_test stdout ----
[INFO] [stdout] 
[INFO] [stdout]   ┌              ┐
[INFO] [stdout]   │ 0.0000000000 │
[INFO] [stdout]   │ 7.0000000000 │
[INFO] [stdout]   │ 0.0000000000 │
[INFO] [stdout]   │ 0.8999999762 │
[INFO] [stdout]   └              ┘
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] thread 'math_util::math_tests::fixed_point_tests::convertion_test' (27) panicked at src/math_util/math_tests/fixed_point_tests.rs:29:5:
[INFO] [stdout] test not implemented
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5ce61fcc5542 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5ce61fcc5542 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5ce61fcc5542 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5ce61fcc5542 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h67edf0e4d33c343c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5ce61fcd5e7f - core::fmt::rt::Argument::fmt::hef94184842aeafdd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5ce61fcd5e7f - core::fmt::write::hcf0c66b48a8fa606
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x5ce61fc929a1 - std::io::default_write_fmt::h69967ac0ba93195f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5ce61fc929a1 - std::io::Write::write_fmt::h8db9396209deaa1c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5ce61fc9ea02 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5ce61fca35af - std::panicking::default_hook::{{closure}}::h91001850288db5f7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x5ce61fca3441 - std::panicking::default_hook::h2346dbb704ef5512
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x5ce61fc622fe - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h18383b2e29377420
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   12:     0x5ce61fc622fe - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5ce61fca3c6f - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h6dba6e441651a0d1
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   14:     0x5ce61fca3c6f - std::panicking::panic_with_hook::hd2b063a6090d23a4
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x5ce61fca32bc - std::panicking::begin_panic::{{closure}}::h03764aec75fd6fbf
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:771:9
[INFO] [stdout]   16:     0x5ce61fc9eb49 - std::sys::backtrace::__rust_end_short_backtrace::h840811b1dfa0dad5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x5ce61fca328c - std::panicking::begin_panic::hcf2bdd8da61aefe8
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:770:5
[INFO] [stdout]   18:     0x5ce61fc391f3 - software_rasterizer::math_util::math_tests::fixed_point_tests::convertion_test::hefaf93becfe2d9ce
[INFO] [stdout]                                at /opt/rustwide/workdir/src/math_util/math_tests/fixed_point_tests.rs:29:5
[INFO] [stdout]   19:     0x5ce61fc39217 - software_rasterizer::math_util::math_tests::fixed_point_tests::convertion_test::{{closure}}::h4ff10a2d8f88e694
[INFO] [stdout]                                at /opt/rustwide/workdir/src/math_util/math_tests/fixed_point_tests.rs:3:21
[INFO] [stdout]   20:     0x5ce61fc395a6 - core::ops::function::FnOnce::call_once::hb2ab1c93379074b2
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   21:     0x5ce61fc620bb - core::ops::function::FnOnce::call_once::h70887edf07a630ba
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   22:     0x5ce61fc620bb - test::__rust_begin_short_backtrace::h27763c4cbbdb8601
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18
[INFO] [stdout]   23:     0x5ce61fc77d25 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74
[INFO] [stdout]   24:     0x5ce61fc77d25 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] [stdout]   25:     0x5ce61fc77d25 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   26:     0x5ce61fc77d25 - std::panicking::catch_unwind::hae1ec7bf94407afa
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   27:     0x5ce61fc77d25 - std::panic::catch_unwind::h0f4ff4773d84d3cd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   28:     0x5ce61fc77d25 - test::run_test_in_process::h03fbc77ae48b3f10
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27
[INFO] [stdout]   29:     0x5ce61fc77d25 - test::run_test::{{closure}}::h83476a9c453dc4d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43
[INFO] [stdout]   30:     0x5ce61fc4e514 - test::run_test::{{closure}}::h515482ad1e7fe7de
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41
[INFO] [stdout]   31:     0x5ce61fc4e514 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   32:     0x5ce61fc51dda - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   33:     0x5ce61fc51dda - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   34:     0x5ce61fc51dda - std::panicking::catch_unwind::do_call::hdc29e11311eb7655
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   35:     0x5ce61fc51dda - std::panicking::catch_unwind::h9e402d6a96fef41c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   36:     0x5ce61fc51dda - std::panic::catch_unwind::h9213c0c54aec70e0
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   37:     0x5ce61fc51dda - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   38:     0x5ce61fc51dda - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   39:     0x5ce61fc99c9f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h2044e71c41d3958a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   40:     0x5ce61fc99c9f - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17
[INFO] [stdout]   41:     0x755d0dc4faa4 - <unknown>
[INFO] [stdout]   42:     0x755d0dcdca34 - clone
[INFO] [stdout]   43:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     math_util::math_tests::fixed_point_tests::convertion_test
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 2 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.19s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "ea3d9602a4dad7913c6d34bd562ede4d54ace635edea8a0a16bb54f105193d13", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ea3d9602a4dad7913c6d34bd562ede4d54ace635edea8a0a16bb54f105193d13", kill_on_drop: false }`
[INFO] [stdout] ea3d9602a4dad7913c6d34bd562ede4d54ace635edea8a0a16bb54f105193d13
