[INFO] crate ray-tracer 0.1.0 is already in cache
[INFO] checking ray-tracer-0.1.0 against master#bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc for pr-70917
[INFO] extracting crate ray-tracer 0.1.0 into /workspace/builds/worker-2/source
[INFO] validating manifest of crates.io crate ray-tracer 0.1.0 on toolchain bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking crates.io crate ray-tracer 0.1.0
[INFO] finished tweaking crates.io crate ray-tracer 0.1.0
[INFO] tweaked toml for crates.io crate ray-tracer 0.1.0 written to /workspace/builds/worker-2/source/Cargo.toml
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"`
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "check" "--frozen" "--all" "--all-targets"`
[INFO] [stdout] 572598c223c4ee4b659673c9b19e4b0e0172b02fd1f1ca895780384d49b02df3
[INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
[INFO] running `"docker" "start" "-a" "572598c223c4ee4b659673c9b19e4b0e0172b02fd1f1ca895780384d49b02df3"`
[INFO] [stderr]    Compiling rand v0.6.5
[INFO] [stderr]     Checking rand_os v0.1.3
[INFO] [stderr]     Checking ray-tracer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] warning: unused import: `crate::ray::Ray`
[INFO] [stderr]  --> src/hit/mod.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::ray::Ray;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::actor::Actor`
[INFO] [stderr]  --> src/hit/mod.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use crate::actor::Actor;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::vector::Vec3`
[INFO] [stderr]  --> src/hitable/mod.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::vector::Vec3;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::vector::Vec3`
[INFO] [stderr]  --> src/hitable/primitive/cube.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::vector::Vec3;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::utils::axis_to_index`
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:11:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | use crate::utils::axis_to_index;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:52:28
[INFO] [stderr]    |
[INFO] [stderr] 52 |             let face : Box<Hitable<T>> = Box::new(Translation::new(face, translation));
[INFO] [stderr]    |                            ^^^^^^^^^^ help: use `dyn`: `dyn Hitable<T>`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/scene/mod.rs:63:28
[INFO] [stderr]    |
[INFO] [stderr] 63 |                         if (reflection < max_reflection) {
[INFO] [stderr]    |                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::u32`
[INFO] [stderr]  --> src/renderer/mod.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::u32;
[INFO] [stderr]   |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/renderer/mod.rs:52:82
[INFO] [stderr]    |
[INFO] [stderr] 52 |     pub fn render_pixel<T>(&self, i: usize, j: usize, scene: &Scene<T>, camera: &Camera<T>) -> Vec3<T>
[INFO] [stderr]    |                                                                                  ^^^^^^^^^ help: use `dyn`: `dyn Camera<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/renderer/mod.rs:84:56
[INFO] [stderr]    |
[INFO] [stderr] 84 |     pub fn render<T>(&self, scene: &Scene<T>, camera: &Camera<T>) -> Image<T>
[INFO] [stderr]    |                                                        ^^^^^^^^^ help: use `dyn`: `dyn Camera<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/renderer/mod.rs:100:55
[INFO] [stderr]     |
[INFO] [stderr] 100 |     fn get_ray<T>(&self, i: usize, j: usize, camera: &Camera<T>, two: T) -> Ray<T>
[INFO] [stderr]     |                                                       ^^^^^^^^^ help: use `dyn`: `dyn Camera<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/material/plain.rs:17:29
[INFO] [stderr]    |
[INFO] [stderr] 17 |     pub fn new(texture: Box<Texture<T>>) -> Self {
[INFO] [stderr]    |                             ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::prelude::*`
[INFO] [stderr]  --> src/material/lambertian.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use rand::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/material/lambertian.rs:21:29
[INFO] [stderr]    |
[INFO] [stderr] 21 |     pub fn new(texture: Box<Texture<T>>, dimming: T) -> Self {
[INFO] [stderr]    |                             ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::prelude::*`
[INFO] [stderr]  --> src/material/metal.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use rand::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/material/metal.rs:21:29
[INFO] [stderr]    |
[INFO] [stderr] 21 |     pub fn new(texture: Box<Texture<T>>, fuzziness: T) -> Self {
[INFO] [stderr]    |                             ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::prelude::*`
[INFO] [stderr]  --> src/material/dielectric.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use rand::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/material/dielectric.rs:21:29
[INFO] [stderr]    |
[INFO] [stderr] 21 |     pub fn new(texture: Box<Texture<T>>, n: T) -> Self {
[INFO] [stderr]    |                             ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/actor/mod.rs:8:22
[INFO] [stderr]   |
[INFO] [stderr] 8 |     pub hitable: Box<Hitable<T>>,
[INFO] [stderr]   |                      ^^^^^^^^^^ help: use `dyn`: `dyn Hitable<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/actor/mod.rs:9:23
[INFO] [stderr]   |
[INFO] [stderr] 9 |     pub material: Box<Material<T>>
[INFO] [stderr]   |                       ^^^^^^^^^^^ help: use `dyn`: `dyn Material<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/texture/checker.rs:8:19
[INFO] [stderr]   |
[INFO] [stderr] 8 |     texture0: Box<Texture<T>>,
[INFO] [stderr]   |                   ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/texture/checker.rs:9:19
[INFO] [stderr]   |
[INFO] [stderr] 9 |     texture1: Box<Texture<T>>,
[INFO] [stderr]   |                   ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/texture/checker.rs:17:31
[INFO] [stderr]    |
[INFO] [stderr] 17 |     pub fn new(texture0:  Box<Texture<T>>, texture1:  Box<Texture<T>>) -> Self {
[INFO] [stderr]    |                               ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/texture/checker.rs:17:59
[INFO] [stderr]    |
[INFO] [stderr] 17 |     pub fn new(texture0:  Box<Texture<T>>, texture1:  Box<Texture<T>>) -> Self {
[INFO] [stderr]    |                                                           ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::vector::Vec3`
[INFO] [stderr]  --> src/tree/linear.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use crate::vector::Vec3;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::boundingbox::BoundingBox`
[INFO] [stderr]  --> src/tree/linear.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::boundingbox::BoundingBox;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::ray::Ray`
[INFO] [stderr]  --> src/hit/mod.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::ray::Ray;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::actor::Actor`
[INFO] [stderr]  --> src/hit/mod.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use crate::actor::Actor;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::vector::Vec3`
[INFO] [stderr]  --> src/hitable/mod.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::vector::Vec3;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::vector::Vec3`
[INFO] [stderr]  --> src/hitable/primitive/cube.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::vector::Vec3;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::utils::axis_to_index`
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:11:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | use crate::utils::axis_to_index;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:52:28
[INFO] [stderr]    |
[INFO] [stderr] 52 |             let face : Box<Hitable<T>> = Box::new(Translation::new(face, translation));
[INFO] [stderr]    |                            ^^^^^^^^^^ help: use `dyn`: `dyn Hitable<T>`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/scene/mod.rs:63:28
[INFO] [stderr]    |
[INFO] [stderr] 63 |                         if (reflection < max_reflection) {
[INFO] [stderr]    |                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::u32`
[INFO] [stderr]  --> src/renderer/mod.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::u32;
[INFO] [stderr]   |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/renderer/mod.rs:52:82
[INFO] [stderr]    |
[INFO] [stderr] 52 |     pub fn render_pixel<T>(&self, i: usize, j: usize, scene: &Scene<T>, camera: &Camera<T>) -> Vec3<T>
[INFO] [stderr]    |                                                                                  ^^^^^^^^^ help: use `dyn`: `dyn Camera<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/renderer/mod.rs:84:56
[INFO] [stderr]    |
[INFO] [stderr] 84 |     pub fn render<T>(&self, scene: &Scene<T>, camera: &Camera<T>) -> Image<T>
[INFO] [stderr]    |                                                        ^^^^^^^^^ help: use `dyn`: `dyn Camera<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/renderer/mod.rs:100:55
[INFO] [stderr]     |
[INFO] [stderr] 100 |     fn get_ray<T>(&self, i: usize, j: usize, camera: &Camera<T>, two: T) -> Ray<T>
[INFO] [stderr]     |                                                       ^^^^^^^^^ help: use `dyn`: `dyn Camera<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/material/plain.rs:17:29
[INFO] [stderr]    |
[INFO] [stderr] 17 |     pub fn new(texture: Box<Texture<T>>) -> Self {
[INFO] [stderr]    |                             ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::prelude::*`
[INFO] [stderr]  --> src/material/lambertian.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use rand::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/material/lambertian.rs:21:29
[INFO] [stderr]    |
[INFO] [stderr] 21 |     pub fn new(texture: Box<Texture<T>>, dimming: T) -> Self {
[INFO] [stderr]    |                             ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::prelude::*`
[INFO] [stderr]  --> src/material/metal.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use rand::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/material/metal.rs:21:29
[INFO] [stderr]    |
[INFO] [stderr] 21 |     pub fn new(texture: Box<Texture<T>>, fuzziness: T) -> Self {
[INFO] [stderr]    |                             ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::prelude::*`
[INFO] [stderr]  --> src/material/dielectric.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use rand::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/material/dielectric.rs:21:29
[INFO] [stderr]    |
[INFO] [stderr] 21 |     pub fn new(texture: Box<Texture<T>>, n: T) -> Self {
[INFO] [stderr]    |                             ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/actor/mod.rs:8:22
[INFO] [stderr]   |
[INFO] [stderr] 8 |     pub hitable: Box<Hitable<T>>,
[INFO] [stderr]   |                      ^^^^^^^^^^ help: use `dyn`: `dyn Hitable<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/actor/mod.rs:9:23
[INFO] [stderr]   |
[INFO] [stderr] 9 |     pub material: Box<Material<T>>
[INFO] [stderr]   |                       ^^^^^^^^^^^ help: use `dyn`: `dyn Material<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/texture/checker.rs:8:19
[INFO] [stderr]   |
[INFO] [stderr] 8 |     texture0: Box<Texture<T>>,
[INFO] [stderr]   |                   ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/texture/checker.rs:9:19
[INFO] [stderr]   |
[INFO] [stderr] 9 |     texture1: Box<Texture<T>>,
[INFO] [stderr]   |                   ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/texture/checker.rs:17:31
[INFO] [stderr]    |
[INFO] [stderr] 17 |     pub fn new(texture0:  Box<Texture<T>>, texture1:  Box<Texture<T>>) -> Self {
[INFO] [stderr]    |                               ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/texture/checker.rs:17:59
[INFO] [stderr]    |
[INFO] [stderr] 17 |     pub fn new(texture0:  Box<Texture<T>>, texture1:  Box<Texture<T>>) -> Self {
[INFO] [stderr]    |                                                           ^^^^^^^^^^ help: use `dyn`: `dyn Texture<T>`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::vector::Vec3`
[INFO] [stderr]  --> src/tree/linear.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use crate::vector::Vec3;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::boundingbox::BoundingBox`
[INFO] [stderr]  --> src/tree/linear.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::boundingbox::BoundingBox;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::hitable::Hitable`
[INFO] [stderr]  --> src/renderer/mod.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use crate::hitable::Hitable;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `two`
[INFO] [stderr]    --> src/renderer/mod.rs:100:66
[INFO] [stderr]     |
[INFO] [stderr] 100 |     fn get_ray<T>(&self, i: usize, j: usize, camera: &Camera<T>, two: T) -> Ray<T>
[INFO] [stderr]     |                                                                  ^^^ help: if this is intentional, prefix it with an underscore: `_two`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `incident`
[INFO] [stderr]   --> src/material/lambertian.rs:32:23
[INFO] [stderr]    |
[INFO] [stderr] 32 |     fn scatter(&self, incident: &Ray<T>, hit: &Hit<T>) -> Scatter<T> {
[INFO] [stderr]    |                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_incident`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `two`
[INFO] [stderr]   --> src/texture/checker.rs:35:13
[INFO] [stderr]    |
[INFO] [stderr] 35 |         let two = T::from(2.0).unwrap();
[INFO] [stderr]    |             ^^^ help: if this is intentional, prefix it with an underscore: `_two`
[INFO] [stderr] 
[INFO] [stderr] warning: field is never read: `width`
[INFO] [stderr]   --> src/hitable/primitive/rectangle.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 |     width: T,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field is never read: `height`
[INFO] [stderr]   --> src/hitable/primitive/rectangle.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 |     height: T,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field is never read: `length`
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 16 |     length: T,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field is never read: `width`
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr] 17 |     width: T,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field is never read: `height`
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 |     height: T,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::hitable::Hitable`
[INFO] [stderr]  --> src/renderer/mod.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use crate::hitable::Hitable;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `hit`
[INFO] [stderr]    --> src/hitable/primitive/sphere.rs:146:18
[INFO] [stderr]     |
[INFO] [stderr] 146 |             Some(hit) => {
[INFO] [stderr]     |                  ^^^ help: if this is intentional, prefix it with an underscore: `_hit`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `hit`
[INFO] [stderr]    --> src/hitable/primitive/sphere.rs:157:18
[INFO] [stderr]     |
[INFO] [stderr] 157 |             Some(hit) => {
[INFO] [stderr]     |                  ^^^ help: if this is intentional, prefix it with an underscore: `_hit`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `hit`
[INFO] [stderr]    --> src/hitable/primitive/rectangle.rs:206:21
[INFO] [stderr]     |
[INFO] [stderr] 206 |         if let Some(hit) = rectangle.hit(&ray, 0.0, 100.0) {
[INFO] [stderr]     |                     ^^^ help: if this is intentional, prefix it with an underscore: `_hit`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `cube`
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:90:13
[INFO] [stderr]    |
[INFO] [stderr] 90 |         let cube = Cube::<f64>::new(length, width, height);
[INFO] [stderr]    |             ^^^^ help: if this is intentional, prefix it with an underscore: `_cube`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `ray`
[INFO] [stderr]    --> src/camera/perspective.rs:219:13
[INFO] [stderr]     |
[INFO] [stderr] 219 |         let ray = camera.get_ray(-1.0, 0.0);
[INFO] [stderr]     |             ^^^ help: if this is intentional, prefix it with an underscore: `_ray`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `two`
[INFO] [stderr]    --> src/renderer/mod.rs:100:66
[INFO] [stderr]     |
[INFO] [stderr] 100 |     fn get_ray<T>(&self, i: usize, j: usize, camera: &Camera<T>, two: T) -> Ray<T>
[INFO] [stderr]     |                                                                  ^^^ help: if this is intentional, prefix it with an underscore: `_two`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `incident`
[INFO] [stderr]   --> src/material/lambertian.rs:32:23
[INFO] [stderr]    |
[INFO] [stderr] 32 |     fn scatter(&self, incident: &Ray<T>, hit: &Hit<T>) -> Scatter<T> {
[INFO] [stderr]    |                       ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_incident`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `two`
[INFO] [stderr]   --> src/texture/checker.rs:35:13
[INFO] [stderr]    |
[INFO] [stderr] 35 |         let two = T::from(2.0).unwrap();
[INFO] [stderr]    |             ^^^ help: if this is intentional, prefix it with an underscore: `_two`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/boundingbox/mod.rs:240:17
[INFO] [stderr]     |
[INFO] [stderr] 240 |             let mut direction = Vec3::new();
[INFO] [stderr]     |                 ----^^^^^^^^^
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/boundingbox/mod.rs:247:17
[INFO] [stderr]     |
[INFO] [stderr] 247 |             let mut direction = Vec3::new();
[INFO] [stderr]     |                 ----^^^^^^^^^
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: field is never read: `width`
[INFO] [stderr]   --> src/hitable/primitive/rectangle.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 |     width: T,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field is never read: `height`
[INFO] [stderr]   --> src/hitable/primitive/rectangle.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 |     height: T,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field is never read: `length`
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 16 |     length: T,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field is never read: `width`
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr] 17 |     width: T,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field is never read: `height`
[INFO] [stderr]   --> src/hitable/primitive/cube.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 |     height: T,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> tests/main.rs:516:31
[INFO] [stderr]     |
[INFO] [stderr] 516 |             let hitable : Box<Hitable<f64>> = if hitable_select < SPHERE_PROBABILITY {
[INFO] [stderr]     |                               ^^^^^^^^^^^^ help: use `dyn`: `dyn Hitable<f64>`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> tests/main.rs:528:32
[INFO] [stderr]     |
[INFO] [stderr] 528 |             let material : Box<Material<f64>> = if material_select < LAMBERTIAN_PROBABILITY {
[INFO] [stderr]     |                                ^^^^^^^^^^^^^ help: use `dyn`: `dyn Material<f64>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> tests/main.rs:667:36
[INFO] [stderr]     |
[INFO] [stderr] 667 |                 let material : Box<Material<f64>> = Box::new(MetalMaterial::new(texture, 0.0));
[INFO] [stderr]     |                                    ^^^^^^^^^^^^^ help: use `dyn`: `dyn Material<f64>`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `width_axis`
[INFO] [stderr]    --> tests/main.rs:102:9
[INFO] [stderr]     |
[INFO] [stderr] 102 |     let width_axis = Axis::X;
[INFO] [stderr]     |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_width_axis`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `height_axis`
[INFO] [stderr]    --> tests/main.rs:103:9
[INFO] [stderr]     |
[INFO] [stderr] 103 |     let height_axis = Axis::Y;
[INFO] [stderr]     |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_height_axis`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `actor`
[INFO] [stderr]    --> tests/main.rs:142:9
[INFO] [stderr]     |
[INFO] [stderr] 142 |     let actor = Actor::<f64> { hitable: rectangle, material};
[INFO] [stderr]     |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_actor`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `hitable`
[INFO] [stderr]    --> tests/main.rs:203:9
[INFO] [stderr]     |
[INFO] [stderr] 203 |     let hitable = Box::new(Translation::new(hitable, Vec3::from_array([0.0, width / 2.0, 0.0])));
[INFO] [stderr]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_hitable`
[INFO] [stderr] 
[INFO] [stderr] warning: constant item is never used: `MULT`
[INFO] [stderr]   --> tests/main.rs:29:1
[INFO] [stderr]    |
[INFO] [stderr] 29 | const MULT : usize = 40;
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant item is never used: `SAMPLING`
[INFO] [stderr]   --> tests/main.rs:30:1
[INFO] [stderr]    |
[INFO] [stderr] 30 | const SAMPLING : usize = 4;
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant item is never used: `REFLECTIONS`
[INFO] [stderr]   --> tests/main.rs:31:1
[INFO] [stderr]    |
[INFO] [stderr] 31 | const REFLECTIONS : usize = 8;
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr]     Finished dev [unoptimized + debuginfo] target(s) in 5.52s
[INFO] running `"docker" "inspect" "572598c223c4ee4b659673c9b19e4b0e0172b02fd1f1ca895780384d49b02df3"`
[INFO] running `"docker" "rm" "-f" "572598c223c4ee4b659673c9b19e4b0e0172b02fd1f1ca895780384d49b02df3"`
[INFO] [stdout] 572598c223c4ee4b659673c9b19e4b0e0172b02fd1f1ca895780384d49b02df3
