[INFO] cloning repository https://github.com/hockeybuggy/ray_tracer
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/hockeybuggy/ray_tracer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fhockeybuggy%2Fray_tracer", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fhockeybuggy%2Fray_tracer'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 96f281ab3987e19249fe2d9afca38afa79b6e7db
[INFO] checking hockeybuggy/ray_tracer against master#bca37a20bd376ce3fd138e7cdee7fe704e0f8814 for pr-139493-3
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fhockeybuggy%2Fray_tracer" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/hockeybuggy/ray_tracer
[INFO] finished tweaking git repo https://github.com/hockeybuggy/ray_tracer
[INFO] tweaked toml for git repo https://github.com/hockeybuggy/ray_tracer written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/hockeybuggy/ray_tracer on toolchain bca37a20bd376ce3fd138e7cdee7fe704e0f8814
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/hockeybuggy/ray_tracer 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" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded weezl v0.1.0
[INFO] [stderr]   Downloaded wasm-bindgen-macro-support v0.2.67
[INFO] [stderr]   Downloaded wasm-bindgen-shared v0.2.67
[INFO] [stderr]   Downloaded wasm-bindgen-macro v0.2.67
[INFO] [stderr]   Downloaded assert_approx_eq v1.1.0
[INFO] [stderr]   Downloaded cast v0.2.3
[INFO] [stderr]   Downloaded wasm-bindgen-backend v0.2.67
[INFO] [stderr]   Downloaded criterion v0.3.3
[INFO] [stderr]   Downloaded wasm-bindgen v0.2.67
[INFO] [stderr]   Downloaded js-sys v0.3.44
[INFO] [stderr]   Downloaded web-sys v0.3.44
[INFO] [stderr]   Downloaded plotters v0.2.15
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] a644eb5b1f8fd942b7ac04e4e707526b0b1394e36c405832fa7161544436cc29
[INFO] running `Command { std: "docker" "start" "-a" "a644eb5b1f8fd942b7ac04e4e707526b0b1394e36c405832fa7161544436cc29", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "a644eb5b1f8fd942b7ac04e4e707526b0b1394e36c405832fa7161544436cc29", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a644eb5b1f8fd942b7ac04e4e707526b0b1394e36c405832fa7161544436cc29", kill_on_drop: false }`
[INFO] [stdout] a644eb5b1f8fd942b7ac04e4e707526b0b1394e36c405832fa7161544436cc29
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] e2c90dcf8f5c742e37b332a9fc8bde967463097cf9104db1031cc5b5298c7412
[INFO] running `Command { std: "docker" "start" "-a" "e2c90dcf8f5c742e37b332a9fc8bde967463097cf9104db1031cc5b5298c7412", kill_on_drop: false }`
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling memoffset v0.5.5
[INFO] [stderr]    Compiling libc v0.2.76
[INFO] [stderr]    Compiling num-traits v0.2.12
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]    Compiling serde v1.0.115
[INFO] [stderr]    Compiling rayon-core v1.7.1
[INFO] [stderr]     Checking either v1.6.0
[INFO] [stderr]    Compiling proc-macro2 v1.0.19
[INFO] [stderr]    Compiling memchr v2.3.3
[INFO] [stderr]    Compiling rayon v1.3.1
[INFO] [stderr]    Compiling num-integer v0.1.43
[INFO] [stderr]    Compiling cast v0.2.3
[INFO] [stderr]    Compiling serde_json v1.0.57
[INFO] [stderr]     Checking itoa v0.4.6
[INFO] [stderr]    Compiling syn v1.0.39
[INFO] [stderr]     Checking regex-automata v0.1.9
[INFO] [stderr]    Compiling num-iter v0.1.41
[INFO] [stderr]    Compiling num-rational v0.3.0
[INFO] [stderr]    Compiling serde_derive v1.0.115
[INFO] [stderr]     Checking itertools v0.9.0
[INFO] [stderr]     Checking deflate v0.8.6
[INFO] [stderr]     Checking half v1.6.0
[INFO] [stderr]     Checking regex-syntax v0.6.18
[INFO] [stderr]     Checking weezl v0.1.0
[INFO] [stderr]     Checking tiff v0.5.0
[INFO] [stderr]     Checking clap v2.33.3
[INFO] [stderr]     Checking oorandom v11.1.2
[INFO] [stderr]     Checking bytemuck v1.4.1
[INFO] [stderr]     Checking assert_approx_eq v1.1.0
[INFO] [stderr]     Checking csv-core v0.1.10
[INFO] [stderr]    Compiling quote v1.0.7
[INFO] [stderr]     Checking gif v0.11.1
[INFO] [stderr]     Checking png v0.16.7
[INFO] [stderr]     Checking crossbeam-queue v0.2.3
[INFO] [stderr]     Checking num_cpus v1.13.0
[INFO] [stderr]     Checking atty v0.2.14
[INFO] [stderr]     Checking criterion-plot v0.4.3
[INFO] [stderr]     Checking plotters v0.2.15
[INFO] [stderr]     Checking crossbeam-deque v0.7.3
[INFO] [stderr]     Checking regex v1.3.9
[INFO] [stderr]     Checking bstr v0.2.13
[INFO] [stderr]     Checking serde_cbor v0.11.1
[INFO] [stderr]     Checking jpeg-decoder v0.1.20
[INFO] [stderr]     Checking csv v1.1.3
[INFO] [stderr]     Checking image v0.23.10
[INFO] [stderr]     Checking tinytemplate v1.1.0
[INFO] [stderr]     Checking criterion v0.3.3
[INFO] [stderr]     Checking ray_tracer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]   --> src/canvas.rs:40:30
[INFO] [stdout]    |
[INFO] [stdout] 40 |         let clamp = |x: f64| (255.0_f64.min(x * 255.0).max(0.0) as u8);
[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] 40 -         let clamp = |x: f64| (255.0_f64.min(x * 255.0).max(0.0) as u8);
[INFO] [stdout] 40 +         let clamp = |x: f64| 255.0_f64.min(x * 255.0).max(0.0) as u8 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/ray.rs:23:69
[INFO] [stdout]    |
[INFO] [stdout] 23 |     pub fn intersect<'a>(&'a self, sphere: &'a shape::Shape) -> Vec<intersection::Intersection> {
[INFO] [stdout]    |                           --                --                      ^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                           |                 |
[INFO] [stdout]    |                           |                 the lifetime is named here
[INFO] [stdout]    |                           the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     pub fn intersect<'a>(&'a self, sphere: &'a shape::Shape) -> Vec<intersection::Intersection<'a>> {
[INFO] [stdout]    |                                                                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/ray.rs:50:14
[INFO] [stdout]    |
[INFO] [stdout] 48 |         &'a self,
[INFO] [stdout]    |          -- the lifetime is named here
[INFO] [stdout] 49 |         world: &'a world::World,
[INFO] [stdout]    |                 -- the lifetime is named here
[INFO] [stdout] 50 |     ) -> Vec<intersection::Intersection> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 50 |     ) -> Vec<intersection::Intersection<'a>> {
[INFO] [stdout]    |                                        ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/shape.rs:56:22
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn intersect(&self, ray: ray::Ray) -> Vec<intersection::Intersection> {
[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] 56 |     pub fn intersect(&self, ray: ray::Ray) -> Vec<intersection::Intersection<'_>> {
[INFO] [stdout]    |                                                                             ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/shape.rs:82:28
[INFO] [stdout]    |
[INFO] [stdout] 82 |     pub fn local_intersect(&self, local_ray: ray::Ray) -> Vec<intersection::Intersection> {
[INFO] [stdout]    |                            ^^^^^ the lifetime is elided here  ^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden 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] 82 |     pub fn local_intersect(&self, local_ray: ray::Ray) -> Vec<intersection::Intersection<'_>> {
[INFO] [stdout]    |                                                                                         ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/shape.rs:89:31
[INFO] [stdout]    |
[INFO] [stdout] 89 |     fn sphere_local_intersect(&self, _local_ray: ray::Ray) -> Vec<intersection::Intersection> {
[INFO] [stdout]    |                               ^^^^^ the lifetime is elided here   ^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden 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] 89 |     fn sphere_local_intersect(&self, _local_ray: ray::Ray) -> Vec<intersection::Intersection<'_>> {
[INFO] [stdout]    |                                                                                             ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/shape.rs:95:30
[INFO] [stdout]    |
[INFO] [stdout] 95 |     fn plane_local_intersect(&self, local_ray: ray::Ray) -> Vec<intersection::Intersection> {
[INFO] [stdout]    |                              ^^^^^ the lifetime is elided here  ^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden 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] 95 |     fn plane_local_intersect(&self, local_ray: ray::Ray) -> Vec<intersection::Intersection<'_>> {
[INFO] [stdout]    |                                                                                           ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/intersection.rs:16:37
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub fn intersection(t: f64, object: &shape::Shape) -> Intersection {
[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] 16 | pub fn intersection(t: f64, object: &shape::Shape) -> Intersection<'_> {
[INFO] [stdout]    |                                                                   ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]   --> src/canvas.rs:40:30
[INFO] [stdout]    |
[INFO] [stdout] 40 |         let clamp = |x: f64| (255.0_f64.min(x * 255.0).max(0.0) as u8);
[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] 40 -         let clamp = |x: f64| (255.0_f64.min(x * 255.0).max(0.0) as u8);
[INFO] [stdout] 40 +         let clamp = |x: f64| 255.0_f64.min(x * 255.0).max(0.0) as u8 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/ray.rs:23:69
[INFO] [stdout]    |
[INFO] [stdout] 23 |     pub fn intersect<'a>(&'a self, sphere: &'a shape::Shape) -> Vec<intersection::Intersection> {
[INFO] [stdout]    |                           --                --                      ^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                           |                 |
[INFO] [stdout]    |                           |                 the lifetime is named here
[INFO] [stdout]    |                           the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     pub fn intersect<'a>(&'a self, sphere: &'a shape::Shape) -> Vec<intersection::Intersection<'a>> {
[INFO] [stdout]    |                                                                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/ray.rs:50:14
[INFO] [stdout]    |
[INFO] [stdout] 48 |         &'a self,
[INFO] [stdout]    |          -- the lifetime is named here
[INFO] [stdout] 49 |         world: &'a world::World,
[INFO] [stdout]    |                 -- the lifetime is named here
[INFO] [stdout] 50 |     ) -> Vec<intersection::Intersection> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 50 |     ) -> Vec<intersection::Intersection<'a>> {
[INFO] [stdout]    |                                        ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/shape.rs:56:22
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn intersect(&self, ray: ray::Ray) -> Vec<intersection::Intersection> {
[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] 56 |     pub fn intersect(&self, ray: ray::Ray) -> Vec<intersection::Intersection<'_>> {
[INFO] [stdout]    |                                                                             ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/shape.rs:82:28
[INFO] [stdout]    |
[INFO] [stdout] 82 |     pub fn local_intersect(&self, local_ray: ray::Ray) -> Vec<intersection::Intersection> {
[INFO] [stdout]    |                            ^^^^^ the lifetime is elided here  ^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden 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] 82 |     pub fn local_intersect(&self, local_ray: ray::Ray) -> Vec<intersection::Intersection<'_>> {
[INFO] [stdout]    |                                                                                         ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/shape.rs:89:31
[INFO] [stdout]    |
[INFO] [stdout] 89 |     fn sphere_local_intersect(&self, _local_ray: ray::Ray) -> Vec<intersection::Intersection> {
[INFO] [stdout]    |                               ^^^^^ the lifetime is elided here   ^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden 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] 89 |     fn sphere_local_intersect(&self, _local_ray: ray::Ray) -> Vec<intersection::Intersection<'_>> {
[INFO] [stdout]    |                                                                                             ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/shape.rs:95:30
[INFO] [stdout]    |
[INFO] [stdout] 95 |     fn plane_local_intersect(&self, local_ray: ray::Ray) -> Vec<intersection::Intersection> {
[INFO] [stdout]    |                              ^^^^^ the lifetime is elided here  ^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden 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] 95 |     fn plane_local_intersect(&self, local_ray: ray::Ray) -> Vec<intersection::Intersection<'_>> {
[INFO] [stdout]    |                                                                                           ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/intersection.rs:16:37
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub fn intersection(t: f64, object: &shape::Shape) -> Intersection {
[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] 16 | pub fn intersection(t: f64, object: &shape::Shape) -> Intersection<'_> {
[INFO] [stdout]    |                                                                   ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 20.24s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: criterion v0.3.3
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 15`
[INFO] running `Command { std: "docker" "inspect" "e2c90dcf8f5c742e37b332a9fc8bde967463097cf9104db1031cc5b5298c7412", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e2c90dcf8f5c742e37b332a9fc8bde967463097cf9104db1031cc5b5298c7412", kill_on_drop: false }`
[INFO] [stdout] e2c90dcf8f5c742e37b332a9fc8bde967463097cf9104db1031cc5b5298c7412
