[INFO] cloning repository https://github.com/StepfenShawn/ferrum_cloud
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/StepfenShawn/ferrum_cloud" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FStepfenShawn%2Fferrum_cloud", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FStepfenShawn%2Fferrum_cloud'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] d2a7dfa2bfbc17d1fe20c6c6a87b38e475283a0f
[INFO] testing StepfenShawn/ferrum_cloud against try#db823df02fd0c2cf67b43025ac3fef3f2d743245 for pr-150681
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FStepfenShawn%2Fferrum_cloud" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/StepfenShawn/ferrum_cloud
[INFO] finished tweaking git repo https://github.com/StepfenShawn/ferrum_cloud
[INFO] tweaked toml for git repo https://github.com/StepfenShawn/ferrum_cloud written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/StepfenShawn/ferrum_cloud on toolchain db823df02fd0c2cf67b43025ac3fef3f2d743245
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/StepfenShawn/ferrum_cloud 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" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] eb5e3262d5c6ad809405b1ea22f4dfe08f4f8b001a5e2c235c0533be68db0d1c
[INFO] running `Command { std: "docker" "start" "-a" "eb5e3262d5c6ad809405b1ea22f4dfe08f4f8b001a5e2c235c0533be68db0d1c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "eb5e3262d5c6ad809405b1ea22f4dfe08f4f8b001a5e2c235c0533be68db0d1c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "eb5e3262d5c6ad809405b1ea22f4dfe08f4f8b001a5e2c235c0533be68db0d1c", kill_on_drop: false }`
[INFO] [stdout] eb5e3262d5c6ad809405b1ea22f4dfe08f4f8b001a5e2c235c0533be68db0d1c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 70cd98b49e3577a1e46a3d5ab27987d7ec732e78439bb93949af7f00b1eae54c
[INFO] running `Command { std: "docker" "start" "-a" "70cd98b49e3577a1e46a3d5ab27987d7ec732e78439bb93949af7f00b1eae54c", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.95
[INFO] [stderr]    Compiling unicode-ident v1.0.18
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling libc v0.2.172
[INFO] [stderr]    Compiling rustix v1.0.7
[INFO] [stderr]    Compiling version_check v0.9.5
[INFO] [stderr]    Compiling ryu v1.0.20
[INFO] [stderr]    Compiling memchr v2.7.4
[INFO] [stderr]    Compiling semver v1.0.26
[INFO] [stderr]    Compiling camino v1.1.10
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling bitflags v2.9.1
[INFO] [stderr]    Compiling itoa v1.0.15
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling linux-raw-sys v0.9.4
[INFO] [stderr]    Compiling cfg-if v1.0.0
[INFO] [stderr]    Compiling pulldown-cmark v0.9.6
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling unicase v2.8.1
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling glob v0.3.2
[INFO] [stderr]    Compiling error-chain v0.12.4
[INFO] [stderr]    Compiling autocfg v1.4.0
[INFO] [stderr]    Compiling bytecount v0.6.9
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling walkdir v2.5.0
[INFO] [stderr]    Compiling peg-runtime v0.6.3
[INFO] [stderr]    Compiling rayon-core v1.12.1
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling regex-syntax v0.8.5
[INFO] [stderr]    Compiling anyhow v1.0.98
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling syn v2.0.101
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling linked-hash-map v0.5.6
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling peg-macros v0.6.3
[INFO] [stderr]    Compiling crossbeam-deque v0.8.6
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling crossbeam v0.8.4
[INFO] [stderr]    Compiling rayon v1.10.0
[INFO] [stderr]    Compiling memmap2 v0.9.5
[INFO] [stderr]    Compiling peg v0.6.3
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling tempfile v3.20.0
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling pcd-rs v0.12.0
[INFO] [stderr]    Compiling cargo-platform v0.1.9
[INFO] [stderr]    Compiling cargo_metadata v0.14.2
[INFO] [stderr]    Compiling skeptic v0.13.7
[INFO] [stderr]    Compiling ply-rs v0.1.3
[INFO] [stderr]    Compiling ferrum_cloud v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `CloudError`
[INFO] [stdout]  --> src/algorithms/feature.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CloudError`
[INFO] [stdout]  --> src/algorithms/filter.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CloudError`
[INFO] [stdout]  --> src/algorithms/registration.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HashMap` and `HashSet`
[INFO] [stdout]  --> src/algorithms/segmentation.rs:9:24
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                        ^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CloudError` and `Result`
[INFO] [stdout]  --> src/core/cloud.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CloudError` and `Result`
[INFO] [stdout]  --> src/search/kdtree.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CloudError` and `Result`
[INFO] [stdout]  --> src/search/octree.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/algorithms/filter.rs:55:17
[INFO] [stdout]    |
[INFO] [stdout] 55 |             let mut result = points.into_iter().next().unwrap();
[INFO] [stdout]    |                 ----^^^^^^
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `avg_pos`
[INFO] [stdout]   --> src/algorithms/filter.rs:50:17
[INFO] [stdout]    |
[INFO] [stdout] 50 |             let avg_pos = [sum[0] / count, sum[1] / count, sum[2] / count];
[INFO] [stdout]    |                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_avg_pos`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transformed_pos`
[INFO] [stdout]   --> src/algorithms/registration.rs:45:13
[INFO] [stdout]    |
[INFO] [stdout] 45 |         let transformed_pos = apply_transform(pos, transform);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transformed_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `point`
[INFO] [stdout]   --> src/algorithms/segmentation.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 |     for (i, point) in cloud.iter().enumerate() {
[INFO] [stdout]    |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_point`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `axis` is never read
[INFO] [stdout]   --> src/search/kdtree.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | struct KdNode<P: Point> {
[INFO] [stdout]    |        ------ field in this struct
[INFO] [stdout] 19 |     point: P,
[INFO] [stdout] 20 |     axis: usize, // 0=x, 1=y, 2=z
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:132:17
[INFO] [stdout]     |
[INFO] [stdout] 132 |     pub fn iter(&self) -> std::slice::Iter<P> {
[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]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 132 |     pub fn iter(&self) -> std::slice::Iter<'_, P> {
[INFO] [stdout]     |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:137:21
[INFO] [stdout]     |
[INFO] [stdout] 137 |     pub fn iter_mut(&mut self) -> std::slice::IterMut<P> {
[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] 137 |     pub fn iter_mut(&mut self) -> std::slice::IterMut<'_, P> {
[INFO] [stdout]     |                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:142:21
[INFO] [stdout]     |
[INFO] [stdout] 142 |     pub fn par_iter(&self) -> rayon::slice::Iter<P> {
[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] 142 |     pub fn par_iter(&self) -> rayon::slice::Iter<'_, P> {
[INFO] [stdout]     |                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:147:25
[INFO] [stdout]     |
[INFO] [stdout] 147 |     pub fn par_iter_mut(&mut self) -> rayon::slice::IterMut<P> {
[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] 147 |     pub fn par_iter_mut(&mut self) -> rayon::slice::IterMut<'_, P> {
[INFO] [stdout]     |                                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 28.84s
[INFO] running `Command { std: "docker" "inspect" "70cd98b49e3577a1e46a3d5ab27987d7ec732e78439bb93949af7f00b1eae54c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "70cd98b49e3577a1e46a3d5ab27987d7ec732e78439bb93949af7f00b1eae54c", kill_on_drop: false }`
[INFO] [stdout] 70cd98b49e3577a1e46a3d5ab27987d7ec732e78439bb93949af7f00b1eae54c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f9b672c9368ac411d5d48bfce32ff962e400cd86e0f4b7872f2b6548669dd13a
[INFO] running `Command { std: "docker" "start" "-a" "f9b672c9368ac411d5d48bfce32ff962e400cd86e0f4b7872f2b6548669dd13a", kill_on_drop: false }`
[INFO] [stderr]    Compiling cfg-if v1.0.0
[INFO] [stderr]    Compiling bitflags v2.9.1
[INFO] [stderr]    Compiling linux-raw-sys v0.9.4
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling rustix v1.0.7
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling pulldown-cmark v0.9.6
[INFO] [stderr]    Compiling tempfile v3.20.0
[INFO] [stderr]    Compiling skeptic v0.13.7
[INFO] [stderr]    Compiling ply-rs v0.1.3
[INFO] [stderr]    Compiling ferrum_cloud v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `CloudError`
[INFO] [stdout]  --> src/algorithms/feature.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CloudError`
[INFO] [stdout]  --> src/algorithms/filter.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CloudError`
[INFO] [stdout]  --> src/algorithms/registration.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HashMap` and `HashSet`
[INFO] [stdout]  --> src/algorithms/segmentation.rs:9:24
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                        ^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CloudError` and `Result`
[INFO] [stdout]  --> src/core/cloud.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CloudError` and `Result`
[INFO] [stdout]  --> src/search/kdtree.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CloudError` and `Result`
[INFO] [stdout]  --> src/search/octree.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CloudError`
[INFO] [stdout]  --> src/algorithms/feature.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CloudError`
[INFO] [stdout]  --> src/algorithms/filter.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CloudError`
[INFO] [stdout]  --> src/algorithms/registration.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HashMap` and `HashSet`
[INFO] [stdout]  --> src/algorithms/segmentation.rs:9:24
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                        ^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CloudError` and `Result`
[INFO] [stdout]  --> src/core/cloud.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CloudError` and `Result`
[INFO] [stdout]  --> src/search/kdtree.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CloudError` and `Result`
[INFO] [stdout]  --> src/search/octree.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::error::{CloudError, Result};
[INFO] [stdout]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/algorithms/filter.rs:55:17
[INFO] [stdout]    |
[INFO] [stdout] 55 |             let mut result = points.into_iter().next().unwrap();
[INFO] [stdout]    |                 ----^^^^^^
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `avg_pos`
[INFO] [stdout]   --> src/algorithms/filter.rs:50:17
[INFO] [stdout]    |
[INFO] [stdout] 50 |             let avg_pos = [sum[0] / count, sum[1] / count, sum[2] / count];
[INFO] [stdout]    |                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_avg_pos`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transformed_pos`
[INFO] [stdout]   --> src/algorithms/registration.rs:45:13
[INFO] [stdout]    |
[INFO] [stdout] 45 |         let transformed_pos = apply_transform(pos, transform);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transformed_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `point`
[INFO] [stdout]   --> src/algorithms/segmentation.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 |     for (i, point) in cloud.iter().enumerate() {
[INFO] [stdout]    |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_point`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `axis` is never read
[INFO] [stdout]   --> src/search/kdtree.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | struct KdNode<P: Point> {
[INFO] [stdout]    |        ------ field in this struct
[INFO] [stdout] 19 |     point: P,
[INFO] [stdout] 20 |     axis: usize, // 0=x, 1=y, 2=z
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:132:17
[INFO] [stdout]     |
[INFO] [stdout] 132 |     pub fn iter(&self) -> std::slice::Iter<P> {
[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]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 132 |     pub fn iter(&self) -> std::slice::Iter<'_, P> {
[INFO] [stdout]     |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:137:21
[INFO] [stdout]     |
[INFO] [stdout] 137 |     pub fn iter_mut(&mut self) -> std::slice::IterMut<P> {
[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] 137 |     pub fn iter_mut(&mut self) -> std::slice::IterMut<'_, P> {
[INFO] [stdout]     |                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:142:21
[INFO] [stdout]     |
[INFO] [stdout] 142 |     pub fn par_iter(&self) -> rayon::slice::Iter<P> {
[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] 142 |     pub fn par_iter(&self) -> rayon::slice::Iter<'_, P> {
[INFO] [stdout]     |                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:147:25
[INFO] [stdout]     |
[INFO] [stdout] 147 |     pub fn par_iter_mut(&mut self) -> rayon::slice::IterMut<P> {
[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] 147 |     pub fn par_iter_mut(&mut self) -> rayon::slice::IterMut<'_, P> {
[INFO] [stdout]     |                                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/algorithms/filter.rs:55:17
[INFO] [stdout]    |
[INFO] [stdout] 55 |             let mut result = points.into_iter().next().unwrap();
[INFO] [stdout]    |                 ----^^^^^^
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `avg_pos`
[INFO] [stdout]   --> src/algorithms/filter.rs:50:17
[INFO] [stdout]    |
[INFO] [stdout] 50 |             let avg_pos = [sum[0] / count, sum[1] / count, sum[2] / count];
[INFO] [stdout]    |                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_avg_pos`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transformed_pos`
[INFO] [stdout]   --> src/algorithms/registration.rs:45:13
[INFO] [stdout]    |
[INFO] [stdout] 45 |         let transformed_pos = apply_transform(pos, transform);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transformed_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `point`
[INFO] [stdout]   --> src/algorithms/segmentation.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 |     for (i, point) in cloud.iter().enumerate() {
[INFO] [stdout]    |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_point`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `axis` is never read
[INFO] [stdout]   --> src/search/kdtree.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | struct KdNode<P: Point> {
[INFO] [stdout]    |        ------ field in this struct
[INFO] [stdout] 19 |     point: P,
[INFO] [stdout] 20 |     axis: usize, // 0=x, 1=y, 2=z
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:132:17
[INFO] [stdout]     |
[INFO] [stdout] 132 |     pub fn iter(&self) -> std::slice::Iter<P> {
[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]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 132 |     pub fn iter(&self) -> std::slice::Iter<'_, P> {
[INFO] [stdout]     |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:137:21
[INFO] [stdout]     |
[INFO] [stdout] 137 |     pub fn iter_mut(&mut self) -> std::slice::IterMut<P> {
[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] 137 |     pub fn iter_mut(&mut self) -> std::slice::IterMut<'_, P> {
[INFO] [stdout]     |                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:142:21
[INFO] [stdout]     |
[INFO] [stdout] 142 |     pub fn par_iter(&self) -> rayon::slice::Iter<P> {
[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] 142 |     pub fn par_iter(&self) -> rayon::slice::Iter<'_, P> {
[INFO] [stdout]     |                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/core/cloud.rs:147:25
[INFO] [stdout]     |
[INFO] [stdout] 147 |     pub fn par_iter_mut(&mut self) -> rayon::slice::IterMut<P> {
[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] 147 |     pub fn par_iter_mut(&mut self) -> rayon::slice::IterMut<'_, P> {
[INFO] [stdout]     |                                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 8.29s
[INFO] running `Command { std: "docker" "inspect" "f9b672c9368ac411d5d48bfce32ff962e400cd86e0f4b7872f2b6548669dd13a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f9b672c9368ac411d5d48bfce32ff962e400cd86e0f4b7872f2b6548669dd13a", kill_on_drop: false }`
[INFO] [stdout] f9b672c9368ac411d5d48bfce32ff962e400cd86e0f4b7872f2b6548669dd13a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] d8b5957715afbf736b6126594ad76fa126afb3861295541803462f62f390a477
[INFO] running `Command { std: "docker" "start" "-a" "d8b5957715afbf736b6126594ad76fa126afb3861295541803462f62f390a477", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `CloudError`
[INFO] [stderr]  --> src/algorithms/feature.rs:7:20
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::error::{CloudError, Result};
[INFO] [stderr]   |                    ^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `CloudError`
[INFO] [stderr]  --> src/algorithms/filter.rs:7:20
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::error::{CloudError, Result};
[INFO] [stderr]   |                    ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `CloudError`
[INFO] [stderr]  --> src/algorithms/registration.rs:7:20
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::error::{CloudError, Result};
[INFO] [stderr]   |                    ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `HashMap` and `HashSet`
[INFO] [stderr]  --> src/algorithms/segmentation.rs:9:24
[INFO] [stderr]   |
[INFO] [stderr] 9 | use std::collections::{HashMap, HashSet};
[INFO] [stderr]   |                        ^^^^^^^  ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `CloudError` and `Result`
[INFO] [stderr]  --> src/core/cloud.rs:7:20
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::error::{CloudError, Result};
[INFO] [stderr]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `CloudError` and `Result`
[INFO] [stderr]  --> src/search/kdtree.rs:7:20
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::error::{CloudError, Result};
[INFO] [stderr]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `CloudError` and `Result`
[INFO] [stderr]  --> src/search/octree.rs:7:20
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::error::{CloudError, Result};
[INFO] [stderr]   |                    ^^^^^^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/algorithms/filter.rs:55:17
[INFO] [stderr]    |
[INFO] [stderr] 55 |             let mut result = points.into_iter().next().unwrap();
[INFO] [stderr]    |                 ----^^^^^^
[INFO] [stderr]    |                 |
[INFO] [stderr]    |                 help: remove this `mut`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `avg_pos`
[INFO] [stderr]   --> src/algorithms/filter.rs:50:17
[INFO] [stderr]    |
[INFO] [stderr] 50 |             let avg_pos = [sum[0] / count, sum[1] / count, sum[2] / count];
[INFO] [stderr]    |                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_avg_pos`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `transformed_pos`
[INFO] [stderr]   --> src/algorithms/registration.rs:45:13
[INFO] [stderr]    |
[INFO] [stderr] 45 |         let transformed_pos = apply_transform(pos, transform);
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transformed_pos`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `point`
[INFO] [stderr]   --> src/algorithms/segmentation.rs:23:13
[INFO] [stderr]    |
[INFO] [stderr] 23 |     for (i, point) in cloud.iter().enumerate() {
[INFO] [stderr]    |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_point`
[INFO] [stderr] 
[INFO] [stderr] warning: field `axis` is never read
[INFO] [stderr]   --> src/search/kdtree.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 18 | struct KdNode<P: Point> {
[INFO] [stderr]    |        ------ field in this struct
[INFO] [stderr] 19 |     point: P,
[INFO] [stderr] 20 |     axis: usize, // 0=x, 1=y, 2=z
[INFO] [stderr]    |     ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/core/cloud.rs:132:17
[INFO] [stderr]     |
[INFO] [stderr] 132 |     pub fn iter(&self) -> std::slice::Iter<P> {
[INFO] [stderr]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 132 |     pub fn iter(&self) -> std::slice::Iter<'_, P> {
[INFO] [stderr]     |                                            +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/core/cloud.rs:137:21
[INFO] [stderr]     |
[INFO] [stderr] 137 |     pub fn iter_mut(&mut self) -> std::slice::IterMut<P> {
[INFO] [stderr]     |                     ^^^^^^^^^     ^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 137 |     pub fn iter_mut(&mut self) -> std::slice::IterMut<'_, P> {
[INFO] [stderr]     |                                                       +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/core/cloud.rs:142:21
[INFO] [stderr]     |
[INFO] [stderr] 142 |     pub fn par_iter(&self) -> rayon::slice::Iter<P> {
[INFO] [stderr]     |                     ^^^^^     ^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 142 |     pub fn par_iter(&self) -> rayon::slice::Iter<'_, P> {
[INFO] [stderr]     |                                                  +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/core/cloud.rs:147:25
[INFO] [stderr]     |
[INFO] [stderr] 147 |     pub fn par_iter_mut(&mut self) -> rayon::slice::IterMut<P> {
[INFO] [stderr]     |                         ^^^^^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                         |
[INFO] [stderr]     |                         the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 147 |     pub fn par_iter_mut(&mut self) -> rayon::slice::IterMut<'_, P> {
[INFO] [stderr]     |                                                             +++
[INFO] [stderr] 
[INFO] [stderr] warning: `ferrum_cloud` (lib) generated 16 warnings (run `cargo fix --lib -p ferrum_cloud` to apply 15 suggestions)
[INFO] [stderr] warning: `ferrum_cloud` (lib test) generated 16 warnings (16 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.20s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/ferrum_cloud-0e63c7dd8805d6bf)
[INFO] [stdout] 
[INFO] [stdout] running 37 tests
[INFO] [stdout] test algorithms::registration::tests::test_icp_placeholder ... ok
[INFO] [stdout] test algorithms::segmentation::tests::test_euclidean_clustering ... ok
[INFO] [stdout] test algorithms::segmentation::tests::test_ransac_plane ... ok
[INFO] [stdout] test core::cloud::tests::test_point_cloud_from_points ... ok
[INFO] [stdout] test core::cloud::tests::test_point_cloud_operations ... ok
[INFO] [stdout] test core::cloud::tests::test_point_cloud_creation ... ok
[INFO] [stdout] test core::metadata::tests::test_organized_metadata ... ok
[INFO] [stdout] test core::metadata::tests::test_metadata_creation ... ok
[INFO] [stdout] test algorithms::registration::tests::test_identity_transform ... ok
[INFO] [stdout] test core::point::tests::test_point_distance ... ok
[INFO] [stdout] test core::point::tests::test_point_xyz_creation ... ok
[INFO] [stdout] test algorithms::filter::tests::test_voxel_downsample ... ok
[INFO] [stdout] test algorithms::filter::tests::test_pass_through_filter ... ok
[INFO] [stdout] test core::cloud::tests::test_filter ... ok
[INFO] [stdout] test core::cloud::tests::test_centroid ... ok
[INFO] [stdout] test algorithms::filter::tests::test_radius_outlier_removal ... ok
[INFO] [stdout] test core::cloud::tests::test_bounding_box ... ok
[INFO] [stdout] test core::view::tests::test_view_slice ... ok
[INFO] [stdout] test core::view::tests::test_point_cloud_view_creation ... ok
[INFO] [stdout] test io::las::tests::test_las_not_implemented ... ok
[INFO] [stdout] test core::point::tests::test_point_xyz_rgb ... ok
[INFO] [stdout] test core::view::tests::test_view_operations ... ok
[INFO] [stdout] test search::kdtree::tests::test_kdtree_build ... ok
[INFO] [stdout] test search::octree::tests::test_octree_build ... ok
[INFO] [stdout] test core::metadata::tests::test_custom_fields ... ok
[INFO] [stdout] test search::kdtree::tests::test_nearest_neighbor ... ok
[INFO] [stdout] test search::kdtree::tests::test_radius_search ... ok
[INFO] [stdout] test utils::tests::test_statistics ... ok
[INFO] [stdout] test tests::test_basic_point_creation ... ok
[INFO] [stdout] test search::octree::tests::test_bounding_box ... ok
[INFO] [stdout] test search::octree::tests::test_octree_radius_search ... ok
[INFO] [stdout] test utils::tests::test_color_conversion ... ok
[INFO] [stdout] test utils::tests::test_math_functions ... ok
[INFO] [stdout] test tests::test_point_cloud_creation ... ok
[INFO] [stdout] test io::pcd::tests::test_pcd_roundtrip ... ok
[INFO] [stdout] test io::ply::tests::test_ply_roundtrip ... ok
[INFO] [stdout] test utils::tests::test_timer ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 37 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests ferrum_cloud
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test src/lib.rs - (line 43) - compile ... FAILED
[INFO] [stdout] test src/lib.rs - (line 19) ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/lib.rs - (line 43) stdout ----
[INFO] [stdout] error[E0433]: failed to resolve: use of unresolved module or unlinked crate `tokio`
[INFO] [stdout]   --> src/lib.rs:47:3
[INFO] [stdout]    |
[INFO] [stdout] 47 | #[tokio::main]
[INFO] [stdout]    |   ^^^^^ use of unresolved module or unlinked crate `tokio`
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `PointCloudViewer`
[INFO] [stdout]   --> src/lib.rs:51:22
[INFO] [stdout]    |
[INFO] [stdout] 51 |     let mut viewer = PointCloudViewer::new().await?;
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^^^ use of undeclared type `PointCloudViewer`
[INFO] [stdout]    |
[INFO] [stdout] help: a struct with a similar name exists
[INFO] [stdout]    |
[INFO] [stdout] 51 -     let mut viewer = PointCloudViewer::new().await?;
[INFO] [stdout] 51 +     let mut viewer = PointCloudView::new().await?;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0282]: type annotations needed
[INFO] [stdout]   --> src/lib.rs:51:9
[INFO] [stdout]    |
[INFO] [stdout] 51 |     let mut viewer = PointCloudViewer::new().await?;
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 52 |     viewer.add_point_cloud(&cloud, "scene")?;
[INFO] [stdout]    |     ------ type must be known at this point
[INFO] [stdout]    |
[INFO] [stdout] help: consider giving `viewer` an explicit type
[INFO] [stdout]    |
[INFO] [stdout] 51 |     let mut viewer: /* Type */ = PointCloudViewer::new().await?;
[INFO] [stdout]    |                   ++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0752]: `main` function is not allowed to be `async`
[INFO] [stdout]   --> src/lib.rs:48:1
[INFO] [stdout]    |
[INFO] [stdout] 48 | async fn main() -> Result<()> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `main` function is not allowed to be `async`
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 4 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0282, E0433, E0752.
[INFO] [stdout] For more information about an error, try `rustc --explain E0282`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 19) stdout ----
[INFO] [stdout] Test executable failed (exit status: 1).
[INFO] [stdout] 
[INFO] [stdout] stderr:
[INFO] [stdout] Error: Io(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" })
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/lib.rs - (line 19)
[INFO] [stdout]     src/lib.rs - (line 43)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.24s
[INFO] [stdout] 
[INFO] [stdout] all doctests ran in 1.65s; merged doctests compilation took 0.41s
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] running `Command { std: "docker" "inspect" "d8b5957715afbf736b6126594ad76fa126afb3861295541803462f62f390a477", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d8b5957715afbf736b6126594ad76fa126afb3861295541803462f62f390a477", kill_on_drop: false }`
[INFO] [stdout] d8b5957715afbf736b6126594ad76fa126afb3861295541803462f62f390a477
