[INFO] cloning repository https://github.com/Ogeon/pyrite
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Ogeon/pyrite" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FOgeon%2Fpyrite", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FOgeon%2Fpyrite'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 971b11ee519ba593574abe912f70c29d6e31a072
[INFO] checking Ogeon/pyrite against 1.95.0 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FOgeon%2Fpyrite" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-2-tc1/source/.cargo/config
[INFO] started tweaking git repo https://github.com/Ogeon/pyrite
[INFO] finished tweaking git repo https://github.com/Ogeon/pyrite
[INFO] tweaked toml for git repo https://github.com/Ogeon/pyrite written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Ogeon/pyrite on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Ogeon/pyrite 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" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: virtual workspace defaulting to `resolver = "1"` despite one or more workspace members being on edition 2021 which implies `resolver = "2"`
[INFO] [stderr]   |
[INFO] [stderr]   = note: to keep the current resolver, specify `workspace.resolver = "1"` in the workspace root's manifest
[INFO] [stderr]   = note: to use the edition 2021 resolver, specify `workspace.resolver = "2"` in the workspace root's manifest
[INFO] [stderr]   = note: for more details see https://doc.rust-lang.org/cargo/reference/resolver.html#resolver-versions
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Updating git repository `https://github.com/Ogeon/palette`
[INFO] [stderr]     Updating git repository `https://github.com/Ogeon/typed_nodes`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded wasm-bindgen-macro v0.2.86
[INFO] [stderr]   Downloaded proc-macro2 v1.0.59
[INFO] [stderr]   Downloaded wasm-bindgen-shared v0.2.86
[INFO] [stderr]   Downloaded smallbox v0.8.1
[INFO] [stderr]   Downloaded autocfg v0.1.8
[INFO] [stderr]   Downloaded noisy_float v0.2.0
[INFO] [stderr]   Downloaded obj v0.10.2
[INFO] [stderr]   Downloaded wasm-bindgen-macro-support v0.2.86
[INFO] [stderr]   Downloaded pin-project-internal v1.1.0
[INFO] [stderr]   Downloaded portable-atomic v0.3.20
[INFO] [stderr]   Downloaded fast-srgb8 v1.0.0
[INFO] [stderr]   Downloaded console v0.15.7
[INFO] [stderr]   Downloaded bitflags v2.3.1
[INFO] [stderr]   Downloaded pin-project v1.1.0
[INFO] [stderr]   Downloaded cgmath v0.17.0
[INFO] [stderr]   Downloaded num-bigint v0.2.6
[INFO] [stderr]   Downloaded collision v0.20.1
[INFO] [stderr]   Downloaded portable-atomic v1.3.2
[INFO] [stderr]   Downloaded wasm-bindgen v0.2.86
[INFO] [stderr]   Downloaded indicatif v0.17.3
[INFO] [stderr]   Downloaded mlua v0.8.9
[INFO] [stderr]   Downloaded crossbeam-epoch v0.9.14
[INFO] [stderr]   Downloaded wasm-bindgen-backend v0.2.86
[INFO] [stderr]   Downloaded exr v1.6.3
[INFO] [stderr]   Downloaded lua-src v546.0.0
[INFO] [stderr]   Downloaded csv v1.2.1
[INFO] [stderr]   Downloaded luajit-src v210.4.5+resty2cf5186
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c655458e2323df37fcd97274f6698ec20cf7eb8576e4867be8e1d55bf720c7b9
[INFO] running `Command { std: "docker" "start" "-a" "c655458e2323df37fcd97274f6698ec20cf7eb8576e4867be8e1d55bf720c7b9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c655458e2323df37fcd97274f6698ec20cf7eb8576e4867be8e1d55bf720c7b9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c655458e2323df37fcd97274f6698ec20cf7eb8576e4867be8e1d55bf720c7b9", kill_on_drop: false }`
[INFO] [stdout] c655458e2323df37fcd97274f6698ec20cf7eb8576e4867be8e1d55bf720c7b9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d2abf1a373ac440ef5fa329e77f41311336664b4d2156697ea777b2dbcf7a089
[INFO] running `Command { std: "docker" "start" "-a" "d2abf1a373ac440ef5fa329e77f41311336664b4d2156697ea777b2dbcf7a089", kill_on_drop: false }`
[INFO] [stderr] warning: virtual workspace defaulting to `resolver = "1"` despite one or more workspace members being on edition 2021 which implies `resolver = "2"`
[INFO] [stderr]   |
[INFO] [stderr]   = note: to keep the current resolver, specify `workspace.resolver = "1"` in the workspace root's manifest
[INFO] [stderr]   = note: to use the edition 2021 resolver, specify `workspace.resolver = "2"` in the workspace root's manifest
[INFO] [stderr]   = note: for more details see https://doc.rust-lang.org/cargo/reference/resolver.html#resolver-versions
[INFO] [stderr]    Compiling libc v0.2.144
[INFO] [stderr]    Compiling proc-macro2 v1.0.59
[INFO] [stderr]    Compiling quote v1.0.28
[INFO] [stderr]    Compiling unicode-ident v1.0.9
[INFO] [stderr]    Compiling crossbeam-utils v0.8.15
[INFO] [stderr]     Checking cfg-if v1.0.0
[INFO] [stderr]    Compiling memoffset v0.8.0
[INFO] [stderr]    Compiling num-traits v0.2.15
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.14
[INFO] [stderr]    Compiling autocfg v0.1.8
[INFO] [stderr]    Compiling memchr v2.5.0
[INFO] [stderr]    Compiling rayon-core v1.11.0
[INFO] [stderr]    Compiling serde v1.0.163
[INFO] [stderr]     Checking scopeguard v1.1.0
[INFO] [stderr]    Compiling crc32fast v1.3.2
[INFO] [stderr]    Compiling lock_api v0.4.9
[INFO] [stderr]     Checking rand_core v0.4.2
[INFO] [stderr]    Compiling rand_chacha v0.1.1
[INFO] [stderr]    Compiling rand_pcg v0.1.2
[INFO] [stderr]    Compiling cc v1.0.79
[INFO] [stderr]    Compiling futures-core v0.3.28
[INFO] [stderr]     Checking getrandom v0.2.9
[INFO] [stderr]    Compiling lua-src v546.0.0
[INFO] [stderr]    Compiling luajit-src v210.4.5+resty2cf5186
[INFO] [stderr]    Compiling rand v0.6.5
[INFO] [stderr]    Compiling syn v2.0.18
[INFO] [stderr]    Compiling maybe-uninit v2.0.0
[INFO] [stderr]    Compiling pkg-config v0.3.27
[INFO] [stderr]     Checking simd-adler32 v0.3.5
[INFO] [stderr]    Compiling portable-atomic v1.3.2
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]     Checking crossbeam-deque v0.8.3
[INFO] [stderr]     Checking crossbeam-channel v0.5.8
[INFO] [stderr]     Checking rand_core v0.3.1
[INFO] [stderr]    Compiling mlua v0.8.9
[INFO] [stderr]     Checking adler v1.0.2
[INFO] [stderr]     Checking num_cpus v1.15.0
[INFO] [stderr]    Compiling slotmap v1.0.6
[INFO] [stderr]    Compiling ahash v0.8.3
[INFO] [stderr]    Compiling portable-atomic v0.3.20
[INFO] [stderr]    Compiling cgmath v0.17.0
[INFO] [stderr]    Compiling crossbeam-queue v0.3.8
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]    Compiling unicode-segmentation v1.10.1
[INFO] [stderr]     Checking miniz_oxide v0.7.1
[INFO] [stderr]    Compiling convert_case v0.6.0
[INFO] [stderr]    Compiling csv-core v0.1.10
[INFO] [stderr]     Checking either v1.8.1
[INFO] [stderr]    Compiling itoa v1.0.6
[INFO] [stderr]    Compiling ryu v1.0.13
[INFO] [stderr]    Compiling palette v0.7.2 (https://github.com/Ogeon/palette#598b2673)
[INFO] [stderr]     Checking rayon v1.7.0
[INFO] [stderr]     Checking flate2 v1.0.26
[INFO] [stderr]     Checking spin v0.9.8
[INFO] [stderr]     Checking rand_hc v0.1.0
[INFO] [stderr]     Checking rand_xorshift v0.1.1
[INFO] [stderr]     Checking rand_isaac v0.1.1
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking nanorand v0.7.0
[INFO] [stderr]     Checking rand_os v0.1.3
[INFO] [stderr]     Checking rand_jitter v0.1.4
[INFO] [stderr]     Checking once_cell v1.17.1
[INFO] [stderr]     Checking futures-sink v0.3.28
[INFO] [stderr]     Checking weezl v0.1.7
[INFO] [stderr]     Checking bstr v0.2.17
[INFO] [stderr]     Checking miniz_oxide v0.6.2
[INFO] [stderr]     Checking jpeg-decoder v0.3.0
[INFO] [stderr]     Checking approx v0.3.2
[INFO] [stderr]     Checking zune-inflate v0.2.54
[INFO] [stderr]     Checking fdeflate v0.3.0
[INFO] [stderr]     Checking color_quant v1.1.0
[INFO] [stderr]     Checking unicode-width v0.1.10
[INFO] [stderr]     Checking lazy_static v1.4.0
[INFO] [stderr]     Checking bytemuck v1.13.1
[INFO] [stderr]     Checking smallvec v1.10.0
[INFO] [stderr]     Checking ppv-lite86 v0.2.17
[INFO] [stderr]     Checking lebe v0.5.2
[INFO] [stderr]     Checking bit_field v0.10.2
[INFO] [stderr]     Checking bit-vec v0.6.3
[INFO] [stderr]     Checking half v2.2.1
[INFO] [stderr]     Checking bitflags v1.3.2
[INFO] [stderr]     Checking rustc-hash v1.1.0
[INFO] [stderr]     Checking bit-set v0.5.3
[INFO] [stderr]     Checking qoi v0.4.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking png v0.17.8
[INFO] [stderr]     Checking tiff v0.8.1
[INFO] [stderr]     Checking gif v0.12.0
[INFO] [stderr]     Checking console v0.15.7
[INFO] [stderr]     Checking smallvec v0.6.14
[INFO] [stderr]     Checking number_prefix v0.4.0
[INFO] [stderr]     Checking byteorder v1.4.3
[INFO] [stderr]     Checking smallbox v0.8.1
[INFO] [stderr]     Checking fast-srgb8 v1.0.0
[INFO] [stderr]     Checking downcast-rs v1.2.0
[INFO] [stderr]    Compiling serde_derive v1.0.163
[INFO] [stderr]    Compiling pin-project-internal v1.1.0
[INFO] [stderr]    Compiling typed_nodes_macros v0.1.0 (https://github.com/Ogeon/typed_nodes#653799b7)
[INFO] [stderr]    Compiling palette_derive v0.7.2 (https://github.com/Ogeon/palette#598b2673)
[INFO] [stderr]     Checking indicatif v0.17.3
[INFO] [stderr]     Checking crossbeam v0.8.2
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking rand_xorshift v0.3.0
[INFO] [stderr]     Checking noisy_float v0.2.0
[INFO] [stderr]     Checking pin-project v1.1.0
[INFO] [stderr]     Checking flume v0.10.14
[INFO] [stderr]     Checking bumpalo v3.13.0
[INFO] [stderr]     Checking path-slash v0.2.1
[INFO] [stderr]     Checking bitflags v2.3.1
[INFO] [stderr]     Checking exr v1.6.3
[INFO] [stderr]     Checking obj v0.10.2
[INFO] [stderr]     Checking image v0.24.6
[INFO] [stderr]    Compiling csv v1.2.1
[INFO] [stderr]    Compiling pyrite v0.0.0 (/opt/rustwide/workdir/pyrite)
[INFO] [stderr]     Checking collision v0.20.1
[INFO] [stderr]     Checking typed_nodes v0.1.0 (https://github.com/Ogeon/typed_nodes#653799b7)
[INFO] [stdout] warning: field `file` is never read
[INFO] [stdout]    --> pyrite/src/main.rs:430:5
[INFO] [stdout]     |
[INFO] [stdout] 427 | struct ImageSettings<'a> {
[INFO] [stdout]     |        ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 430 |     file: Option<String>,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ExpressionId` is never constructed
[INFO] [stdout]    --> pyrite/src/project/expressions.rs:458:12
[INFO] [stdout]     |
[INFO] [stdout] 458 | pub struct ExpressionId(usize);
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MaterialId` is never constructed
[INFO] [stdout]   --> pyrite/src/project/materials.rs:44:19
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub(crate) struct MaterialId(usize);
[INFO] [stdout]    |                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `TableExt` is never used
[INFO] [stdout]   --> pyrite/src/project/tables.rs:21:11
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub trait TableExt {
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TableId` is never constructed
[INFO] [stdout]   --> pyrite/src/project/tables.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct TableId(usize);
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `probability` is never read
[INFO] [stdout]    --> pyrite/src/renderer/photon_mapping.rs:443:5
[INFO] [stdout]     |
[INFO] [stdout] 438 | struct CameraBounce<'a> {
[INFO] [stdout]     |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 443 |     probability: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `probability` is never read
[INFO] [stdout]    --> pyrite/src/renderer/photon_mapping.rs:520:5
[INFO] [stdout]     |
[INFO] [stdout] 516 | struct LightBounce<'a> {
[INFO] [stdout]     |        ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 520 |     probability: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LightSource` is never constructed
[INFO] [stdout]    --> pyrite/src/renderer/photon_mapping.rs:565:8
[INFO] [stdout]     |
[INFO] [stdout] 565 | struct LightSource<'a> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Light` is never constructed
[INFO] [stdout]    --> pyrite/src/tracer.rs:203:12
[INFO] [stdout]     |
[INFO] [stdout] 203 | pub struct Light {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> pyrite/src/film.rs:97:28
[INFO] [stdout]    |
[INFO] [stdout] 97 |     pub fn get_pixel_ref_f(&self, position: Point2<f32>) -> Option<DetachedPixel> {
[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]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 97 |     pub fn get_pixel_ref_f(&self, position: Point2<f32>) -> Option<DetachedPixel<'_>> {
[INFO] [stdout]    |                                                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> pyrite/src/shapes/mod.rs:55:26
[INFO] [stdout]    |
[INFO] [stdout] 55 |     pub fn ray_intersect(&self, ray: &Ray3<f32>) -> Option<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] 55 |     pub fn ray_intersect(&self, ray: &Ray3<f32>) -> Option<Intersection<'_>> {
[INFO] [stdout]    |                                                                        ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/shapes/mod.rs:158:25
[INFO] [stdout]     |
[INFO] [stdout] 158 |     pub fn get_material(&self) -> Material {
[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] 158 |     pub fn get_material(&self) -> Material<'_> {
[INFO] [stdout]     |                                           ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/shapes/mod.rs:166:25
[INFO] [stdout]     |
[INFO] [stdout] 166 |     pub fn sample_point(&self, rng: &mut impl Rng) -> Option<SurfacePoint> {
[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] 166 |     pub fn sample_point(&self, rng: &mut impl Rng) -> Option<SurfacePoint<'_>> {
[INFO] [stdout]     |                                                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/shapes/mod.rs:209:27
[INFO] [stdout]     |
[INFO] [stdout] 209 |     pub fn sample_towards(&self, rng: &mut impl Rng, target: &Point3<f32>) -> Option<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] 209 |     pub fn sample_towards(&self, rng: &mut impl Rng, target: &Point3<f32>) -> Option<Intersection<'_>> {
[INFO] [stdout]     |                                                                                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/shapes/mod.rs:442:26
[INFO] [stdout]     |
[INFO] [stdout] 442 |     pub fn ray_intersect(&self, ray: &Ray3<f32>) -> Option<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] 442 |     pub fn ray_intersect(&self, ray: &Ray3<f32>) -> Option<Intersection<'_>> {
[INFO] [stdout]     |                                                                        ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/spatial/bvh.rs:159:26
[INFO] [stdout]     |
[INFO] [stdout] 159 |     pub fn ray_intersect(&self, ray: Ray3<f32>) -> Intersections<T> {
[INFO] [stdout]     |                          ^^^^^                     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 159 |     pub fn ray_intersect(&self, ray: Ray3<f32>) -> Intersections<'_, T> {
[INFO] [stdout]     |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> pyrite/src/spatial/kd_tree.rs:37:83
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub fn neighbors<'a>(&'a self, point: &'a E::Point, radius: f32) -> Neighbors<'_, E> {
[INFO] [stdout]    |                           --               -- the lifetime is named here          ^^ the same lifetime is elided here
[INFO] [stdout]    |                           |
[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] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 37 -     pub fn neighbors<'a>(&'a self, point: &'a E::Point, radius: f32) -> Neighbors<'_, E> {
[INFO] [stdout] 37 +     pub fn neighbors<'a>(&'a self, point: &'a E::Point, radius: f32) -> Neighbors<'a, E> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/world.rs:273:22
[INFO] [stdout]     |
[INFO] [stdout] 273 |     pub fn intersect(&self, ray: Ray3<f32>) -> Option<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] 273 |     pub fn intersect(&self, ray: Ray3<f32>) -> Option<Intersection<'_>> {
[INFO] [stdout]     |                                                                   ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/world.rs:301:22
[INFO] [stdout]     |
[INFO] [stdout] 301 |     pub fn pick_lamp(&self, rng: &mut impl Rng) -> Option<(&Lamp, f32)> {
[INFO] [stdout]     |                      ^^^^^                                 ^^^^^
[INFO] [stdout]     |                      |                                     ||
[INFO] [stdout]     |                      |                                     |the same lifetime is hidden here
[INFO] [stdout]     |                      the lifetime is elided here           the same 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] 301 |     pub fn pick_lamp(&self, rng: &mut impl Rng) -> Option<(&Lamp<'_>, f32)> {
[INFO] [stdout]     |                                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> pyrite/src/film.rs:97:28
[INFO] [stdout]    |
[INFO] [stdout] 97 |     pub fn get_pixel_ref_f(&self, position: Point2<f32>) -> Option<DetachedPixel> {
[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]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 97 |     pub fn get_pixel_ref_f(&self, position: Point2<f32>) -> Option<DetachedPixel<'_>> {
[INFO] [stdout]    |                                                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> pyrite/src/shapes/mod.rs:55:26
[INFO] [stdout]    |
[INFO] [stdout] 55 |     pub fn ray_intersect(&self, ray: &Ray3<f32>) -> Option<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] 55 |     pub fn ray_intersect(&self, ray: &Ray3<f32>) -> Option<Intersection<'_>> {
[INFO] [stdout]    |                                                                        ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/shapes/mod.rs:158:25
[INFO] [stdout]     |
[INFO] [stdout] 158 |     pub fn get_material(&self) -> Material {
[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] 158 |     pub fn get_material(&self) -> Material<'_> {
[INFO] [stdout]     |                                           ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/shapes/mod.rs:166:25
[INFO] [stdout]     |
[INFO] [stdout] 166 |     pub fn sample_point(&self, rng: &mut impl Rng) -> Option<SurfacePoint> {
[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] 166 |     pub fn sample_point(&self, rng: &mut impl Rng) -> Option<SurfacePoint<'_>> {
[INFO] [stdout]     |                                                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/shapes/mod.rs:209:27
[INFO] [stdout]     |
[INFO] [stdout] 209 |     pub fn sample_towards(&self, rng: &mut impl Rng, target: &Point3<f32>) -> Option<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] 209 |     pub fn sample_towards(&self, rng: &mut impl Rng, target: &Point3<f32>) -> Option<Intersection<'_>> {
[INFO] [stdout]     |                                                                                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/shapes/mod.rs:442:26
[INFO] [stdout]     |
[INFO] [stdout] 442 |     pub fn ray_intersect(&self, ray: &Ray3<f32>) -> Option<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] 442 |     pub fn ray_intersect(&self, ray: &Ray3<f32>) -> Option<Intersection<'_>> {
[INFO] [stdout]     |                                                                        ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/spatial/bvh.rs:159:26
[INFO] [stdout]     |
[INFO] [stdout] 159 |     pub fn ray_intersect(&self, ray: Ray3<f32>) -> Intersections<T> {
[INFO] [stdout]     |                          ^^^^^                     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 159 |     pub fn ray_intersect(&self, ray: Ray3<f32>) -> Intersections<'_, T> {
[INFO] [stdout]     |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> pyrite/src/spatial/kd_tree.rs:37:83
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub fn neighbors<'a>(&'a self, point: &'a E::Point, radius: f32) -> Neighbors<'_, E> {
[INFO] [stdout]    |                           --               -- the lifetime is named here          ^^ the same lifetime is elided here
[INFO] [stdout]    |                           |
[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] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 37 -     pub fn neighbors<'a>(&'a self, point: &'a E::Point, radius: f32) -> Neighbors<'_, E> {
[INFO] [stdout] 37 +     pub fn neighbors<'a>(&'a self, point: &'a E::Point, radius: f32) -> Neighbors<'a, E> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/world.rs:273:22
[INFO] [stdout]     |
[INFO] [stdout] 273 |     pub fn intersect(&self, ray: Ray3<f32>) -> Option<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] 273 |     pub fn intersect(&self, ray: Ray3<f32>) -> Option<Intersection<'_>> {
[INFO] [stdout]     |                                                                   ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> pyrite/src/world.rs:301:22
[INFO] [stdout]     |
[INFO] [stdout] 301 |     pub fn pick_lamp(&self, rng: &mut impl Rng) -> Option<(&Lamp, f32)> {
[INFO] [stdout]     |                      ^^^^^                                 ^^^^^
[INFO] [stdout]     |                      |                                     ||
[INFO] [stdout]     |                      |                                     |the same lifetime is hidden here
[INFO] [stdout]     |                      the lifetime is elided here           the same 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] 301 |     pub fn pick_lamp(&self, rng: &mut impl Rng) -> Option<(&Lamp<'_>, f32)> {
[INFO] [stdout]     |                                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [optimized + debuginfo] target(s) in 1m 52s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: mlua v0.8.9
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] running `Command { std: "docker" "inspect" "d2abf1a373ac440ef5fa329e77f41311336664b4d2156697ea777b2dbcf7a089", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d2abf1a373ac440ef5fa329e77f41311336664b4d2156697ea777b2dbcf7a089", kill_on_drop: false }`
[INFO] [stdout] d2abf1a373ac440ef5fa329e77f41311336664b4d2156697ea777b2dbcf7a089
