[INFO] cloning repository https://github.com/nounoursheureux/rusttracer
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/nounoursheureux/rusttracer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnounoursheureux%2Frusttracer", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnounoursheureux%2Frusttracer'...
[INFO] [stderr] fatal: error closing file /workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnounoursheureux%2Frusttracer/packed-refs.new: No space left on device
[WARN] Retrying crate fetch in 3 seconds (attempt 1)
[INFO] cloning repository https://github.com/nounoursheureux/rusttracer
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/nounoursheureux/rusttracer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnounoursheureux%2Frusttracer", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnounoursheureux%2Frusttracer'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] f3de6c51c82c35b1f3e7a1ef9a87a17c6fb6318e
[INFO] checking nounoursheureux/rusttracer against master#9bfa31f632912180dc742809bcc51a97f2d7079d for pr-140151
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnounoursheureux%2Frusttracer" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/nounoursheureux/rusttracer on toolchain 9bfa31f632912180dc742809bcc51a97f2d7079d
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+9bfa31f632912180dc742809bcc51a97f2d7079d" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/nounoursheureux/rusttracer
[INFO] finished tweaking git repo https://github.com/nounoursheureux/rusttracer
[INFO] tweaked toml for git repo https://github.com/nounoursheureux/rusttracer written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] crate git repo https://github.com/nounoursheureux/rusttracer 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" "+9bfa31f632912180dc742809bcc51a97f2d7079d" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:b0b074c097205a61b89e8ad263052f976b2b332c4dc5f02aef1fe52501660d6e" "/opt/rustwide/cargo-home/bin/cargo" "+9bfa31f632912180dc742809bcc51a97f2d7079d" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] eea1c8a2c6af14c905a671fd680595dd48f6908fe047747cbcab77616fb12cb6
[INFO] running `Command { std: "docker" "start" "-a" "eea1c8a2c6af14c905a671fd680595dd48f6908fe047747cbcab77616fb12cb6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "eea1c8a2c6af14c905a671fd680595dd48f6908fe047747cbcab77616fb12cb6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "eea1c8a2c6af14c905a671fd680595dd48f6908fe047747cbcab77616fb12cb6", kill_on_drop: false }`
[INFO] [stdout] eea1c8a2c6af14c905a671fd680595dd48f6908fe047747cbcab77616fb12cb6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:b0b074c097205a61b89e8ad263052f976b2b332c4dc5f02aef1fe52501660d6e" "/opt/rustwide/cargo-home/bin/cargo" "+9bfa31f632912180dc742809bcc51a97f2d7079d" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] aa93d848fc8debd96170fea17c07d27a3390a85d6bb20e36ee7e0830ee7fb24f
[INFO] running `Command { std: "docker" "start" "-a" "aa93d848fc8debd96170fea17c07d27a3390a85d6bb20e36ee7e0830ee7fb24f", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]     Checking num-traits v0.1.41
[INFO] [stderr]     Checking adler32 v1.0.2
[INFO] [stderr]     Checking byteorder v1.2.1
[INFO] [stderr]     Checking libc v0.2.34
[INFO] [stderr]     Checking bitflags v1.0.1
[INFO] [stderr]     Checking approx v0.1.1
[INFO] [stderr]     Checking tobj v0.1.6
[INFO] [stderr]     Checking inflate v0.3.3
[INFO] [stderr]     Checking deflate v0.7.17
[INFO] [stderr]     Checking rand v0.3.18
[INFO] [stderr]     Checking num-integer v0.1.35
[INFO] [stderr]     Checking cgmath v0.15.0
[INFO] [stderr]     Checking num-iter v0.1.34
[INFO] [stderr]     Checking png v0.11.0
[INFO] [stderr]     Checking rusttracer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `cgmath`
[INFO] [stdout]  --> src/shape.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use cgmath;
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `cgmath::vec3`
[INFO] [stdout]  --> src/shape.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use cgmath::vec3;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `util::*`
[INFO] [stdout]  --> src/shape.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use util::*;
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `util::*`
[INFO] [stdout]  --> src/mesh.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use util::*;
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Shape` and `Triangle`
[INFO] [stdout]  --> src/mesh.rs:7:13
[INFO] [stdout]   |
[INFO] [stdout] 7 | use shape::{Triangle, Shape, Vertex};
[INFO] [stdout]   |             ^^^^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `cgmath::vec4`
[INFO] [stdout]  --> src/object.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use cgmath::vec4;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Triangle`
[INFO] [stdout]   --> src/main.rs:18:28
[INFO] [stdout]    |
[INFO] [stdout] 18 | use shape::{Shape, Sphere, Triangle};
[INFO] [stdout]    |                            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `util::*`
[INFO] [stdout]   --> src/main.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use util::*;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `cgmath`
[INFO] [stdout]  --> src/shape.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use cgmath;
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `cgmath::vec3`
[INFO] [stdout]  --> src/shape.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use cgmath::vec3;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `util::*`
[INFO] [stdout]  --> src/shape.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use util::*;
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `util::*`
[INFO] [stdout]  --> src/mesh.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use util::*;
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Shape` and `Triangle`
[INFO] [stdout]  --> src/mesh.rs:7:13
[INFO] [stdout]   |
[INFO] [stdout] 7 | use shape::{Triangle, Shape, Vertex};
[INFO] [stdout]   |             ^^^^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `cgmath::vec4`
[INFO] [stdout]  --> src/object.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use cgmath::vec4;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Triangle`
[INFO] [stdout]   --> src/main.rs:18:28
[INFO] [stdout]    |
[INFO] [stdout] 18 | use shape::{Shape, Sphere, Triangle};
[INFO] [stdout]    |                            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `util::*`
[INFO] [stdout]   --> src/main.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use util::*;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Shape`
[INFO] [stdout]   --> src/main.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 | use shape::{Shape, Sphere, Triangle};
[INFO] [stdout]    |             ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sphere`
[INFO] [stdout]   --> src/main.rs:51:6
[INFO] [stdout]    |
[INFO] [stdout] 51 |     let sphere = Sphere {
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_sphere`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AABB` is never constructed
[INFO] [stdout]   --> src/shape.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct AABB {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AABB` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `aabb` is never used
[INFO] [stdout]   --> src/shape.rs:96:9
[INFO] [stdout]    |
[INFO] [stdout] 90 | impl Triangle {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub fn aabb(&self) -> AABB {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `vertices`, `faces`, and `transform` are never read
[INFO] [stdout]   --> src/object.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub struct Object {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] 9  |     pub vertices: Vec<Vertex>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 10 |     pub faces: Vec<Face>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 11 |     pub triangles: Vec<Triangle>,
[INFO] [stdout] 12 |     pub transform: Matrix4f,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `object_id` is never read
[INFO] [stdout]   --> src/scene.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct SceneIntersection {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] 13 |     pub object_id: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SceneIntersection` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `opaque` is never read
[INFO] [stdout]  --> src/material.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct Material {
[INFO] [stdout]   |            -------- field in this struct
[INFO] [stdout] 5 |     pub color: Color,
[INFO] [stdout] 6 |     pub opaque: bool,
[INFO] [stdout]   |         ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Material` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `V` should have a snake case name
[INFO] [stdout]   --> src/main.rs:29:7
[INFO] [stdout]    |
[INFO] [stdout] 29 |         let V = (ray.origin - inter.position).normalize();
[INFO] [stdout]    |             ^ help: convert the identifier to snake case (notice the capitalization): `v`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L` should have a snake case name
[INFO] [stdout]   --> src/main.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 39 |             let L = (scene.lights[0] - inter.position).normalize();
[INFO] [stdout]    |                 ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L` should have a snake case name
[INFO] [stdout]   --> src/shape.rs:59:7
[INFO] [stdout]    |
[INFO] [stdout] 59 |         let L = self.center - ray.origin;
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Shape`
[INFO] [stdout]   --> src/main.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 | use shape::{Shape, Sphere, Triangle};
[INFO] [stdout]    |             ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sphere`
[INFO] [stdout]   --> src/main.rs:51:6
[INFO] [stdout]    |
[INFO] [stdout] 51 |     let sphere = Sphere {
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_sphere`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AABB` is never constructed
[INFO] [stdout]   --> src/shape.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct AABB {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AABB` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `aabb` is never used
[INFO] [stdout]   --> src/shape.rs:96:9
[INFO] [stdout]    |
[INFO] [stdout] 90 | impl Triangle {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub fn aabb(&self) -> AABB {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Zero`, `One`, and `Two` are never constructed
[INFO] [stdout]  --> src/util.rs:3:2
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub enum EqSolution {
[INFO] [stdout]   |          ---------- variants in this enum
[INFO] [stdout] 3 |     Zero,
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 4 |     One(f32),
[INFO] [stdout]   |     ^^^
[INFO] [stdout] 5 |     Two(f32, f32)
[INFO] [stdout]   |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `solve_quadratic_equation` is never used
[INFO] [stdout]  --> src/util.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn solve_quadratic_equation(a: f32, b: f32, c: f32) -> EqSolution {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `vertices`, `faces`, and `transform` are never read
[INFO] [stdout]   --> src/object.rs:9:9
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub struct Object {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] 9  |     pub vertices: Vec<Vertex>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 10 |     pub faces: Vec<Face>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 11 |     pub triangles: Vec<Triangle>,
[INFO] [stdout] 12 |     pub transform: Matrix4f,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `object_id` is never read
[INFO] [stdout]   --> src/scene.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct SceneIntersection {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] 13 |     pub object_id: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SceneIntersection` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `opaque` is never read
[INFO] [stdout]  --> src/material.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct Material {
[INFO] [stdout]   |            -------- field in this struct
[INFO] [stdout] 5 |     pub color: Color,
[INFO] [stdout] 6 |     pub opaque: bool,
[INFO] [stdout]   |         ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Material` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `V` should have a snake case name
[INFO] [stdout]   --> src/main.rs:29:7
[INFO] [stdout]    |
[INFO] [stdout] 29 |         let V = (ray.origin - inter.position).normalize();
[INFO] [stdout]    |             ^ help: convert the identifier to snake case (notice the capitalization): `v`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L` should have a snake case name
[INFO] [stdout]   --> src/main.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 39 |             let L = (scene.lights[0] - inter.position).normalize();
[INFO] [stdout]    |                 ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L` should have a snake case name
[INFO] [stdout]   --> src/shape.rs:59:7
[INFO] [stdout]    |
[INFO] [stdout] 59 |         let L = self.center - ray.origin;
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 4.77s
[INFO] running `Command { std: "docker" "inspect" "aa93d848fc8debd96170fea17c07d27a3390a85d6bb20e36ee7e0830ee7fb24f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "aa93d848fc8debd96170fea17c07d27a3390a85d6bb20e36ee7e0830ee7fb24f", kill_on_drop: false }`
[INFO] [stdout] aa93d848fc8debd96170fea17c07d27a3390a85d6bb20e36ee7e0830ee7fb24f
