[INFO] cloning repository https://github.com/kabosusang/crab_tinyrenderer
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/kabosusang/crab_tinyrenderer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkabosusang%2Fcrab_tinyrenderer", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkabosusang%2Fcrab_tinyrenderer'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 757885a7d97e2e80f0c5647cbcf5a9943aa56256
[INFO] testing kabosusang/crab_tinyrenderer against beta-2026-04-21 for beta-1.96-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkabosusang%2Fcrab_tinyrenderer" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/kabosusang/crab_tinyrenderer
[INFO] finished tweaking git repo https://github.com/kabosusang/crab_tinyrenderer
[INFO] tweaked toml for git repo https://github.com/kabosusang/crab_tinyrenderer written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/kabosusang/crab_tinyrenderer on toolchain beta-2026-04-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/kabosusang/crab_tinyrenderer 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-2026-04-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2c6bf42e1ea7fbf0bb273bebb4295681907ddca088943215feac0e546c205508
[INFO] running `Command { std: "docker" "start" "-a" "2c6bf42e1ea7fbf0bb273bebb4295681907ddca088943215feac0e546c205508", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2c6bf42e1ea7fbf0bb273bebb4295681907ddca088943215feac0e546c205508", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2c6bf42e1ea7fbf0bb273bebb4295681907ddca088943215feac0e546c205508", kill_on_drop: false }`
[INFO] [stdout] 2c6bf42e1ea7fbf0bb273bebb4295681907ddca088943215feac0e546c205508
[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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c054a6b094c054acd31c7f5f40d512773034c00f5929ebac49e157fd6e99d1d1
[INFO] running `Command { std: "docker" "start" "-a" "c054a6b094c054acd31c7f5f40d512773034c00f5929ebac49e157fd6e99d1d1", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.184
[INFO] [stderr]    Compiling unicode-ident v1.0.24
[INFO] [stderr]    Compiling pkg-config v0.3.33
[INFO] [stderr]    Compiling xml-rs v0.8.28
[INFO] [stderr]    Compiling rustix v1.1.4
[INFO] [stderr]    Compiling downcast-rs v1.2.1
[INFO] [stderr]    Compiling memoffset v0.6.5
[INFO] [stderr]    Compiling libloading v0.8.9
[INFO] [stderr]    Compiling scoped-tls v1.0.1
[INFO] [stderr]    Compiling getrandom v0.4.2
[INFO] [stderr]    Compiling cc v1.2.60
[INFO] [stderr]    Compiling linux-raw-sys v0.12.1
[INFO] [stderr]    Compiling bitflags v2.11.0
[INFO] [stderr]    Compiling fastrand v2.4.1
[INFO] [stderr]    Compiling xcursor v0.3.10
[INFO] [stderr]    Compiling raw-window-handle v0.6.2
[INFO] [stderr]    Compiling proc-macro2 v1.0.106
[INFO] [stderr]    Compiling dlib v0.5.3
[INFO] [stderr]    Compiling wayland-sys v0.29.5
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]    Compiling quote v1.0.45
[INFO] [stderr]    Compiling wayland-scanner v0.29.5
[INFO] [stderr]    Compiling minifb v0.28.0
[INFO] [stderr]    Compiling nix v0.24.3
[INFO] [stderr]    Compiling wayland-client v0.29.5
[INFO] [stderr]    Compiling wayland-protocols v0.29.5
[INFO] [stderr]    Compiling tempfile v3.27.0
[INFO] [stderr]    Compiling wayland-commons v0.29.5
[INFO] [stderr]    Compiling wayland-cursor v0.29.5
[INFO] [stderr]    Compiling CGRL v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `*`
[INFO] [stdout]  --> src/graphic/line.rs:1:25
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::math::{self, *};
[INFO] [stdout]   |                         ^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/graphic/line.rs:26:26
[INFO] [stdout]    |
[INFO] [stdout] 26 |         let x_inc: f32 = (dx / steps as f32);
[INFO] [stdout]    |                          ^                 ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 -         let x_inc: f32 = (dx / steps as f32);
[INFO] [stdout] 26 +         let x_inc: f32 = dx / steps as f32 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/graphic/line.rs:27:26
[INFO] [stdout]    |
[INFO] [stdout] 27 |         let y_inc: f32 = (dy / steps as f32);
[INFO] [stdout]    |                          ^                 ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 27 -         let y_inc: f32 = (dy / steps as f32);
[INFO] [stdout] 27 +         let y_inc: f32 = dy / steps as f32 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::intrinsics::write_bytes`
[INFO] [stdout]  --> src/graphic/canvas.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::intrinsics::write_bytes;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `write`
[INFO] [stdout]  --> src/graphic/error.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fmt::{self, write};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated module `std::intrinsics`: import this function via `std::ptr` instead
[INFO] [stdout]  --> src/graphic/canvas.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::intrinsics::write_bytes;
[INFO] [stdout]   |                      ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `DDA` is never used
[INFO] [stdout]  --> src/graphic/line.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | impl Line {
[INFO] [stdout]   | --------- associated function in this implementation
[INFO] [stdout] 6 |     // DDA
[INFO] [stdout] 7 |     pub fn DDA(x0: f32, y0: f32, x1: f32, y1: f32) -> Vec<(usize, usize)> {
[INFO] [stdout]   |            ^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated constant `WHITE` is never used
[INFO] [stdout]   --> src/graphic/color.rs:31:15
[INFO] [stdout]    |
[INFO] [stdout] 16 | impl Color {
[INFO] [stdout]    | ---------- associated constant in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub const WHITE: Self = Self::new(255, 255, 255);
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `center_origin`, `draw_line_dda`, `draw_wireframe_triangle`, and `draw_filled_triangle` are never used
[INFO] [stdout]    --> src/graphic/canvas.rs:36:18
[INFO] [stdout]     |
[INFO] [stdout]  35 | impl Canvas {
[INFO] [stdout]     | ----------- associated items in this implementation
[INFO] [stdout]  36 |     pub const fn center_origin(canvas: &Canvas, x: isize, y: isize) -> (usize, usize) {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  71 |     pub fn draw_line_dda(
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn draw_wireframe_triangle(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 144 |     pub fn draw_filled_triangle(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `max` is never used
[INFO] [stdout]  --> src/math/number.rs:2:8
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub fn max<T: PartialOrd>(v1: T, v2: T) -> T {
[INFO] [stdout]   |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `interpolate_isize` is never used
[INFO] [stdout]   --> src/math/number.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub fn interpolate_isize(y_start: isize, x_start: isize, y_end: isize, x_end: isize) -> Vec<isize> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `DDA` should have a snake case name
[INFO] [stdout]  --> src/graphic/line.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 |     pub fn DDA(x0: f32, y0: f32, x1: f32, y1: f32) -> Vec<(usize, usize)> {
[INFO] [stdout]   |            ^^^ help: convert the identifier to snake case: `dda`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `BresenHam` should have a snake case name
[INFO] [stdout]   --> src/graphic/line.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub fn BresenHam(x0: usize, y0: usize, x1: usize, y1: usize) -> Vec<(usize, usize)> {
[INFO] [stdout]    |            ^^^^^^^^^ help: convert the identifier to snake case: `bresen_ham`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/graphic/canvas.rs:80:13
[INFO] [stdout]    |
[INFO] [stdout] 80 |             self.draw_point(point.0, point.1, color);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 80 |             let _ = self.draw_point(point.0, point.1, color);
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/graphic/canvas.rs:118:13
[INFO] [stdout]     |
[INFO] [stdout] 118 |             self.draw_point(point.0, point.1, color);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 118 |             let _ = self.draw_point(point.0, point.1, color);
[INFO] [stdout]     |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 46.04s
[INFO] running `Command { std: "docker" "inspect" "c054a6b094c054acd31c7f5f40d512773034c00f5929ebac49e157fd6e99d1d1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c054a6b094c054acd31c7f5f40d512773034c00f5929ebac49e157fd6e99d1d1", kill_on_drop: false }`
[INFO] [stdout] c054a6b094c054acd31c7f5f40d512773034c00f5929ebac49e157fd6e99d1d1
[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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 58a925af0a5f152b03b4b65f084d38c4a138bc6110aff853ca9c6423ca71b003
[INFO] running `Command { std: "docker" "start" "-a" "58a925af0a5f152b03b4b65f084d38c4a138bc6110aff853ca9c6423ca71b003", kill_on_drop: false }`
[INFO] [stderr]    Compiling CGRL v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `*`
[INFO] [stdout]  --> src/graphic/line.rs:1:25
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::math::{self, *};
[INFO] [stdout]   |                         ^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/graphic/line.rs:26:26
[INFO] [stdout]    |
[INFO] [stdout] 26 |         let x_inc: f32 = (dx / steps as f32);
[INFO] [stdout]    |                          ^                 ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 -         let x_inc: f32 = (dx / steps as f32);
[INFO] [stdout] 26 +         let x_inc: f32 = dx / steps as f32 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/graphic/line.rs:27:26
[INFO] [stdout]    |
[INFO] [stdout] 27 |         let y_inc: f32 = (dy / steps as f32);
[INFO] [stdout]    |                          ^                 ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 27 -         let y_inc: f32 = (dy / steps as f32);
[INFO] [stdout] 27 +         let y_inc: f32 = dy / steps as f32 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::intrinsics::write_bytes`
[INFO] [stdout]  --> src/graphic/canvas.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::intrinsics::write_bytes;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `write`
[INFO] [stdout]  --> src/graphic/error.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fmt::{self, write};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated module `std::intrinsics`: import this function via `std::ptr` instead
[INFO] [stdout]  --> src/graphic/canvas.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::intrinsics::write_bytes;
[INFO] [stdout]   |                      ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `DDA` is never used
[INFO] [stdout]  --> src/graphic/line.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | impl Line {
[INFO] [stdout]   | --------- associated function in this implementation
[INFO] [stdout] 6 |     // DDA
[INFO] [stdout] 7 |     pub fn DDA(x0: f32, y0: f32, x1: f32, y1: f32) -> Vec<(usize, usize)> {
[INFO] [stdout]   |            ^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated constant `WHITE` is never used
[INFO] [stdout]   --> src/graphic/color.rs:31:15
[INFO] [stdout]    |
[INFO] [stdout] 16 | impl Color {
[INFO] [stdout]    | ---------- associated constant in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub const WHITE: Self = Self::new(255, 255, 255);
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `center_origin`, `draw_line_dda`, `draw_wireframe_triangle`, and `draw_filled_triangle` are never used
[INFO] [stdout]    --> src/graphic/canvas.rs:36:18
[INFO] [stdout]     |
[INFO] [stdout]  35 | impl Canvas {
[INFO] [stdout]     | ----------- associated items in this implementation
[INFO] [stdout]  36 |     pub const fn center_origin(canvas: &Canvas, x: isize, y: isize) -> (usize, usize) {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  71 |     pub fn draw_line_dda(
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn draw_wireframe_triangle(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 144 |     pub fn draw_filled_triangle(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `max` is never used
[INFO] [stdout]  --> src/math/number.rs:2:8
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub fn max<T: PartialOrd>(v1: T, v2: T) -> T {
[INFO] [stdout]   |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `interpolate_isize` is never used
[INFO] [stdout]   --> src/math/number.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub fn interpolate_isize(y_start: isize, x_start: isize, y_end: isize, x_end: isize) -> Vec<isize> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `DDA` should have a snake case name
[INFO] [stdout]  --> src/graphic/line.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 |     pub fn DDA(x0: f32, y0: f32, x1: f32, y1: f32) -> Vec<(usize, usize)> {
[INFO] [stdout]   |            ^^^ help: convert the identifier to snake case: `dda`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `BresenHam` should have a snake case name
[INFO] [stdout]   --> src/graphic/line.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub fn BresenHam(x0: usize, y0: usize, x1: usize, y1: usize) -> Vec<(usize, usize)> {
[INFO] [stdout]    |            ^^^^^^^^^ help: convert the identifier to snake case: `bresen_ham`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/graphic/canvas.rs:80:13
[INFO] [stdout]    |
[INFO] [stdout] 80 |             self.draw_point(point.0, point.1, color);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 80 |             let _ = self.draw_point(point.0, point.1, color);
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/graphic/canvas.rs:118:13
[INFO] [stdout]     |
[INFO] [stdout] 118 |             self.draw_point(point.0, point.1, color);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 118 |             let _ = self.draw_point(point.0, point.1, color);
[INFO] [stdout]     |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.54s
[INFO] running `Command { std: "docker" "inspect" "58a925af0a5f152b03b4b65f084d38c4a138bc6110aff853ca9c6423ca71b003", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "58a925af0a5f152b03b4b65f084d38c4a138bc6110aff853ca9c6423ca71b003", kill_on_drop: false }`
[INFO] [stdout] 58a925af0a5f152b03b4b65f084d38c4a138bc6110aff853ca9c6423ca71b003
[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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] e2f736993f8185dcb3a05a622f5b5070485c3dc3f2dab87879234f22d2b0b00e
[INFO] running `Command { std: "docker" "start" "-a" "e2f736993f8185dcb3a05a622f5b5070485c3dc3f2dab87879234f22d2b0b00e", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `*`
[INFO] [stderr]  --> src/graphic/line.rs:1:25
[INFO] [stderr]   |
[INFO] [stderr] 1 | use crate::math::{self, *};
[INFO] [stderr]   |                         ^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]   --> src/graphic/line.rs:26:26
[INFO] [stderr]    |
[INFO] [stderr] 26 |         let x_inc: f32 = (dx / steps as f32);
[INFO] [stderr]    |                          ^                 ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 26 -         let x_inc: f32 = (dx / steps as f32);
[INFO] [stderr] 26 +         let x_inc: f32 = dx / steps as f32 ;
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]   --> src/graphic/line.rs:27:26
[INFO] [stderr]    |
[INFO] [stderr] 27 |         let y_inc: f32 = (dy / steps as f32);
[INFO] [stderr]    |                          ^                 ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 27 -         let y_inc: f32 = (dy / steps as f32);
[INFO] [stderr] 27 +         let y_inc: f32 = dy / steps as f32 ;
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::intrinsics::write_bytes`
[INFO] [stderr]  --> src/graphic/canvas.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::intrinsics::write_bytes;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `write`
[INFO] [stderr]  --> src/graphic/error.rs:1:22
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::fmt::{self, write};
[INFO] [stderr]   |                      ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated module `std::intrinsics`: import this function via `std::ptr` instead
[INFO] [stderr]  --> src/graphic/canvas.rs:1:22
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::intrinsics::write_bytes;
[INFO] [stderr]   |                      ^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `DDA` is never used
[INFO] [stderr]  --> src/graphic/line.rs:7:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | impl Line {
[INFO] [stderr]   | --------- associated function in this implementation
[INFO] [stderr] 6 |     // DDA
[INFO] [stderr] 7 |     pub fn DDA(x0: f32, y0: f32, x1: f32, y1: f32) -> Vec<(usize, usize)> {
[INFO] [stderr]   |            ^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: associated constant `WHITE` is never used
[INFO] [stderr]   --> src/graphic/color.rs:31:15
[INFO] [stderr]    |
[INFO] [stderr] 16 | impl Color {
[INFO] [stderr]    | ---------- associated constant in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 31 |     pub const WHITE: Self = Self::new(255, 255, 255);
[INFO] [stderr]    |               ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `center_origin`, `draw_line_dda`, `draw_wireframe_triangle`, and `draw_filled_triangle` are never used
[INFO] [stderr]    --> src/graphic/canvas.rs:36:18
[INFO] [stderr]     |
[INFO] [stderr]  35 | impl Canvas {
[INFO] [stderr]     | ----------- associated items in this implementation
[INFO] [stderr]  36 |     pub const fn center_origin(canvas: &Canvas, x: isize, y: isize) -> (usize, usize) {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  71 |     pub fn draw_line_dda(
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 125 |     pub fn draw_wireframe_triangle(
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 144 |     pub fn draw_filled_triangle(
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `max` is never used
[INFO] [stderr]  --> src/math/number.rs:2:8
[INFO] [stderr]   |
[INFO] [stderr] 2 | pub fn max<T: PartialOrd>(v1: T, v2: T) -> T {
[INFO] [stderr]   |        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `interpolate_isize` is never used
[INFO] [stderr]   --> src/math/number.rs:22:8
[INFO] [stderr]    |
[INFO] [stderr] 22 | pub fn interpolate_isize(y_start: isize, x_start: isize, y_end: isize, x_end: isize) -> Vec<isize> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `DDA` should have a snake case name
[INFO] [stderr]  --> src/graphic/line.rs:7:12
[INFO] [stderr]   |
[INFO] [stderr] 7 |     pub fn DDA(x0: f32, y0: f32, x1: f32, y1: f32) -> Vec<(usize, usize)> {
[INFO] [stderr]   |            ^^^ help: convert the identifier to snake case: `dda`
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: method `BresenHam` should have a snake case name
[INFO] [stderr]   --> src/graphic/line.rs:38:12
[INFO] [stderr]    |
[INFO] [stderr] 38 |     pub fn BresenHam(x0: usize, y0: usize, x1: usize, y1: usize) -> Vec<(usize, usize)> {
[INFO] [stderr]    |            ^^^^^^^^^ help: convert the identifier to snake case: `bresen_ham`
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]   --> src/graphic/canvas.rs:80:13
[INFO] [stderr]    |
[INFO] [stderr] 80 |             self.draw_point(point.0, point.1, color);
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]    |
[INFO] [stderr] 80 |             let _ = self.draw_point(point.0, point.1, color);
[INFO] [stderr]    |             +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> src/graphic/canvas.rs:118:13
[INFO] [stderr]     |
[INFO] [stderr] 118 |             self.draw_point(point.0, point.1, color);
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 118 |             let _ = self.draw_point(point.0, point.1, color);
[INFO] [stderr]     |             +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `CGRL` (bin "CGRL" test) generated 15 warnings (run `cargo fix --bin "CGRL" -p CGRL --tests` to apply 5 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.10s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/CGRL-ed2b6ddc36745864)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "e2f736993f8185dcb3a05a622f5b5070485c3dc3f2dab87879234f22d2b0b00e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e2f736993f8185dcb3a05a622f5b5070485c3dc3f2dab87879234f22d2b0b00e", kill_on_drop: false }`
[INFO] [stdout] e2f736993f8185dcb3a05a622f5b5070485c3dc3f2dab87879234f22d2b0b00e
